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