OpenShift-クラスター
OpenShiftは、OpenShiftクラスターをセットアップするために2つのインストール方法を使用します。
- クイックインストール方法
- 高度な構成方法
クラスターのセットアップ
クイックインストール方法
この方法は、未達成のクラスターセットアップ構成をすばやく実行するために使用されます。この方法を使用するには、最初にインストーラーをインストールする必要があります。これは、次のコマンドを実行することで実行できます。
Interactive method
$ atomic-openshift-installer install
これは、インタラクティブなセットアップを実行したい場合に便利です。
Unattended installation method
この方法は、ユーザーが構成yamlファイルを定義し、その下に配置できる、無人のインストール方法を設定する場合に使用されます。 ~/.config/openshift/Installer.cfg.ymlという名前で。次に、次のコマンドを実行して、–u tag。
$ atomic-openshift-installer –u install
デフォルトでは、下にある構成ファイルを使用します ~/.config/openshift/。一方、Ansibleはインストールのバックアップとして使用されます。
version: v2
variant: openshift-enterprise
variant_version: 3.1
ansible_log_path: /tmp/ansible.log
deployment:
ansible_ssh_user: root
hosts:
- ip: 172.10.10.1
hostname: vklnld908.int.example.com
public_ip: 24.222.0.1
public_hostname: master.example.com
roles:
- master
- node
containerized: true
connect_to: 24.222.0.1
- ip: 172.10.10.2
hostname: vklnld1446.int.example.com
public_ip: 24.222.0.2
public_hostname: node1.example.com
roles:
- node
connect_to: 10.0.0.2
- ip: 172.10.10.3
hostname: vklnld1447.int.example.com
public_ip: 10..22.2.3
public_hostname: node2.example.com
roles:
- node
connect_to: 10.0.0.3
roles:
master:
<variable_name1>: "<value1>"
<variable_name2>: "<value2>"
node:
<variable_name1>: "<value1>"
ここに、特定の変数を設定したい場合に定義できる役割固有の変数があります。
完了したら、次のコマンドを使用してインストールを確認できます。
$ oc get nodes
NAME STATUS AGE
master.example.com Ready 10d
node1.example.com Ready 10d
node2.example.com Ready 10d
高度なインストール
高度なインストールは完全にAnsible構成に基づいており、マスターとノードの構成に関する完全なホスト構成と変数の定義が存在します。これには、構成に関するすべての詳細が含まれています。
セットアップが完了し、プレイブックの準備ができたら、次のコマンドを実行してクラスターをセットアップできます。
$ ansible-playbook -i inventry/hosts ~/openshift-ansible/playbooks/byo/config.yml
クラスターへのホストの追加
−を使用してクラスターにホストを追加できます
- クイックインストーラーツール
- 高度な構成方法
Quick installation toolインタラクティブモードと非インタラクティブモードの両方で機能します。次のコマンドを使用します。
$ atomic-openshift-installer -u -c </path/to/file> scaleup
アプリケーション構成ファイルの外観をスケーリングする形式は、マスターとノードの両方を追加するために使用できます。
高度な構成方法
この方法では、Ansibleのホストファイルを更新してから、このファイルに新しいノードまたはサーバーの詳細を追加します。設定ファイルは次のようになります。
[OSEv3:children]
masters
nodes
new_nodes
new_master
同じAnsibleホストファイルに、以下に示すように、新しいノードに関する変数の詳細を追加します。
[new_nodes]
vklnld1448.int.example.com openshift_node_labels = "{'region': 'primary', 'zone': 'east'}"
最後に、更新されたホストファイルを使用して、新しい構成を実行し、構成ファイルを呼び出して、次のコマンドを使用してセットアップを完了します。
$ ansible-playbook -i /inventory/hosts /usr/share/ansible/openshift-ansible/playbooks/test/openshift-node/scaleup.yml
クラスタログの管理
OpenShiftクラスターログは、クラスターのマスターマシンとノードマシンから生成されるログに他なりません。これらは、サーバーログ、マスターログ、コンテナログ、ポッドログなど、あらゆる種類のログを管理できます。コンテナログ管理には複数のテクノロジとアプリケーションが存在します。
リストされているツールのいくつかは、ログ管理のために実装できます。
- Fluentd
- ELK
- Kabna
- Nagios
- Splunk
ELK stack−このスタックは、すべてのノードからログを収集し、体系的な形式で表示する場合に役立ちます。ELKスタックは、主に3つの主要なカテゴリに分類されます。
ElasticSearch −主に、すべてのコンテナから情報を収集し、中央の場所に配置する責任があります。
Fluentd −収集したログをelasticsearchコンテナエンジンにフィードするために使用されます。
Kibana −収集されたデータをグラフィカルインターフェイスで有用な情報として表示するために使用されるグラフィカルインターフェイス。
注意すべき重要な点の1つは、このシステムがクラスターにデプロイされると、すべてのノードからログの収集を開始することです。
ログ診断
OpenShiftには組み込みがあります oc adm dignostics複数のエラー状況の分析に使用できるOCを使用したコマンド。このツールは、マスターからクラスター管理者として使用できます。このユーティリティは、既知の問題のトラブルシューティングと診断に非常に役立ちます。これは、マスタークライアントとノードで実行されます。
アグリメントやフラグなしで実行すると、クライアント、サーバー、およびノードのマシンの構成ファイルを検索し、それらを診断に使用します。次の引数を渡すことにより、診断を個別に実行できます-
- AggregatedLogging
- AnalyzeLogs
- ClusterRegistry
- ClusterRoleBindings
- ClusterRoles
- ClusterRouter
- ConfigContexts
- DiagnosticPod
- MasterConfigCheck
- MasterNode
- MetricsApiProxy
- NetworkCheck
- NodeConfigCheck
- NodeDefinitions
- ServiceExternalIPs
- UnitStatus
次のコマンドで簡単に実行できます。
$ oc adm diagnostics <DiagnosticName>
クラスターのアップグレード
クラスターのアップグレードには、クラスター内の複数のものをアップグレードし、クラスターを新しいコンポーネントとアップグレードで更新することが含まれます。これには以下が含まれます-
- マスターコンポーネントのアップグレード
- ノードコンポーネントのアップグレード
- ポリシーのアップグレード
- ルートのアップグレード
- 画像ストリームのアップグレード
これらすべてのアップグレードを実行するには、最初にクイックインストーラーまたはユーティリティを配置する必要があります。そのためには、次のユーティリティを更新する必要があります-
- atomic-openshift-utils
- atomic-openshift-excluder
- atomic-openshift-docker-excluder
- etcdパッケージ
アップグレードを開始する前に、マスターマシンでetcdをバックアップする必要があります。これは、次のコマンドを使用して実行できます。
$ ETCD_DATA_DIR = /var/lib/origin/openshift.local.etcd
$ etcdctl backup \
--data-dir $ETCD_DATA_DIR \
--backup-dir $ETCD_DATA_DIR.bak.<date>
マスターコンポーネントのアップグレード
OpenShiftマスターでは、etcdファイルを更新してからDockerに移行することでアップグレードを開始します。最後に、自動実行機能を実行して、クラスターを必要な位置に配置します。ただし、アップグレードを開始する前に、まず各マスターでアトミックopenshiftパッケージをアクティブ化する必要があります。これは、次のコマンドを使用して実行できます。
Step 1 −atomic-openshiftパッケージを削除します
$ atomic-openshift-excluder unexclude
Step 2 −すべてのマスターのetcdをアップグレードします。
$ yum update etcd
Step 3 − etcdのサービスを再起動し、正常に開始されたかどうかを確認します。
$ systemctl restart etcd
$ journalctl -r -u etcd
Step 4 −Dockerパッケージをアップグレードします。
$ yum update docker
Step 5 − Dockerサービスを再起動し、正しく起動しているかどうかを確認します。
$ systemctl restart docker
$ journalctl -r -u docker
Step 6 −完了したら、次のコマンドを使用してシステムを再起動します。
$ systemctl reboot
$ journalctl -r -u docker
Step 7 −最後に、atomic-executerを実行して、パッケージをyumexcludesのリストに戻します。
$ atomic-openshift-excluder exclude
ポリシーをアップグレードするためのそのような強制はありません。推奨された場合にのみアップグレードする必要があります。これは、次のコマンドで確認できます。
$ oadm policy reconcile-cluster-roles
ほとんどの場合、ポリシー定義を更新する必要はありません。
ノードコンポーネントのアップグレード
マスターの更新が完了したら、ノードのアップグレードを開始できます。覚えておくべきことの1つは、クラスター内のあらゆる種類の問題を回避するために、アップグレードの期間を短くする必要があるということです。
Step 1 −アップグレードを実行するすべてのノードからすべてのアトミックOpenShiftパッケージを削除します。
$ atomic-openshift-excluder unexclude
Step 2 −次に、アップグレード前にノードスケジューリングを無効にします。
$ oadm manage-node <node name> --schedulable = false
Step 3 −現在のホストから他のホストにすべてのノードを複製します。
$ oadm drain <node name> --force --delete-local-data --ignore-daemonsets
Step 4 −ホスト上のDockerセットアップをアップグレードします。
$ yum update docker
Step 5 − Dockerサービスを再起動してから、Dockerサービスノードを起動します。
$systemctl restart docker
$ systemctl restart atomic-openshift-node
Step 6 −両方が正しく起動したかどうかを確認します。
$ journalctl -r -u atomic-openshift-node
Step 7 −アップグレードが完了したら、ノードマシンを再起動します。
$ systemctl reboot
$ journalctl -r -u docker
Step 8 −ノードでスケジューリングを再度有効にします。
$ oadm manage-node <node> --schedulable.
Step 9 −アトミックopenshiftエグゼキュータを実行して、OpenShiftパッケージをノードに戻します。
$ atomic-openshift-excluder exclude
Step 10 −最後に、すべてのノードが使用可能かどうかを確認します。
$ oc get nodes
NAME STATUS AGE
master.example.com Ready 12d
node1.example.com Ready 12d
node2.example.com Ready 12d