3.5.6.2.3. 사용자 정의 바인딩
odo link
는 구성 요소에 사용자 정의 바인딩 정보를 삽입할 수 있는 --map
플래그를 허용합니다. 이러한 바인딩 정보는 구성 요소에 연결하는 리소스의 매니페스트에서 가져옵니다. 예를 들어 백엔드 구성 요소 및 PostgreSQL 서비스의 컨텍스트에서 PostgreSQL 서비스의 매니페스트 postgrescluster.yaml
파일의 정보를 백엔드 구성 요소에 삽입할 수 있습니다.
PostgresCluster
서비스의 이름이 hippo
(또는 PostgresCluster 서비스
의 이름이 다르게 지정되는 경우)인 경우 해당 YAML 정의의 postgresVersion
값을 백엔드 구성 요소에 삽입하려면 명령을 실행합니다.
$ odo link PostgresCluster/hippo --map pgVersion='{{ .hippo.spec.postgresVersion }}'
Postgres 서비스의 이름이 hippo
와 다른 경우, pgVersion
값으로 .hippo
대신 위의 명령에 해당 이름을 지정해야 합니다.
링크 작업 후 odo push
를 정상적으로 실행합니다. 푸시 작업이 완료되면 백엔드 구성 요소 디렉터리에서 다음 명령을 실행하여 사용자 정의 매핑이 올바르게 삽입되었는지 확인할 수 있습니다.
$ odo exec -- env | grep pgVersion
출력 예:
pgVersion=13
사용자 정의 바인딩 정보를 두 개 이상 삽입하려는 경우 odo link
는 여러 개의 키-값 쌍의 매핑을 허용합니다. 유일한 제약 조건은 이러한 값을 --map <key>=<value>로 지정해야 한다는 것입니다
. 예를 들어, PostgreSQL 이미지 정보를 버전과 함께 삽입하려면 다음을 실행할 수 있습니다.
$ odo link PostgresCluster/hippo --map pgVersion='{{ .hippo.spec.postgresVersion }}' --map pgImage='{{ .hippo.spec.image }}'
odo push
를 실행합니다. 두 매핑이 모두 올바르게 삽입되었는지 확인하려면 다음 명령을 실행합니다.
$ odo exec -- env | grep -e "pgVersion\|pgImage"
출력 예:
pgVersion=13 pgImage=registry.developers.crunchydata.com/crunchydata/crunchy-postgres-ha:centos8-13.4-0
3.5.6.2.3.1. 인라인으로, 또는 아니오?
odo 링크가
대한 매니페스트 파일을 생성하는 기본 동작을 허용할 수 있습니다. 또는 모든 것을 단일 kubernetes/
디렉터리에 링크에devfile.yaml
파일에 저장하려는 경우 --inlined
플래그를 사용할 수 있습니다.