11.4. OpenShift Container Platform에 애플리케이션 배포
OpenShift Container Platform에 애플리케이션을 배포할 수 있습니다.
rails-app
프로젝트를 생성하면 자동으로 새 프로젝트 네임스페이스로 전환됩니다.
OpenShift Container Platform에서 애플리케이션을 배포하려면 다음 세 단계를 수행해야 합니다.
- OpenShift Container Platform의 PostgreSQL 이미지에서 데이터베이스 서비스를 생성합니다.
- 데이터베이스 서비스와 연결된 OpenShift Container Platform의 Ruby 2.0 빌더 이미지 및 Ruby on Rails 소스 코드에서 프런트 엔드 서비스를 생성합니다.
- 애플리케이션 경로를 생성합니다.
절차
Ruby on Rails 애플리케이션을 배포하려면 애플리케이션을 위한 새 프로젝트를 생성합니다.
$ oc new-project rails-app --description="My Rails application" --display-name="Rails Application"
11.4.1. 데이터베이스 서비스 생성
Rails 애플리케이션에는 실행 중인 데이터베이스 서비스가 필요합니다. 이 서비스의 경우 PostgreSQL 데이터베이스 이미지를 사용합니다.
데이터베이스 서비스를 생성하려면 oc new-app
명령을 사용합니다. 데이터베이스 컨테이너 내에서 사용할 몇 가지 필요한 환경 변수를 이 명령으로 전달해야 합니다. 이러한 환경 변수는 사용자 이름, 암호 및 데이터베이스 이름을 설정하는 데 필요합니다. 이러한 환경 변수 값은 원하는 대로 변경할 수 있습니다. 변수는 다음과 같습니다.
- POSTGRESQL_DATABASE
- POSTGRESQL_USER
- POSTGRESQL_PASSWORD
이러한 변수를 설정하면 다음과 같은 결과를 얻을 수 있습니다.
- 지정된 이름의 데이터베이스가 있습니다.
- 지정된 이름의 사용자가 있습니다.
- 사용자가 지정된 암호를 사용하여 지정된 데이터베이스에 액세스할 수 있습니다.
프로세스
데이터베이스 서비스를 생성합니다.
$ oc new-app postgresql -e POSTGRESQL_DATABASE=db_name -e POSTGRESQL_USER=username -e POSTGRESQL_PASSWORD=password
데이터베이스 관리자의 암호도 설정하려면 다음 행을 이전 명령에 추가합니다.
-e POSTGRESQL_ADMIN_PASSWORD=admin_pw
진행 상황을 확인합니다.
$ oc get pods --watch
11.4.2. 프런트 엔드 서비스 생성
애플리케이션을 OpenShift Container Platform으로 가져오려면 애플리케이션이 상주하는 리포지터리를 지정해야 합니다.
프로세스
프런트 엔드 서비스를 생성하고 데이터베이스 서비스를 생성할 때 설정된 데이터베이스 관련 환경 변수를 지정합니다.
$ oc new-app path/to/source/code --name=rails-app -e POSTGRESQL_USER=username -e POSTGRESQL_PASSWORD=password -e POSTGRESQL_DATABASE=db_name -e DATABASE_SERVICE_NAME=postgresql
OpenShift Container Platform은 이 명령을 사용하여 소스 코드를 가져와서 빌더를 설정하고, 애플리케이션 이미지를 빌드하며, 새로 생성된 이미지를 지정된 환경 변수와 함께 배포합니다. 애플리케이션 이름은
rails-app
으로 지정됩니다.rails-app
배포 구성의 JSON 문서를 보고 환경 변수가 추가되었는지 확인합니다.$ oc get dc rails-app -o json
다음 섹션이 표시되어야 합니다.
출력 예
env": [ { "name": "POSTGRESQL_USER", "value": "username" }, { "name": "POSTGRESQL_PASSWORD", "value": "password" }, { "name": "POSTGRESQL_DATABASE", "value": "db_name" }, { "name": "DATABASE_SERVICE_NAME", "value": "postgresql" } ],
빌드 프로세스를 확인합니다.
$ oc logs -f build/rails-app-1
빌드가 완료되면 OpenShift Container Platform에서 실행 중인 Pod를 확인합니다.
$ oc get pods
myapp-<number>-<hash>
로 시작되는 행이 표시되어야 합니다. OpenShift Container Platform에서 실행 중인 애플리케이션을 나타냅니다.애플리케이션이 작동하려면 데이터베이스 마이그레이션 스크립트를 실행하여 데이터베이스를 초기화해야 합니다. 이 작업을 수행하는 방법은 다음 두 가지입니다.
실행 중인 프런트 엔드 컨테이너에서 수동으로 수행합니다.
rsh
명령을 사용하여 프런트 엔드 컨테이너에 대해 실행합니다.$ oc rsh <frontend_pod_id>
컨테이너 내부에서 마이그레이션을 실행합니다.
$ RAILS_ENV=production bundle exec rake db:migrate
Rails 애플리케이션을
development
또는test
환경에서 실행 중인 경우RAILS_ENV
환경 변수를 지정할 필요가 없습니다.
- 템플릿에 사전 배포 라이프사이클 후크를 추가하여 수행합니다.
11.4.3. 애플리케이션 경로 생성
서비스를 공개하여 애플리케이션 경로를 생성할 수 있습니다.
프로세스
www.example.com
과 같이 외부에서 접근할 수 있는 호스트 이름을 지정하여 서비스를 공개하려면 OpenShift Container Platform 경로를 사용합니다. 이 경우 다음을 입력하여 프런트 엔드 서비스를 공개해야 합니다.$ oc expose service rails-app --hostname=www.example.com
지정한 호스트 이름이 라우터의 IP 주소로 해석되는지 확인하십시오.