第2章 3scale 2.5 から 2.6 へのアップグレード


前提条件

  • Red Hat 3scale API Management 2.5 がプロジェクトにデプロイされている。
  • ツールの前提条件

    • base64
    • jq

手順

3scale API Management 2.5 を 2.6 にアップグレードするには、3scale がデプロイされているプロジェクトに移動します。

$ oc project <3scale-project>

続いて、以下の順序で手順を実行します。

2.1. 3scale プロジェクトのバックアップディレクトリーの作成

3scale プロジェクトのバックアップディレクトリーを作成するには、以下の手順に従います。{BACKUP_DIR} は、3scale バックアップのマシン上の場所であることに 注意 してください。

手順

  1. バックアップディレクトリーを作成します。

    mkdir ${BACKUP_DIR}
  2. バックアップ用のディレクトリーおよびサブディレクトリーを作成します。

    mkdir ${BACKUP_DIR}/system-database ${BACKUP_DIR}/zync-database ${BACKUP_DIR}/system-redis ${BACKUP_DIR}/backend-redis ${BACKUP_DIR}/system-app ${BACKUP_DIR}/openshift
    
    mkdir ${BACKUP_DIR}/openshift/configmaps/ ${BACKUP_DIR}/openshift/deploymentConfigs ${BACKUP_DIR}/openshift/imageStreams ${BACKUP_DIR}/openshift/other/ ${BACKUP_DIR}/openshift/routes/ ${BACKUP_DIR}/openshift/secrets/ ${BACKUP_DIR}/openshift/services/

2.1.1. system-database (MySQL) のバックアップ

system-mysql データベースをダンプし、ダンプを ${BACKUP_DIR}/system-database/system-mysql-backup.gz 内に保存します。

oc rsh $(oc get pods -l 'deploymentConfig=system-mysql' -o json | jq -r '.items[0].metadata.name') bash -c 'export MYSQL_PWD=${MYSQL_ROOT_PASSWORD}; mysqldump --single-transaction -hsystem-mysql -uroot system' | gzip > ${BACKUP_DIR}/system-database/system-mysql-backup.gz

2.1.2. zync-database のバックアップ

zync-database PostrgreSQL データベースをダンプし、ダンプを ${BACKUP_DIR}/zync-database/zync-database-backup.gz 内に保存します。

oc rsh $(oc get pods -l 'deploymentConfig=zync-database' -o json | jq '.items[0].metadata.name' -r) bash -c 'pg_dumpall -c --if-exists' | gzip > ${BACKUP_DIR}/zync-database/zync-database-backup.gz

2.1.3. system-redis のバックアップ

${BACKUP_DIR}/system-redis/system-redis-dump.rdb 内に system-redis ダンプを抽出します

oc cp $(oc get pods -l 'deploymentConfig=system-redis' -o json | jq '.items[0].metadata.name' -r):/var/lib/redis/data/dump.rdb ${BACKUP_DIR}/system-redis/system-redis-dump.rdb

2.1.4. backend-redis のバックアップ

${BACKUP_DIR}/backend-redis/backend-redis-dump.rdb 内に backend-redis ダンプを抽出します。

oc cp $(oc get pods -l 'deploymentConfig=backend-redis' -o json | jq '.items[0].metadata.name' -r):/var/lib/redis/data/dump.rdb ${BACKUP_DIR}/backend-redis/backend-redis-dump.rdb

2.1.5. system-app 永続データのバックアップ

${BACKUP_DIR}/system-app/ 内に system-app 永続データをコピーします。

oc rsync $(oc get pods -l 'deploymentConfig=system-app' -o json | jq '.items[0].metadata.name' -r):/opt/system/public/system ${BACKUP_DIR}/system-app/

2.1.6. DeploymentConfig のバックアップ

for object in `oc get dc | awk '{print $1}' | grep -v NAME`; do oc get -o yaml --export dc ${object} > ${BACKUP_DIR}/openshift/deploymentConfigs/${object}_dc.yaml; done

2.1.7. ImageStream のバックアップ

for object in `oc get is | awk '{print $1}' | grep -v NAME`; do oc get -o yaml --export is ${object} > ${BACKUP_DIR}/openshift/imageStreams/${object}_is.yaml; done

2.1.8. シークレットのバックアップ

トークンとシークレットのデフォルトのビルダーとデプロイヤーを除くすべてをバックアップします。

for object in `oc get secret | awk '{print $1}' | grep -v NAME | grep -v default | grep -v builder | grep -v deployer`; do oc get -o yaml --export secret ${object} > ${BACKUP_DIR}/openshift/secrets/${object}_secret.yaml; done

2.1.9. サービスのバックアップ

for object in `oc get svc | awk '{print $1}' | grep -v NAME`; do oc get -o yaml --export svc ${object} > ${BACKUP_DIR}/openshift/services/${object}_svc.yaml; done

2.1.10. アップルートのバックアップ

for object in `oc get routes | awk '{print $1}' | grep -v NAME`; do oc get -o yaml --export route ${object} > ${BACKUP_DIR}/openshift/routes/${object}_route.yaml; done

2.1.11. ConfigMap のバックアップ

for object in `oc get cm | awk '{print $1}' | grep -v NAME`; do oc get -o yaml --export cm ${object} > ${BACKUP_DIR}/openshift/configmaps/${object}_cm.yaml; done

2.1.12. その他のリソースのバックアップ

バックアップオブジェクトではないその他のカスタムリソースを処理するために、2 番目のバックアップを作成します。

oc get -o yaml --export all > ${BACKUP_DIR}/openshift/other/threescale-project-elements.yaml

for object in rolebindings serviceaccounts secrets imagestreamtags cm rolebindingrestrictions limitranges resourcequotas pvc templates cronjobs statefulsets hpa deployments replicasets poddisruptionbudget endpoints; do
   oc get -o yaml --export $object > ${BACKUP_DIR}/openshift/other/$object.yaml; done
Red Hat logoGithubRedditYoutubeTwitter

詳細情報

試用、購入および販売

コミュニティー

Red Hat ドキュメントについて

Red Hat をお使いのお客様が、信頼できるコンテンツが含まれている製品やサービスを活用することで、イノベーションを行い、目標を達成できるようにします。

多様性を受け入れるオープンソースの強化

Red Hat では、コード、ドキュメント、Web プロパティーにおける配慮に欠ける用語の置き換えに取り組んでいます。このような変更は、段階的に実施される予定です。詳細情報: Red Hat ブログ.

会社概要

Red Hat は、企業がコアとなるデータセンターからネットワークエッジに至るまで、各種プラットフォームや環境全体で作業を簡素化できるように、強化されたソリューションを提供しています。

© 2024 Red Hat, Inc.