OpenShift-クイックガイド

OpenShiftは、Red Hatがホストするクラウド開発Platformas a Service(PaaS)です。これは、アプリケーションを作成、テスト、実行し、最終的にクラウドにデプロイするために使用される、オープンソースのクラウドベースのユーザーフレンドリーなプラットフォームです。

OpenShiftは、Node.js、Ruby、Python、Perl、Javaなどのさまざまな言語で記述されたアプリケーションを管理できます。OpenShiftの重要な機能の1つは拡張可能であり、ユーザーが他の言語で記述されたアプリケーションをサポートするのに役立ちます。

OpenShiftには、抽象化レイヤーとして仮想化のさまざまな概念が付属しています。OpenShiftの背後にある基本的な概念は、仮想化に基づいています。

仮想化

一般に、仮想化は、システム、ストレージ、またはオペレーティングシステムから始まるものの物理的または実際のバージョンではなく、仮想システムの作成として定義できます。仮想化の主な目標は、ITインフラストラクチャをよりスケーラブルで信頼性の高いものにすることです。仮想化の概念は数十年前から存在しており、今日のIT業界の進化に伴い、システムレベル、ハードウェアレベルから、サーバーレベルの仮想化までの幅広いレイヤーに適用できます。

使い方

これは、任意のアプリケーションまたはオペレーティングシステムが実際の物理層から抽象化されるテクノロジーとして説明できます。仮想化テクノロジーの主な用途の1つはサーバー仮想化です。これは、ハイパーバイザーと呼ばれるソフトウェアを使用して、基盤となるハードウェアからレイヤーを抽象化します。仮想化で実行されているオペレーティングシステムのパフォーマンスは、物理ハードウェアで実行されている場合と同じくらい良好です。ただし、実行中のシステムとアプリケーションのほとんどは基盤となるハードウェアを使用する必要がないため、仮想化の概念は一般的です。

物理アーキテクチャと仮想アーキテクチャ

仮想化の種類

  • Application Virtualization−この方法では、アプリケーションは基盤となるオペレーティングシステムから抽象化されます。この方法は、アプリケーションをその下のオペレーティングシステムに依存せずに単独で実行できる場合に非常に便利です。

  • Desktop Virtualization−この方法は、デスクのシンクライアントを使用してリモートでデスクトップにアクセスできるワークステーションの負荷を軽減するために使用されます。この方法では、デスクトップは主にデータセンターで実行されます。典型的な例は、ほとんどの組織で使用されている仮想デスクトップイメージ(VDI)です。

  • Data Virtualization −これは、従来のデータおよびデータ管理の方法を抽象化して回避する方法です。

  • Server Virtualization−この方法では、物理サーバー、プロセス、およびオペレーティングシステムを含むサーバー関連のリソースが仮想化されます。この抽象化を可能にするソフトウェアは、ハイパーバイザーと呼ばれることがよくあります。

  • Storage Virtualization −これは、複数のストレージデバイスを単一の中央コンソールから管理される単一のストレージデバイスにプールするプロセスです。

  • Network Virtualization −これは、利用可能なすべてのネットワークリソースを、それぞれが互いに独立している利用可能な帯域幅とチャネルを分割することによって結合する方法です。

OpenShift

OpenShiftは、クラウド対応のアプリケーションPlatform as a Service(PaaS)です。これは、組織が従来のアプリケーションインフラストラクチャとプラットフォームを物理的な仮想メディアからクラウドに移行するのに役立つオープンソーステクノロジーです。

OpenShiftは非常に多様なアプリケーションをサポートしており、OpenShiftクラウドプラットフォームで簡単に開発およびデプロイできます。OpenShiftは基本的に、開発者とユーザー向けに3種類のプラットフォームをサポートしています。

サービスとしてのインフラストラクチャ(IaaS)

この形式では、サービスプロバイダーは、ハードウェアレベルの仮想マシンに事前定義された仮想ハー​​ドウェア構成を提供します。このスペースには、AWS Googleクラウド、Rackspaceなどをはじめとする複数の競合他社があります。

セットアップと投資の長い手順の後にIaaSを使用することの主な欠点は、オペレーティングシステムとサーバーパッケージのインストールと保守、インフラストラクチャのネットワークの管理、および基本的なシステム管理の管理を引き続き担当することです。

サービスとしてのソフトウェア(SaaS)

SaaSを使用すると、基盤となるインフラストラクチャについての心配が最も少なくなります。プラグアンドプレイと同じくらい簡単で、ユーザーはサービスにサインアップして使用を開始するだけです。この設定の主な欠点は、サービスプロバイダーによって許可されている最小限のカスタマイズしか実行できないことです。SaaSの最も一般的な例の1つはGmailで、ユーザーはログインして使用を開始するだけです。ユーザーは、自分のアカウントにいくつかの小さな変更を加えることもできます。ただし、開発者の観点からはあまり役に立ちません。

Platform as a Service(PaaS)

これは、SaaSとIaaSの中間層と見なすことができます。PaaS評価の主なターゲットは、開発環境をいくつかのコマンドで起動できる開発者向けです。これらの環境は、データベースを備えたWebアプリケーションサーバーを使用するだけでなく、すべての開発ニーズを満たすことができるように設計されています。これを行うには、1つのコマンドが必要であり、サービスプロバイダーが代行します。

OpenShiftを使用する理由

OpenShiftは、エンタープライズユニットが基盤となるオペレーティングシステムを気にすることなくアプリケーションをクラウド上でホストするための共通プラットフォームを提供します。これにより、アプリケーションのクラウドでの使用、開発、およびデプロイが非常に簡単になります。重要な機能の1つは、あらゆる種類の開発とテストのための管理されたハードウェアとネットワークリソースを提供することです。OpenShiftを使用すると、PaaS開発者は必要な環境を仕様に基づいて自由に設計できます。

OpenShiftは、サービスプランに関してさまざまな種類のサービスレベルアグリーメントを提供します。

Free −このプランは3年間に制限されており、それぞれに1GBのスペースがあります。

Bronze −このプランには3年間が含まれ、年間1GBのスペースで最大16年間拡張されます。

Sliver −これはブロンズの16年間の計画ですが、追加費用なしで6GBのストレージ容量があります。

上記の機能の他に、OpenShiftはOpenShiftEnterpriseと呼ばれるオンプレミスバージョンも提供します。OpenShiftでは、開発者はスケーラブルなアプリケーションとスケーラブルでないアプリケーションを設計するためのレバレッジを持っており、これらの設計はHAproxyサーバーを使用して実装されます。

特徴

OpenShiftでサポートされる機能は複数あります。それらのいくつかは-

  • 多言語サポート
  • 複数のデータベースのサポート
  • 拡張可能なカートリッジシステム
  • ソースコードバージョン管理
  • ワンクリック展開
  • マルチ環境サポート
  • 標準化された開発者のワークフロー
  • 依存関係とビルド管理
  • 自動アプリケーションスケーリング
  • レスポンシブWebコンソール
  • 豊富なコマンドラインツールセット
  • アプリケーションへのリモートSSHログイン
  • RestAPIサポート
  • セルフサービスのオンデマンドアプリケーションスタック
  • 組み込みのデータベースサービス
  • 継続的インテグレーションとリリース管理
  • IDE統合
  • アプリケーションのリモートデバッグ

OpenShiftは、OpenShift V2という名前のベースから誕生しました。これは、主に年とカートリッジの概念に基づいており、各コンポーネントには、マシンの作成からアプリケーションのデプロイまで、アプリケーションのビルドからデプロイまでの仕様があります。

Cartridges −それらは、環境がそれらを実行するために必要なアプリケーションのタイプと、このセクションで満たされるすべての依存関係から始めて、新しいアプリケーションを構築するための焦点でした。

year−リソース、メモリ、およびCPUに関する特定の仕様を持つベアメタルマシンまたはサーバーとして定義できます。これらは、アプリケーションを実行するための基本的な単位と見なされていました。

Application −これらは、OpenShift環境でデプロイおよび実行されるアプリケーションまたは統合アプリケーションを単に指します。

このセクションをさらに深く掘り下げていく中で、OpenShiftのさまざまなフォーマットとオファリングについて説明します。以前は、OpenShiftには3つのメジャーバージョンがありました。

OpenShift Origin−これはOpenShiftのコミュニティ追加またはオープンソースバージョンでした。他の2つのバージョンのアップストリームプロジェクトとしても知られていました。

OpenShift Online −AWSでホストされるサービスとしてのパブリックPaaSです。

OpenShift Enterprise −は、ISVおよびベンダーライセンスを備えたOpenShiftの強化バージョンです。

OpenShift Online

OpenShift onlineは、パブリッククラウド上でコンテナー化されたアプリケーションを迅速に構築、デプロイ、スケーリングできるOpenShiftコミュニティのオファリングです。これは、Red Hatのパブリッククラウドアプリケーション開発およびホスティングプラットフォームであり、アプリケーションの自動プロビジョニング、管理、およびスケーリングを可能にし、開発者がアプリケーションロジックの記述に集中できるようにします。

Red Hat OpenShiftOnlineでのアカウントの設定

Step 1 −ブラウザにアクセスしてサイトにアクセスします https://manage.openshift.com/

Step 2 − Red Hatアカウントをお持ちの場合は、次のURLを使用してRedHatログインIDとパスワードを使用してOpenShiftアカウントにログインします。 https://developers.redhat.com

Step 3 − Red Hatアカウントにログインしていない場合は、次のリンクを使用してOpenShiftオンラインサービスにサインアップしてください。

https://developers.redhat.com/auth/realms/rhd/login-actions/registration?code=G4w-myLd3GCH_QZCqMUmIOQlU7DIf_gfIvGu38nnzZQ.cb229a9d-3cff-4c58-b7f6-7b2c9eb17926

ログイン後、次のページが表示されます。

すべての準備が整うと、次のスクリーンショットに示すように、RedHatにいくつかの基本的なアカウントの詳細が表示されます。

最後に、ログインすると、次のページが表示されます。

OpenShift Container Platform

OpenShiftコンテナープラットフォームは、開発チームやIT運用チームなどの複数のチームがコンテナー化されたインフラストラクチャーを構築およびデプロイするのに役立つエンタープライズプラットフォームです。OpenShiftに組み込まれているすべてのコンテナーは、非常に信頼性の高いDockerコンテナー化テクノロジーを使用しており、パブリックにホストされているクラウドプラットフォームの任意のデータセンターにデプロイできます。

OpenShiftコンテナープラットフォームは、正式にはOpenShiftEnterprisesと呼ばれていました。これは、サービスとしてのRed Hatオンプレミスプライベートプラットフォームであり、Dockerを利用したアプリケーションコンテナのコアコンセプトに基づいて構築されており、オーケストレーションと管理はKubernetesによって管理されます。

言い換えると、OpenShiftはDockerとKubernetesをエンタープライズレベルに統合します。これは、エンタープライズユニットが独自に選択したインフラストラクチャで申請者を展開および管理するためのコンテナプラットフォームソフトウェアです。たとえば、AWSインスタンスでOpenShiftインスタンスをホストします。

OpenShiftコンテナープラットフォームは、 two package levels

OpenShift Container Local−これは、ローカルマシンにアプリケーションをデプロイしてテストしたい開発者向けです。このパッケージは、主にアプリケーションの開発とテストのために開発チームによって使用されます。

OpenShift Container Lab −これは、開発から製品前環境への展開まで、アプリケーションの拡張評価用に設計されています。

OpenShift専用

これは、OpenShiftのポートフォリオに追加された別のオファリングであり、お客様は、選択したパブリッククラウドのいずれかでコンテナー化されたプラットフォームをホストすることを選択できます。これにより、エンドユーザーはマルチクラウドサービスの真の感覚を得ることができ、ニーズを満たす任意のクラウドでOpenShiftを使用できます。

これは、エンドユーザーがOpenShiftを使用してテストデプロイを構築し、クラウドでホストされているOpenShiftでアプリケーションを実行できるRedHatの最新の製品の1つです。

OpenShiftDedicatedの機能

OpenShift専用は、パブリッククラウド上でカスタマイズされたソリューションアプリケーションプラットフォームを提供し、OpenShift3テクノロジーから継承されます。

  • Extensible and Open −これはDockerのオープンコンセプトに基づいて構築されており、クラウドにデプロイされているため、必要に応じてそれ自体を消費できます。

  • Portability − Dockerを使用して構築されているため、Dockerで実行されているアプリケーションは、Dockerがサポートされている場所から別の場所に簡単に出荷できます。

  • Orchestration − OpenShift 3では、コンテナーオーケストレーションとクラスター管理の主要な機能の1つが、OpenShiftバージョン3で提供されるようになったKubernetesを使用してサポートされます。

  • Automation −このバージョンのOpenShiftは、ソースコード管理、ビルド自動化、およびデプロイメント自動化の機能を備えており、Platform as aServiceプロバイダーとして市場で非常に人気があります。

OpenShiftの競合他社

Google App Engine−これは、Webアプリケーションを開発およびホストするためのGoogleの無料プラットフォームです。Googleのアプリエンジンは、迅速な開発とデプロイのプラットフォームを提供します。

Microsoft Azure − Azureクラウドは、Microsoftのデータセンターでホストされています。

Amazon Elastic Cloud Compute −これらはAmazonが提供する組み込みサービスであり、クラウド上でスケーラブルなWebアプリケーションを開発およびホストするのに役立ちます。

Cloud Foundry −は、Java、Ruby、Python、およびNode.jsアプリケーション用のオープンソースPaaSプラットフォームです。

CloudStack − ApacheのCloudStackは、Citrixによって開発されたプロジェクトであり、OpenShiftおよびOpenStackの直接の競合相手になるように設計されています。

OpenStack −クラウドコンピューティングのためにRedHatが提供するもう1つのクラウドテクノロジー。

Kubernetes −これは、Dockerコンテナーを管理するために構築された直接オーケストレーションおよびクラスター管理テクノロジーです。

OpenShiftは、KubernetesとDockerクラスターを使用して各レイヤーが他のレイヤーと緊密にバインドされたレイヤードシステムです。OpenShiftのアーキテクチャーは、Kubernetesを使用してすべてのレイヤーの上でホストされるDockerコンテナーをサポートおよび管理できるように設計されています。以前のバージョンのOpenShiftV2とは異なり、新しいバージョンのOpenShiftV3はコンテナー化されたインフラストラクチャーをサポートします。このモデルでは、Dockerは軽量Linuxベースのコンテナーの作成を支援し、Kubernetesは複数のホスト上のコンテナーを調整および管理するタスクをサポートします。

OpenShiftのコンポーネント

OpenShiftアーキテクチャーの重要なコンポーネントの1つは、Kubernetesでコンテナー化されたインフラストラクチャーを管理することです。Kubernetesは、インフラストラクチャのデプロイと管理を担当します。どのKubernetesクラスターでも、複数のマスターと複数のノードを使用できるため、セットアップで障害が発生することはありません。

Kubernetesマスターマシンコンポーネント

Etcd−クラスター内の各ノードで使用できる構成情報を格納します。これは、複数のノードに分散できる高可用性のKey ValueStoreです。機密情報が含まれている可能性があるため、KubernetesAPIサーバーからのみアクセスできるようにする必要があります。これは、すべての人がアクセスできる分散キーバリューストアです。

API Server− Kubernetesは、APIを使用してクラスター上のすべての操作を提供するAPIサーバーです。APIサーバーは、さまざまなツールやライブラリが簡単に通信できることを意味するインターフェイスを実装しています。kubeconfigは、通信に使用できるサーバー側ツールと一緒のパッケージです。KubernetesAPIを公開します。」

Controller Manager−このコンポーネントは、クラスターの状態を調整してタスクを実行するほとんどのコレクターを担当します。これは、非終了ループで実行され、情報の収集とAPIサーバーへの送信を担当するデーモンと見なすことができます。これは、クラスターの共有状態を取得し、サーバーの現在のステータスを目的の状態にするために変更を加えるために機能します。主要なコントローラーは、レプリケーションコントローラー、エンドポイントコントローラー、名前空間コントローラー、およびサービスアカウントコントローラーです。コントローラマネージャは、ノードやエンドポイントなどを処理するためにさまざまな種類のコントローラを実行します。

Scheduler−これはKubernetesマスターの重要なコンポーネントです。これは、ワークロードの分散を担当するマスターのサービスです。これは、クラスターノードの作業負荷の使用率を追跡し、リソースが使用可能なワークロードを配置して、ワークロードを受け入れる役割を果たします。言い換えると、これはポッドを使用可能なノードに割り当てるためのメカニズムです。スケジューラーは、ワークロードの使用率とポッドの新しいノードへの割り当てを担当します。

Kubernetesノードコンポーネント

以下は、Kubernetesマスターと通信するために必要なノードサーバーの主要コンポーネントです。

Docker −各ノードの最初の要件はDockerです。これは、比較的分離されているが軽量のオペレーティング環境でカプセル化されたアプリケーションコンテナを実行するのに役立ちます。

Kubelet Service−これは各ノードの小さなサービスであり、コントロールプレーンサービスとの間で情報を中継する役割を果たします。etcdストアと対話して、構成の詳細とライト値を読み取ります。これはマスターコンポーネントと通信して、コマンドを受信して​​動作します。その後、kubeletプロセスは、作業状態とノードサーバーを維持する責任を負います。ネットワークルール、ポートフォワーディングなどを管理します。

Kubernetes Proxy Service−これは、各ノードで実行されるプロキシサービスであり、外部ホストがサービスを利用できるようにするのに役立ちます。リクエストを正しいコンテナに転送するのに役立ちます。Kubernetes Proxy Serviceは、プリミティブな負荷分散を実行できます。これにより、ネットワーク環境が予測可能でアクセス可能であると同時に、分離されていることが保証されます。ノード上のポッド、ボリューム、シークレットを管理し、新しいコンテナのヘルスチェックを作成します。

統合されたOpenShiftContainer Registry

OpenShiftコンテナーレジストリーは、Dockerイメージを保存するために使用されるRedHatの組み込みストレージユニットです。OpenShiftの最新の統合バージョンでは、OpenShift内部ストレージ内の画像を表示するためのユーザーインターフェイスが用意されています。これらのレジストリは、指定されたタグを持つイメージを保持することができ、後でそれからコンテナを構築するために使用されます。

よく使われる用語

Image− Kubernetes(Docker)イメージは、コンテナ化されたインフラストラクチャの主要な構成要素です。現在のところ、KubernetesはDockerイメージのみをサポートしています。ポッド内の各コンテナには、Dockerイメージが実行されています。ポッドを構成する場合、構成ファイルのimageプロパティの構文はDockerコマンドと同じです。

Project −以前のバージョンのOpenShiftV2に存在していたドメインの名前が変更されたバージョンとして定義できます。

Container −イメージがKubernetesクラスターノードにデプロイされた後に作成されるものです。

Node−ノードはKubernetesクラスターで動作するマシンであり、マスターのミニオンとも呼ばれます。これらは、物理インスタンス、VMインスタンス、またはクラウドインスタンスを実行できる作業ユニットです。

Pod−ポッドは、Kubernetesクラスターのノード内のコンテナーとそのストレージのコレクションです。内部に複数のコンテナを含むポッドを作成することができます。たとえば、データベースコンテナとWebサーバーコンテナをポッド内に保持します。

この章では、OpenShiftの環境設定について学習します。

システム要件

エンタープライズOpenShiftをセットアップするには、アクティブなRedHatアカウントが必要です。OpenShiftはKubernetesマスターおよびノー​​ドアーキテクチャーで動作するため、両方を別々のマシンにセットアップする必要があります。一方のマシンがマスターとして機能し、もう一方のマシンがノードで動作します。両方を設定するには、最小システム要件があります。

マスターマシンの構成

以下は、マスターマシン構成の最小システム要件です。

  • 物理、仮想、または任意のクラウド環境でホストされているベースマシン。

  • そのインスタンスに必要なパッケージを備えた少なくともLinux7。

  • 2CPUコア。

  • 少なくとも8GBのRAM。

  • 30GBの内蔵ハードディスクメモリ。

ノードマシン構成

  • マスターマシンに指定された物理または仮想ベースイメージ。
  • マシン上に少なくともLinux7。
  • Dockerは1.6以上のバージョンでインストールされています。
  • 1CPUコア。
  • 8GBのRAM。
  • イメージをホストするための15GBのハードディスクとイメージを保存するための15GB。

OpenShiftセットアップのステップバイステップガイド

以下の説明では、OpenShiftラボ環境をセットアップします。これは、後でより大きなクラスターに拡張できます。OpenShiftにはマスターとノードのセットアップが必要なため、クラウド、物理、または仮想マシンのいずれかでホストされる少なくとも2台のマシンが必要になります。

Step 1−最初に両方のマシンにLinuxをインストールします。ここで、Linux7は最小バージョンである必要があります。これは、アクティブなRed Hatサブスクリプションがある場合は、次のコマンドを使用して実行できます。

# subscription-manager repos --disable = "*"

# subscription-manager repos --enable = "rhel-7-server-rpms"

# subscription-manager repos --enable = "rhel-7-server-extras-rpms"

# subscription-manager repos --enable = "rhel-7-server-optional-rpms"

# subscription-manager repos --enable = "rhel-7-server-ose-3.0-rpms"

# yum install wget git net-tools bind-utils iptables-services bridge-utils

# yum install wget git net-tools bind-utils iptables-services bridge-utils

# yum install python-virtualenv

# yum install gcc

# yum install httpd-tools

# yum install docker

# yum update

上記のすべての基本パッケージを両方のマシンにインストールしたら、次のステップはそれぞれのマシンにDockerをセットアップすることです。

Step 2−ローカルネットワークでのみ安全でない通信を許可するようにDockerを構成します。このために、/ etc / sysconfig内のDockerファイルを編集します。ファイルが存在しない場合は、手動で作成する必要があります。

# vi /etc/sysconfig/docker
OPTIONS = --selinux-enabled --insecure-registry 192.168.122.0/24

マスターマシンでDockerを構成した後、両方のマシン間でパスワードなしの通信をセットアップする必要があります。このために、公開鍵と秘密鍵の認証を使用します。

Step 3 −マスターマシンでキーを生成してから、id_rsa.pubキーをノードマシンの許可されたキーファイルにコピーします。これは、次のコマンドを使用して実行できます。

# ssh-keygen

# ssh-copy-id -i .ssh/id_rsa.pub [email protected]

上記のすべてのセットアップが完了したら、次にマスターマシンでOpenShiftバージョン3をセットアップします。

Step 4 −マスターマシンから、次のcurlコマンドを実行します。

# sh <(curl -s https://install.openshift.com/ose)

上記のコマンドは、OSV3のセットアップを配置します。次のステップは、マシンでOpenShiftV3を設定することです。

インターネットから直接ダウンロードできない場合は、からダウンロードできます。 https://install.openshift.com/portable/oo-install-ose.tgz インストーラーをローカルマスターマシンで実行できるtarパッケージとして。

セットアップの準備ができたら、マシン上のOSV3の実際の構成から始める必要があります。この設定は、実際の本番環境をテストするために非常に固有であり、LDAPなどが用意されています。

Step 5 −マスターマシンで、/ etc / openshift / master /master-config.yamlの下にある次のコードを設定します

# vi /etc/openshift/master/master-config.yaml
identityProviders:
- name: my_htpasswd_provider
challenge: true
login: true
provider:
apiVersion: v1
kind: HTPasswdPasswordIdentityProvider
file: /root/users.htpasswd
routingConfig:
subdomain: testing.com

次に、デフォルト管理用の標準ユーザーを作成します。

# htpasswd -c /root/users.htpasswd admin

Step 6− OpenShiftはイメージの設定にDockerレジストリを使用するため、Dockerレジストリを設定する必要があります。これは、ビルド後にDockerイメージを作成および保存するために使用されます。

次のコマンドを使用して、OpenShiftノードマシンにディレクトリを作成します。

# mkdir /images

次に、レジストリのセットアップ中に作成されるデフォルトの管理者資格情報を使用してマスターマシンにログインします。

# oc login
Username: system:admin

デフォルトで作成されたプロジェクトに切り替えます。

# oc project default

Step 7 −Dockerレジストリを作成します。

#echo '{"kind":"ServiceAccount","apiVersion":"v1","metadata":{"name":"registry"}}' | oc create -f -

ユーザー権限を編集します。

#oc edit scc privileged
users:
- system:serviceaccount:openshift-infra:build-controller
- system:serviceaccount:default:registry

イメージレジストリを作成および編集します。

#oadm registry --service-account = registry --
config = /etc/openshift/master/admin.kubeconfig --
credentials = /etc/openshift/master/openshift-registry.kubeconfig --
images = 'registry.access.redhat.com/openshift3/ose-${component}:${version}' --
mount-host = /images

Step 8 −デフォルトのルーティングを作成します。

デフォルトでは、OpenShiftはソフトウェアネットワークとしてOpenVswitchを使用します。次のコマンドを使用して、デフォルトのルーティングを作成します。これは、ロードバランシングとプロキシルーティングに使用されます。ルーターはDockerレジストリに似ており、レジストリでも実行されます。

# echo '{"kind":"ServiceAccount","apiVersion":"v1","metadata":{"name":"router"}}' | oc create -f -

次に、ユーザーの権限を編集します。

#oc edit scc privileged
users:
   - system:serviceaccount:openshift-infra:build-controller
   - system:serviceaccount:default:registry
   - system:serviceaccount:default:router

#oadm router router-1 --replicas = 1 --
credentials = '/etc/openshift/master/openshift-router.kubeconfig' --
images = 'registry.access.redhat.com/openshift3/ose-${component}:${version}'

Step 9 −DNSを構成します。

URLリクエストを処理するために、OpenShiftには機能するDNS環境が必要です。このDNS構成は、ルーターを指すDNSワイルドカードを作成するために必要なワイルドカードを作成するために必要です。

# yum install bind-utils bind

# systemctl start named

# systemctl enable named

vi /etc/named.conf
options {listen-on port 53 { 10.123.55.111; };
forwarders {
   10.38.55.13;
   ;
};

zone "lab.com" IN {
   type master;
   file "/var/named/dynamic/test.com.zone";
   allow-update { none; };
};

Step 10−最後のステップは、OpenShiftV3マスターマシンにgithubサーバーをセットアップすることです。これはオプションです。これは、次の一連のコマンドを使用して簡単に実行できます。

#yum install curl openssh-server

#systemctl enable sshd

# systemctl start sshd

# firewall-cmd --permanent --add-service = http

# systemctl reload firewalld

#curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-

#yum install gitlab-ce

# gitlab-ctl reconfigure

上記のセットアップが完了したら、アプリケーションをテストしてデプロイすることで確認できます。これについては、以降の章で詳しく説明します。

アプリケーションの実際のセットアップとデプロイを開始する前に、OpenShiftV3で使用されるいくつかの基本的な用語と概念を理解する必要があります。

コンテナと画像

画像

これらは、Dockerイメージから形成されるOpenShiftの基本的な構成要素です。OpenShiftの各ポッドでは、クラスター内で独自のイメージが実行されています。ポッドを構成すると、レジストリからプールされるフィールドがあります。この構成ファイルは、イメージをプルしてクラスターノードにデプロイします。

apiVersion: v1
kind: pod
metadata:
   name: Tesing_for_Image_pull -----------> Name of Pod
      spec:
containers:
- name: neo4j-server ------------------------> Name of the image
image: <Name of the Docker image>----------> Image to be pulled
imagePullPolicy: Always ------------->Image pull policy
command: [“echo”, “SUCCESS”] -------------------> Massage after image pull

イメージをプルして作成するには、次のコマンドを実行します。OCは、ログイン後にOpenShift環境と通信するためのクライアントです。

$ oc create –f Tesing_for_Image_pull

コンテナ

これは、DockerイメージがOpenShiftクラスターにデプロイされるときに作成されます。構成を定義する際に、構成ファイルでコンテナーセクションを定義します。1つのコンテナーで複数のイメージを内部で実行でき、クラスターノードで実行されているすべてのコンテナーはOpenShiftKubernetesによって管理されます。

spec:
   containers:
   - name: py ------------------------> Name of the container
   image: python----------> Image going to get deployed on container
   command: [“python”, “SUCCESS”]
   restartPocliy: Never --------> Restart policy of container

以下は、内部で複数のイメージが実行されているコンテナーを定義するための仕様です。

apiVersion: v1
kind: Pod
metadata:
   name: Tomcat
spec:
   containers:
   - name: Tomcat
   image: tomcat: 8.0
   ports:
   - containerPort: 7500
      imagePullPolicy: Always
      -name: Database
      Image: mongoDB
      Ports:
      - containerPort: 7501
imagePullPolicy: Always

上記の構成では、TomcatとMongoDBの2つのイメージを内部に持つマルチコンテナーポッドを定義しました。

ポッドとサービス

ポッド

ポッドは、OpenShift(Kubernetes)クラスターのノード内のコンテナーとそのストレージのコレクションとして定義できます。一般に、単一のコンテナポッドから複数のコンテナポッドまで、2種類のポッドがあります。

Single Container Pod −これらは、OCコマンドまたは基本構成のymlファイルを使用して簡単に作成できます。

$ oc run <name of pod> --image = <name of the image from registry>

次のように単純なyamlファイルで作成します。

apiVersion: v1
kind: Pod
metadata:
   name: apache
spec:
   containers:
   - name: apache
   image: apache: 8.0
   ports:
      - containerPort: 7500
imagePullPolicy: Always

上記のファイルが作成されると、次のコマンドでポッドが生成されます。

$ oc create –f apache.yml

Multi-Container Pod−マルチコンテナポッドとは、内部で複数のコンテナが実行されているポッドです。これらは、yamlファイルを使用して次のように作成されます。

apiVersion: v1
kind: Pod
metadata:
   name: Tomcat
spec:
   containers:
   - name: Tomcat
   image: tomcat: 8.0
   ports:
      - containerPort: 7500
imagePullPolicy: Always
   -name: Database
   Image: mongoDB
   Ports:
      - containerPort: 7501
imagePullPolicy: Always

これらのファイルを作成した後、上記と同じ方法を使用してコンテナを作成できます。

Service−ポッド内で実行されているコンテナのセットがあるため、同じように、ポッドの論理セットとして定義できるサービスがあります。これはポッドの上にある抽象化レイヤーであり、ポッドにアクセスするための単一のIP名とDNS名を提供します。サービスは、負荷分散構成の管理とポッドのスケーリングを非常に簡単に行うのに役立ちます。OpenShiftでは、サービスはRESTオブジェクトであり、その神格化をOpenShiftマスターのapiServiceにポストして、新しいインスタンスを作成できます。

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   ports:
      - port: 8080
         targetPort: 31999

ビルドとストリーム

ビルド

OpenShiftでは、ビルドはイメージをコンテナーに変換するプロセスです。ソースコードを画像に変換する処理です。このビルドプロセスは、ソースコードをイメージにビルドするという事前定義された戦略に基づいて機能します。

ビルドは複数の戦略とソースを処理します。

戦略を構築する

  • Source to Image−これは基本的に、再現可能な画像の作成に役立つツールです。これらのイメージは、Dockerrunコマンドを使用して実行する準備が常に整っています。

  • Docker Build −これは、単純なDockerビルドコマンドを実行して、Dockerファイルを使用してイメージをビルドするプロセスです。

  • Custom Build −これらはベースDockerイメージの作成に使用されるビルドです。

ソースを構築する

Git−このソースは、gitリポジトリがイメージの構築に使用される場合に使用されます。Dockerfileはオプションです。ソースコードからの設定は次のようになります。

source:
type: "Git"
git:
   uri: "https://github.com/vipin/testing.git"
   ref: "master"
contextDir: "app/dir"
dockerfile: "FROM openshift/ruby-22-centos7\nUSER example"

Dockerfile − Dockerfileは、構成ファイルの入力として使用されます。

source:
   type: "Dockerfile"
   dockerfile: "FROM ubuntu: latest
   RUN yum install -y httpd"

Image Streams−イメージストリームは、イメージをプルした後に作成されます。イメージストリームの利点は、新しいバージョンのイメージの更新を検索することです。これは、タグで識別されるDocker形式のコンテナイメージをいくつでも比較するために使用されます。

画像ストリームは、新しい画像が作成されたときに自動的にアクションを実行できます。すべてのビルドとデプロイメントは、イメージアクションを監視し、それに応じてアクションを実行できます。以下は、ビルドストリームを定義する方法です。

apiVersion: v1
kind: ImageStream
metadata:
   annotations:
      openshift.io/generated-by: OpenShiftNewApp
   generation: 1
   labels:
      app: ruby-sample-build
   selflink: /oapi/v1/namespaces/test/imagestreams/origin-ruby-sample
   uid: ee2b9405-c68c-11e5-8a99-525400f25e34
spec: {}
status:
   dockerImageRepository: 172.30.56.218:5000/test/origin-ruby-sample
   tags:
   - items:
      - created: 2016-01-29T13:40:11Z
      dockerImageReference: 172.30.56.218:5000/test/origin-apache-sample
      generation: 1
      image: vklnld908.int.clsa.com/vipin/test
   tag: latest

ルートとテンプレート

ルート

OpenShiftでは、ルーティングは、外部から到達可能なホスト名を作成および設定することにより、サービスを外部に公開する方法です。ルートとエンドポイントは、サービスを外部に公開するために使用され、そこからユーザーはネームコネクティビティ(DNS)を使用して定義済みのアプリケーションにアクセスできます。

OpenShiftでは、ルートは、OpenShiftadminによってクラスターにデプロイされたルーターを使用して作成されます。ルーターは、HTTP(80)およびhttps(443)ポートを外部アプリケーションにバインドするために使用されます。

以下は、ルートでサポートされているさまざまな種類のプロトコルです。

  • HTTP
  • HTTPS
  • TSLとWebソケット

サービスを構成する場合、セレクターを使用してサービスを構成し、そのサービスを使用するエンドポイントを検索します。以下は、適切なプロトコルを使用してサービスとそのサービスのルーティングを作成する方法の例です。

{
   "kind": "Service",
   "apiVersion": "v1",
   "metadata": {"name": "Openshift-Rservice"},
   "spec": {
      "selector": {"name":"RService-openshift"},
      "ports": [
         {
            "protocol": "TCP",
            "port": 8888,
            "targetPort": 8080
         }
      ]
   }
}

次に、次のコマンドを実行すると、サービスが作成されます。

$ oc create -f ~/training/content/Openshift-Rservice.json

これは、作成後のサービスの外観です。

$ oc describe service Openshift-Rservice

Name:              Openshift-Rservice
Labels:            <none>
Selector:          name = RService-openshift
Type:              ClusterIP
IP:                172.30.42.80
Port:              <unnamed> 8080/TCP
Endpoints:         <none>
Session Affinity:  None
No events.

次のコードを使用して、サービスのルーティングを作成します。

{
   "kind": "Route",
   "apiVersion": "v1",
   "metadata": {"name": "Openshift-service-route"},
   "spec": {
      "host": "hello-openshift.cloudapps.example.com",
      "to": {
         "kind": "Service",
         "name": "OpenShift-route-service"
      },
      "tls": {"termination": "edge"}
   }
}

OCコマンドを使用してルートを作成すると、ルートリソースの新しいインスタンスが作成されます。

テンプレート

テンプレートは、OpenShiftで複数回使用できる標準オブジェクトとして定義されています。これは、複数のオブジェクトを作成するために使用されるプレースホルダーのリストでパラメーター化されます。これは、ポッドからネットワークまで、ユーザーが作成する権限を持つものを作成するために使用できます。イメージ内のCLIまたはGUIインターフェイスからのテンプレートをプロジェクトディレクトリにアップロードすると、オブジェクトのリストを作成できます。

apiVersion: v1
kind: Template
metadata:
   name: <Name of template>
   annotations:
      description: <Description of Tag>
      iconClass: "icon-redis"
      tags: <Tages of image>
objects:
   - apiVersion: v1
   kind: Pod
   metadata:
      name: <Object Specification>
spec:
   containers:
      image: <Image Name>
      name: master
      ports:
      - containerPort: <Container port number>
         protocol: <Protocol>
labels:
   redis: <Communication Type>

認証と承認

認証

OpenShiftでは、マスターとクライアントの構造を設定する際に、マスターはOAuthサーバーの組み込み機能を思い付きます。OAuthサーバーは、APIへの認証に使用されるトークンの生成に使用されます。OAuthはマスターのデフォルト設定として提供されるため、デフォルトですべて許可IDプロバイダーが使用されます。で構成できるさまざまなIDプロバイダーが存在します/etc/openshift/master/master-config.yaml

OAuthにはさまざまなタイプのIDプロバイダーが存在します。

  • すべて許可
  • すべて拒否
  • HTPasswd
  • LDAP
  • 基本認証

すべて許可

apiVersion: v1
   kind: Pod
   metadata:
      name: redis-master
   spec:
      containers:
         image: dockerfile/redis
         name: master
      ports:
      - containerPort: 6379
         protocol: TCP
      oauthConfig:
      identityProviders:
      - name: my_allow_provider
         challenge: true
         login: true
      provider:
         apiVersion: v1
         kind: AllowAllPasswordIdentityProvider

すべて拒否

apiVersion: v1
kind: Pod
metadata:
   name: redis-master
spec:
   containers:
      image: dockerfile/redis
   name: master
   ports:
   - containerPort: 6379
      protocol: TCP
   oauthConfig:
   identityProviders:
   - name: my_allow_provider
      challenge: true
      login: true
   provider:
      apiVersion: v1
      kind: DenyAllPasswordIdentityProvider

HTPasswd

HTPasswdを使用するには、最初にマスターマシンでHttpd-toolsをセットアップしてから、他のマシンで行ったのと同じ方法で構成する必要があります。

identityProviders:
   - name: my_htpasswd_provider
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: HTPasswdPasswordIdentityProvider

承認

承認はOpenShiftマスターの機能であり、ユーザーの検証を検証するために使用されます。これは、アクションを実行しようとしているユーザーをチェックして、ユーザーが特定のプロジェクトでそのアクションを実行する権限を持っているかどうかを確認することを意味します。これは、管理者がプロジェクトへのアクセスを制御するのに役立ちます。

承認ポリシーは、-を使用して制御されます

  • Rules
  • Roles
  • Bindings

承認の評価は、-を使用して行われます。

  • Identity
  • Action
  • Bindings

ポリシーの使用-

  • クラスターポリシー
  • ローカルポリシー

OpenShiftは、GUIまたはCLIのいずれかによってアプリケーションを作成およびデプロイするための2種類のメディアンで構成されています。この章では、CLIを使用して新しいアプリケーションを作成します。OCクライアントを使用してOpenShift環境と通信します。

新しいアプリケーションの作成

OpenShiftには、新しいアプリケーションを作成する3つの方法があります。

  • ソースコードから
  • 画像から
  • テンプレートから

ソースコードから

ソースコードからアプリケーションを作成しようとすると、OpenShiftは、アプリケーションのビルドフローを定義するリポジトリ内に存在する必要があるDockerファイルを探します。ocnew-appを使用してアプリケーションを作成します。

リポジトリーを使用する際に最初に覚えておくべきことは、OpenShiftがコードをプルしてビルドするリポジトリーの起点を指す必要があるということです。

OCクライアントがインストールされているDockerマシンにリポジトリが複製され、ユーザーが同じディレクトリ内にいる場合は、次のコマンドを使用してリポジトリを作成できます。

$ oc new-app . <Hear. Denotes current working directory>

以下は、特定のブランチのリモートリポジトリからビルドしようとする例です。

$ oc new-app https://github.com/openshift/Testing-deployment.git#test1

ここで、test1は、OpenShiftで新しいアプリケーションを作成しようとしているところからのブランチです。

リポジトリでDockerファイルを指定する場合は、以下のようにビルド戦略を定義する必要があります。

$ oc new-app OpenShift/OpenShift-test~https://github.com/openshift/Testingdeployment.git

画像から

イメージを使用してアプリケーションを構築している間、イメージはローカルのDockerサーバー、社内でホストされているDockerリポジトリ、またはDockerハブに存在します。ユーザーが確認する必要がある唯一のことは、問題なくハブからイメージをプルするためのアクセス権を持っていることです。

OpenShiftには、Dockerイメージであるかソースストリームであるかに関係なく、使用されるソースを判別する機能があります。ただし、ユーザーが希望する場合は、それがイメージストリームであるかDockerイメージであるかを明示的に定義できます。

$ oc new-app - - docker-image tomcat

画像ストリームの使用-

$ oc new-app tomcat:v1

テンプレートから

テンプレートは、新しいアプリケーションの作成に使用できます。既存のテンプレートにすることも、新しいテンプレートを作成することもできます。

次のyamlファイルは、基本的にデプロイに使用できるテンプレートです。

apiVersion: v1
kind: Template
metadata:
   name: <Name of template>
   annotations:
      description: <Description of Tag>
      iconClass: "icon-redis"
      tags: <Tages of image>
objects:
   - apiVersion: v1
   kind: Pod
   metadata:
      name: <Object Specification>
spec:
   containers:
      image: <Image Name>
      name: master
      ports:
      - containerPort: <Container port number>
         protocol: <Protocol>
labels:
   redis: <Communication Type>

Webアプリケーションの開発と展開

OpenShiftでの新しいアプリケーションの開発

OpenShiftで新しいアプリケーションを作成するには、新しいアプリケーションコードを記述し、OpenShiftOCビルドコマンドを使用してビルドする必要があります。説明したように、新しいイメージを作成する方法は複数あります。ここでは、テンプレートを使用してアプリケーションを構築します。このテンプレートは、ocnew-appコマンドで実行すると新しいアプリケーションを構築します。

次のテンプレートは、2つのフロントエンドアプリケーションと1つのデータベースを作成します。それに加えて、2つの新しいサービスが作成され、それらのアプリケーションがOpenShiftクラスターにデプロイされます。アプリケーションをビルドおよびデプロイする際、最初にOpenShiftで名前空間を作成し、その名前空間でアプリケーションをデプロイする必要があります。

Create a new namespace

$ oc new-project openshift-test --display-name = "OpenShift 3 Sample" --
description = "This is an example project to demonstrate OpenShift v3"

テンプレート

{
   "kind": "Template",
   "apiVersion": "v1",
   "metadata": {
      "name": "openshift-helloworld-sample",
      "creationTimestamp": null,
         "annotations": {
         "description": "This example shows how to create a simple openshift
         application in openshift origin v3",
         "iconClass": "icon-openshift",
         "tags": "instant-app,openshift,mysql"
      }
   }
},

オブジェクト定義

Secret definition in a template

"objects": [
{
   "kind": "Secret",
   "apiVersion": "v1",
   "metadata": {"name": "dbsecret"},
   "stringData" : {
      "mysql-user" : "${MYSQL_USER}",
      "mysql-password" : "${MYSQL_PASSWORD}"
   }
},

Service definition in a template

{
   "kind": "Service",
   "apiVersion": "v1",
   "metadata": {
      "name": "frontend",
      "creationTimestamp": null
   },
   "spec": {
      "ports": [
         {
            "name": "web",
            "protocol": "TCP",
            "port": 5432,
            "targetPort": 8080,
            "nodePort": 0
         }
      ],
      "selector": {"name": "frontend"},
      "type": "ClusterIP",
      "sessionAffinity": "None"
   },
   "status": {
      "loadBalancer": {}
   }
},

Route definition in a template

{
   "kind": "Route",
   "apiVersion": "v1",
   "metadata": {
      "name": "route-edge",
      "creationTimestamp": null,
      "annotations": {
         "template.openshift.io/expose-uri": "http://{.spec.host}{.spec.path}"
      }
   },
   "spec": {
      "host": "www.example.com",
      "to": {
         "kind": "Service",
         "name": "frontend"
      },
      "tls": {
         "termination": "edge"
      }
   },
   "status": {}
},
{ 
   "kind": "ImageStream",
   "apiVersion": "v1",
   "metadata": {
      "name": "origin-openshift-sample",
      "creationTimestamp": null
   },
   "spec": {},
   "status": {
      "dockerImageRepository": ""
   }
},
{ 
   "kind": "ImageStream",
   "apiVersion": "v1",
   "metadata": {
      "name": "openshift-22-ubuntu7",
      "creationTimestamp": null 
   },
   "spec": {
      "dockerImageRepository": "ubuntu/openshift-22-ubuntu7"
   },
   "status": {
      "dockerImageRepository": ""
   }
},

Build config definition in a template

{
   "kind": "BuildConfig",
   "apiVersion": "v1",
   "metadata": {
      "name": "openshift-sample-build",
      "creationTimestamp": null,
      "labels": {name": "openshift-sample-build"}
   },
   "spec": {
      "triggers": [
         { "type": "GitHub",
            "github": {
            "secret": "secret101" } 
         },
         {
            "type": "Generic",
            "generic": {
               "secret": "secret101",
               "allowEnv": true } 
         },
         { 
            "type": "ImageChange",
            "imageChange": {} 
         },
         { "type": "ConfigChange”}
      ],
      "source": {
         "type": "Git",
         "git": {
            "uri": https://github.com/openshift/openshift-hello-world.git } 
      },
      "strategy": {
         "type": "Docker",
         "dockerStrategy": {
            "from": {
               "kind": "ImageStreamTag",
               "name": "openshift-22-ubuntu7:latest” 
            },
            "env": [
               {
                  "name": "EXAMPLE",
                  "value": "sample-app"
               } 
            ]
         }
      },
      "output": {
         "to": {
            "kind": "ImageStreamTag",
            "name": "origin-openshift-sample:latest"
         }
      },
      "postCommit": {
         "args": ["bundle", "exec", "rake", "test"]
      },
      "status": {
         "lastVersion": 0
      }
   }
},

Deployment config in a template

"status": {
   "lastVersion": 0
}
{
   "kind": "DeploymentConfig",
   "apiVersion": "v1",
   "metadata": {
      "name": "frontend",
      "creationTimestamp": null
   }
}, 
"spec": {
   "strategy": {
      "type": "Rolling",
      "rollingParams": {
         "updatePeriodSeconds": 1,
         "intervalSeconds": 1,
         "timeoutSeconds": 120,
         "pre": {
            "failurePolicy": "Abort",
            "execNewPod": {
               "command": [
                  "/bin/true"
               ],
               "env": [
                  { 
                     "name": "CUSTOM_VAR1",
                     "value": "custom_value1"
                  }
               ]
            }
         }
      }
   }
}
"triggers": [
   {
      "type": "ImageChange",
      "imageChangeParams": {
         "automatic": true,
         "containerNames": [
            "openshift-helloworld"
         ],
         "from": {
            "kind": "ImageStreamTag",
            "name": "origin-openshift-sample:latest"
         }
      }
   },
   {
      "type": "ConfigChange"
   }
],
"replicas": 2,
"selector": {
   "name": "frontend"
},
"template": {
   "metadata": {
      "creationTimestamp": null,
      "labels": {
         "name": "frontend"
      }
   },
   "spec": {
      "containers": [
         {
            "name": "openshift-helloworld",
            "image": "origin-openshift-sample",
            "ports": [
               { 
                  "containerPort": 8080,
                  "protocol": "TCP” 
               }
            ],
            "env": [
               {
                  "name": "MYSQL_USER",
                  "valueFrom": {
                     "secretKeyRef" : {
                        "name" : "dbsecret",
                        "key" : "mysql-user"
                     }
                  }
               },
               {
                  "name": "MYSQL_PASSWORD",
                  "valueFrom": {
                     "secretKeyRef" : {
                        "name" : "dbsecret",
                        "key" : "mysql-password"
                     }
                  }
               },
               {
                  "name": "MYSQL_DATABASE",
                  "value": "${MYSQL_DATABASE}"
               }
            ],
            "resources": {},
            "terminationMessagePath": "/dev/termination-log",
            "imagePullPolicy": "IfNotPresent",
            "securityContext": {
               "capabilities": {},
               "privileged": false
            }
         }
      ],
      "restartPolicy": "Always",
      "dnsPolicy": "ClusterFirst"
   },
   "status": {}
},

Service definition in a template

{
   "kind": "Service",
   "apiVersion": "v1",
   "metadata": {
      "name": "database",
      "creationTimestamp": null 
   },
   "spec": {
   "ports": [
      {
         "name": "db",
         "protocol": "TCP",
         "port": 5434,
         "targetPort": 3306,
         "nodePort": 0
      } 
   ],
   "selector": {
      "name": "database 
   },
   "type": "ClusterIP",
   "sessionAffinity": "None" },
   "status": {
      "loadBalancer": {}
   }
},

Deployment config definition in a template

{
   "kind": "DeploymentConfig",
   "apiVersion": "v1",
   "metadata": {
      "name": "database",
      "creationTimestamp": null
   },
   "spec": {
      "strategy": {
         "type": "Recreate",
         "resources": {}
      },
      "triggers": [
         {
            "type": "ConfigChange"
         }
      ],
      "replicas": 1,
      "selector": {"name": "database"},
      "template": {
         "metadata": {
            "creationTimestamp": null,
            "labels": {"name": "database"}
         },
         "template": {
            "metadata": {
               "creationTimestamp": null,
               "labels": {
                  "name": "database"
               } 
            },
            "spec": {
               "containers": [
                  {
                     "name": "openshift-helloworld-database",
                     "image": "ubuntu/mysql-57-ubuntu7:latest",
                     "ports": [
                        {
                           "containerPort": 3306,
                           "protocol": "TCP" 
                        }
                     ],
                     "env": [
                        {
                           "name": "MYSQL_USER",
                           "valueFrom": {
                              "secretKeyRef" : {
                                 "name" : "dbsecret",
                                 "key" : "mysql-user"
                              }
                           }
                        },
                        {
                           "name": "MYSQL_PASSWORD",
                           "valueFrom": {
                              "secretKeyRef" : {
                                 "name" : "dbsecret",
                                 "key" : "mysql-password"
                              }
                           }
                        },
                        {
                           "name": "MYSQL_DATABASE",
                           "value": "${MYSQL_DATABASE}" 
                        } 
                     ],
                     "resources": {},
                     "volumeMounts": [
                        {
                           "name": "openshift-helloworld-data",
                           "mountPath": "/var/lib/mysql/data"
                        }
                     ],
                     "terminationMessagePath": "/dev/termination-log",
                     "imagePullPolicy": "Always",
                     "securityContext": {
                        "capabilities": {},
                        "privileged": false
                     } 
                  }
               ],
               "volumes": [
                  { 
                     "name": "openshift-helloworld-data",
                     "emptyDir": {"medium": ""} 
                  } 
               ],
               "restartPolicy": "Always",
               "dnsPolicy": "ClusterFirst” 
            } 
         }
      },
      "status": {} 
   },
   "parameters": [
      { 
         "name": "MYSQL_USER",
         "description": "database username",
         "generate": "expression",
         "from": "user[A-Z0-9]{3}",
         "required": true 
      },
      {
         "name": "MYSQL_PASSWORD",
         "description": "database password",
         "generate": "expression",
         "from": "[a-zA-Z0-9]{8}",
         "required": true
      }, 
      {
         "name": "MYSQL_DATABASE",
         "description": "database name",
         "value": "root",
         "required": true 
      } 
   ],
   "labels": {
      "template": "application-template-dockerbuild" 
   } 
}

上記のテンプレートファイルは一度にコンパイルする必要があります。最初にすべてのコンテンツを1つのファイルにコピーし、完了したらyamlファイルとして名前を付ける必要があります。

アプリケーションを作成するには、次のコマンドを実行する必要があります。

$ oc new-app application-template-stibuild.json
--> Deploying template openshift-helloworld-sample for "application-template-stibuild.json"

   openshift-helloworld-sample
   ---------
   This example shows how to create a simple ruby application in openshift origin v3
   * With parameters:
      * MYSQL_USER = userPJJ # generated
      * MYSQL_PASSWORD = cJHNK3se # generated
      * MYSQL_DATABASE = root

--> Creating resources with label app = ruby-helloworld-sample ...
   service "frontend" created
   route "route-edge" created
   imagestream "origin-ruby-sample" created
   imagestream "ruby-22-centos7" created
   buildconfig "ruby-sample-build" created
   deploymentconfig "frontend" created
   service "database" created
   deploymentconfig "database" created
   
--> Success
   Build scheduled, use 'oc logs -f bc/ruby-sample-build' to track its progress.
   Run 'oc status' to view your app.

ビルドを監視したい場合は、-を使用して行うことができます

$ oc get builds

NAME                        TYPE      FROM          STATUS     STARTED         DURATION
openshift-sample-build-1    Source   Git@bd94cbb    Running    7 seconds ago   7s

−を使用してOpenShiftにデプロイされたアプリケーションを確認できます

$ oc get pods
NAME                            READY   STATUS      RESTARTS   AGE
database-1-le4wx                1/1     Running     0          1m
frontend-1-e572n                1/1     Running     0          27s
frontend-1-votq4                1/1     Running     0          31s
opeshift-sample-build-1-build   0/1     Completed   0          1m

を使用して、サービス定義に従ってアプリケーションサービスが作成されているかどうかを確認できます。

$ oc get services
NAME        CLUSTER-IP      EXTERNAL-IP     PORT(S)      SELECTOR          AGE
database    172.30.80.39    <none>         5434/TCP     name=database      1m
frontend    172.30.17.4     <none>         5432/TCP     name=frontend      1m

OpenShiftには、ビルドパイプラインを自動化する複数の方法があります。そのためには、ビルドフローを記述するBuildConfigリソースを作成する必要があります。BuildConfigのフローは、Jenkinsジョブ定義のジョブ定義と比較できます。ビルドフローを作成するときに、ビルド戦略を選択する必要があります。

BuildConfigファイル

OpenShiftでは、BuildConfigはAPIに接続して新しいインスタンスを作成するために使用されるレストオブジェクトです。

kind: "BuildConfig"
apiVersion: "v1"
metadata:
   name: "<Name of build config file>"
spec:
   runPolicy: "Serial"
   triggers:
   -
      type: "GitHub"
      github:
         secret: "<Secrete file name>"
   - type: "Generic"
   generic:
      secret: "secret101"
   -
   type: "ImageChange"
   source:
      type: "<Source of code>"
      git:
   uri: "https://github.com/openshift/openshift-hello-world"
   dockerfile: "FROM openshift/openshift-22-centos7\nUSER example"
   strategy:
      type: "Source"
      
sourceStrategy:
   from:
      kind: "ImageStreamTag"
      name: "openshift-20-centos7:latest"
   output:
      to:
         kind: "ImageStreamTag"
         name: "origin-openshift-sample:latest"
   postCommit:
      script: "bundle exec rake test"

OpenShiftには、4種類のビルド戦略があります。

  • ソースから画像への戦略
  • Docker戦略
  • カスタム戦略
  • パイプライン戦略

ソースから画像への戦略

ソースコードからコンテナイメージを作成できます。このフローでは、実際のコードが最初にコンテナーにダウンロードされ、次にコンテナー内でコンパイルされます。コンパイルされたコードは同じコンテナ内にデプロイされ、イメージはそのコードから構築されます。

strategy:
   type: "Source"
   sourceStrategy:
      from:
         kind: "ImageStreamTag"
         name: "builder-image:latest"
      forcePull: true

複数の戦略ポリシーがあります。

  • Forcepull
  • インクリメンタルビルド
  • 外部ビルド

Docker戦略

このフローでは、OpenShiftはDockerfileを使用してイメージをビルドし、作成されたイメージをDockerレジストリーにアップロードします。

strategy:
   type: Docker
   dockerStrategy:
      from:
         kind: "ImageStreamTag"
         name: "ubuntu:latest"

Dockerファイルオプションは、ファイルパス、キャッシュなし、強制プルから始まる複数の場所で使用できます。

  • イメージから
  • Dockerfileパス
  • キャッシュなし
  • 強制的に引っ張る

カスタム戦略

これはさまざまな種類のビルド戦略の1つであり、ビルドの出力がイメージになるような強制はありません。それはジェンキンスのフリースタイルの仕事と比較することができます。これにより、Jar、rpm、およびその他のパッケージを作成できます。

strategy:
   type: "Custom"
   customStrategy:
      from:
         kind: "DockerImage"
         name: "openshift/sti-image-builder"

これは、複数のビルド戦略で構成されています。

  • Dockerソケットを公開する
  • Secrets
  • 強制的に引っ張る

パイプライン戦略

パイプライン戦略は、カスタムビルドパイプラインを作成するために使用されます。これは基本的に、パイプラインにワークフローを実装するために使用されます。このビルドフローは、GroovyDSL言語を使用したカスタムビルドパイプラインフローを使用します。OpenShiftは、Jenkinsでパイプラインジョブを作成して実行します。このパイプラインフローは、Jenkinsでも使用できます。この戦略では、Jenkinsfileを使用して、buildconfig定義に追加します。

Strategy:
   type: "JenkinsPipeline"
   jenkinsPipelineStrategy:
   jenkinsfile: "node('agent') {\nstage 'build'\nopenshiftBuild(buildConfig: 'OpenShift-build', showBuildLogs: 'true')\nstage 'deploy'\nopenshiftDeploy(deploymentConfig: 'backend')\n}"

Using build pipeline

kind: "BuildConfig"
apiVersion: "v1"
metadata:
   name: "test-pipeline"
spec:
   source:
      type: "Git"
      git:
         uri: "https://github.com/openshift/openshift-hello-world"
   strategy:
      type: "JenkinsPipeline"
      jenkinsPipelineStrategy:
         jenkinsfilePath: <file path repository>

OpenShift CLIは、コマンドラインからOpenShiftアプリケーションを管理するために使用されます。OpenShift CLIには、エンドツーエンドのアプリケーションライフサイクルを管理する機能があります。一般に、OpenShiftクライアントであるOCを使用してOpenShiftと通信します。

OpenShiftCLIセットアップ

別のオペレーティングシステムでOCクライアントをセットアップするには、さまざまな手順を実行する必要があります。

Windows用OCクライアント

Step 1 −次のリンクからoccliをダウンロードします https://github.com/openshift/origin/releases/tag/v3.6.0-alpha.2

Step 2 −マシンのターゲットパスでパッケージを解凍します。

Step 3 −システムのパス環境変数を編集します。

C:\Users\xxxxxxxx\xxxxxxxx>echo %PATH%

C:\oraclexe\app\oracle\product\10.2.0\server\bin;C:\Program Files 
(x86)\Intel\iCLS Client\;C:\Program Files\Intel\iCLS Client\;C:\Program Files 
(x86)\AMD APP\bin\x86_64;C:\Program Files (x86)\AMD APP\bin\x86;

C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\
v1.0\;C:\Program Files (x86)\Windows Live\Shared;C:\Program Files 
(x86)\ATI Technologies\ATI.ACE\C

ore-Static;C:\Program Files\Intel\Intel(R) Management Engine 
Components\DAL;C:\Program Files\Intel\Intel(R) Management Engine 
Components\IPT;C:\Program Files (x86)\Intel\Intel(R) Management Engine Components\DAL;

Step 4 −WindowsでのOCセットアップを検証します。

C:\openshift-origin-client-tools-v3.6.0-alpha.2-3c221d5-windows>oc version
oc v3.6.0-alpha.2+3c221d5
kubernetes v1.6.1+5115d708d7
features: Basic-Auth

Mac OSX用のOCクライアント

Windowsと同じ場所のMacOSセットアップバイナリをダウンロードし、後でその場所で解凍して、環境のPATH変数の下に実行可能ファイルのパスを設定できます。

Alternatively

Home brewを使用して、次のコマンドを使用して設定できます。

$ brew install openshift-cli

Linux用OCクライアント

同じページの下に、インストールに使用できるLinuxインストール用のtarファイルがあります。後で、その特定の実行可能場所を指すパス変数を設定できます。

https://github.com/openshift/origin/releases/tag/v3.6.0-alpha.2

次のコマンドを使用して、tarファイルを解凍します。

$ tar –xf < path to the OC setup tar file >

次のコマンドを実行して、認証を確認します。

C:\openshift-origin-client-tools-v3.6.0-alpha.2-3c221d5-windows>oc login
Server [https://localhost:8443]:

CLI構成ファイル

OC CLI構成ファイルは、複数のOpenShiftサーバー接続および認証メカニズムを管理するために使用されます。この構成ファイルは、複数のプロファイルの保存と管理、およびプロファイル間の切り替えにも使用されます。通常の設定ファイルは次のようになります。

$ oc config view
apiVersion: v1
clusters:
   - cluster:
      server: https://vklnld908.int.example.com
   name: openshift
   
contexts:
- context:
   cluster: openshift
   namespace: testproject
   user: alice
   name: alice
current-context: alice
kind: Config
preferences: {}
users:
- name: vipin
   user:
      token: ZCJKML2365jhdfafsdj797GkjgjGKJKJGjkg232

CLIクライアントのセットアップ

ユーザー資格情報を設定するため

$ oc config set-credentials <user_nickname>
[--client-certificate = <path/to/certfile>] [--client-key=<path/to/keyfile>]
[--token = <bearer_token>] [--username = <basic_user>] [--password = <basic_password>]

クラスター設定用

$ oc config set-cluster <cluster_nickname> [--server = <master_ip_or_fqdn>]
[--certificate-authority = <path/to/certificate/authority>]
[--api-version = <apiversion>] [--insecure-skip-tls-verify = true]

$ oc config set-credentials vipin --token = ZCJKML2365jhdfafsdj797GkjgjGKJKJGjkg232

コンテキスト設定用

$ oc config set-context <context_nickname> [--cluster = <cluster_nickname>]
[--user = <user_nickname>] [--namespace = <namespace>]

CLIプロファイル

単一のCLI構成ファイルに複数のプロファイルを含めることができ、各プロファイルには異なるOpenShiftサーバー構成があり、後で異なるCLIプロファイルを切り替えるために使用できます。

apiVersion: v1
clusters: --→ 1
- cluster:
   insecure-skip-tls-verify: true
   server: https://vklnld908.int.example.com:8443
   name: vklnld908.int.example.com:8443
- cluster:
   insecure-skip-tls-verify: true
   server: https://vklnld1446.int.example.com:8443
   name: vklnld1446.int.example.com:8443
contexts: ---→ 2
- context:
   cluster: vklnld908.int.example.com:8443
   namespace: openshift-project
   user: vipin/vklnld908.int.example.com:8443
   name: openshift-project/vklnld908.int.example.com:8443/vipin
- context:
   cluster: vklnld908.int.example.com:8443
   namespace: testing-project
   user: alim/vklnld908.int.example.com:8443
   name: testproject-project/openshift1/alim
current-context: testing-project/vklnld908.int.example.com:8443/vipin - 3
kind: Config
preferences: {}

users:
- name: vipin/vklnld908.int.example.com:8443
user: ---→ 4
   token: ZCJKML2365jhdfafsdj797GkjgjGKJKJGjkg232

上記の設定では、OpenShiftマスターマシンの2つのインスタンスを定義するクラスターから始まる4つの主要なセクションに分割されていることがわかります。2番目のコンテキストセクションでは、vipinとalimという名前の2つのコンテキストを定義します。現在のコンテキストは、現在使用されているコンテキストを定義します。ここで定義を変更すると、他のコンテキストまたはプロファイルに変更できます。最後に、ユーザー定義とその認証トークンが定義されます。この場合はvipinです。

使用中の現在のプロファイルを確認したい場合は、-を使用して確認できます。

$ oc status oc status In project testing Project (testing-project) $ oc project
Using project "testing-project" from context named "testing-
project/vklnld908.int.example.com:8443/vipin" on server "https://vklnld908.int.example.com:8443".

他のCLIに切り替えたい場合は、次のコマンドを使用してコマンドラインから切り替えることができます。

$ oc project openshift-project
Now using project "Openshift-project" on server "
https://vklnld908.int.example.com:8443".

上記のコマンドを使用して、プロファイルを切り替えることができます。いつでも構成を表示したい場合は、$ oc configviewコマンドを使用できます。

OpenShift CLIは、アプリケーションのすべての基本および高度な設定、管理、追加、およびデプロイメントを実行できます。

OCコマンドを使用してさまざまな種類の操作を実行できます。このクライアントは、OpenShiftまたはKubernetes互換プラットフォームでのアプリケーションの開発、ビルド、デプロイ、および実行を支援します。また、「adm」サブコマンドの下にクラスターを管理するための管理コマンドも含まれています。

基本コマンド

次の表に、基本的なOCコマンドを示します。

シニア番号 コマンドと説明
1

Types

概念とタイプの紹介

2

Login

サーバーにログインします

3

new-project

新しいプロジェクトをリクエストする

4

new-app

新しいアプリケーションを作成する

5

Status

現在のプロジェクトの概要を表示する

6

Project

別のプロジェクトに切り替える

7

Projects

既存のプロジェクトを表示する

8

Explain

リソースのドキュメント

9

Cluster

OpenShiftクラスターの開始と停止

ログインする

サーバーにログインし、後で使用できるようにログインを保存します。クライアントを初めて使用するユーザーは、このコマンドを実行してサーバーに接続し、認証されたセッションを確立して、構成ファイルへの接続を保存する必要があります。デフォルトの設定は、「。kube / config」の下のホームディレクトリに保存されます。

ログインに必要な情報(ユーザー名とパスワード、セッショントークン、サーバーの詳細など)は、フラグを介して提供できます。指定しない場合、コマンドは必要に応じてユーザー入力を求めるプロンプトを表示します。

Usage

oc login [URL] [options]

Example

# Log in interactively
oc login

# Log in to the given server with the given certificate authority file
oc login localhost:8443 --certificate-authority = /path/to/cert.crt

# Log in to the given server with the given credentials (will not prompt interactively)
oc login localhost:8443 --username = myuser --password=mypass

オプション-

-p, --password = " −パスワード、提供されていない場合はプロンプトが表示されます

-u, --username = " −ユーザー名、指定されていない場合はプロンプトが表示されます

--certificate-authority = "−証明書へのパス。認証局のファイル

--insecure-skip-tls-verify = false− trueの場合、サーバーの証明書の有効性はチェックされません。これにより、HTTPS接続が安全でなくなります

--token = " −APIサーバーへの認証用のベアラートークン

コマンドに関する完全な詳細を取得するには、 oc <Command Name> --help コマンド。

コマンドのビルドとデプロイ

次の表に、ビルドコマンドとデプロイコマンドを示します。

シニア番号 コマンドと説明
1

Rollout

KubernetesデプロイメントまたはOpenShiftデプロイを管理する

2

Deploy

展開を表示、開始、キャンセル、または再試行します

3

Rollback

アプリケーションの一部を前の状態に戻します

4

new-build

新しいビルド構成を作成する

5

start-build

新しいビルドを開始します

6

cancel-build

実行中、保留中、または新しいビルドをキャンセルします

7

import-image

Dockerレジストリから画像をインポートします

8

Tag

既存の画像を画像ストリームにタグ付けする

アプリケーション管理コマンド

次の表に、アプリケーション管理コマンドを示します。

シニア番号 コマンドと説明
1

Get

1つまたは複数のリソースを表示する

2

Describe

特定のリソースまたはリソースのグループの詳細を表示する

3

Edit

サーバー上のリソースを編集します

4

Set

オブジェクトに特定の機能を設定するのに役立つコマンド

5

Label

リソースのラベルを更新する

6

Annotate

リソースの注釈を更新します

7

Expose

複製されたアプリケーションをサービスまたはルートとして公開する

8

Delete

1つ以上のリソースを削除します

9

Scale

デプロイメント内のポッドの数を変更する

10

Autoscale

デプロイメント構成、デプロイメント、レプリケーション、コントローラー、またはレプリカセットを自動スケーリングします

11

Secrets

秘密を管理する

12

Serviceaccounts

プロジェクトのサービスアカウントを管理する

コマンドのトラブルシューティングとデバッグ

次の表に、トラブルシューティングコマンドとデバッグコマンドを示します。

シニア番号 コマンドと説明
1

logs

リソースのログを印刷する

2

Rsh

ポッドでシェルセッションを開始します

3

Rsync

ローカルファイルシステムとポッド間でファイルをコピーする

4

port-forward

1つ以上のローカルポートをポッドに転送する

5

Debug

デバッグ用にポッドの新しいインスタンスを起動します

6

Exec

コンテナ内でコマンドを実行する

7

Procy

KubernetesAPIサーバーへのプロキシを実行します

9

Attach

実行中のコンテナにアタッチする

10

Run

クラスターで特定のイメージを実行する

11

Cp

コンテナとの間でファイルとディレクトリをコピーする

高度なコマンド

次の表に、高度なコマンドを示します。

シニア番号 コマンドと説明
1

adm

クラスターを管理するためのツール

2

create

ファイル名または標準入力でリソースを作成します

3

replace

リソースをファイル名またはstdinに置き換えます

4

apply

ファイル名またはstdinによってリソースに構成を適用します

5

patch

戦略的マージパッチを使用してリソースのフィールドを更新します

6

process

テンプレートをリソースのリストに処理します

7

export

リソースをエクスポートして、他の場所で使用できるようにします

8

extract

シークレットまたは構成マップをディスクに抽出します

9

idle

アイドル状態のスケーラブルなリソース

10

observe

リソースへの変更を観察し、それらに対応します(実験的)

11

policy

承認ポリシーを管理する

12

auth

承認を検査する

13

convert

異なるAPIバージョン間で設定ファイルを変換する

14

import

アプリケーションをインポートするコマンド

設定コマンド

次の表に、設定コマンドを示します。

シニア番号 コマンドと説明
1

Logout

現在のサーバーセッションを終了します

2

Config

クライアントの構成ファイルを変更します

3

Whoami

現在のセッションに関する情報を返す

4

Completion

指定されたシェル(bashまたはzsh)の出力シェル完了コード

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

自動スケーリングはOpenShiftの機能であり、デプロイされたアプリケーションは、特定の仕様に従って必要に応じてスケーリングおよびシンクできます。OpenShiftアプリケーションでは、自動スケーリングはポッド自動スケーリングとも呼ばれます。二つありますtypes of application scaling 次のように。

垂直スケーリング

垂直スケーリングとは、1台のマシンにますます多くの電力を追加することです。つまり、CPUとハードディスクを追加することを意味します。これはOpenShiftの古い方法であり、現在OpenShiftリリースではサポートされていません。

水平スケーリング

このタイプのスケーリングは、マシンの数を増やしてより多くの要求を処理する必要がある場合に役立ちます。

OpenShiftには、 two methods to enable the scaling feature

  • デプロイメント構成ファイルの使用
  • イメージの実行中

デプロイメント構成ファイルの使用

この方法では、スケーリング機能はdeploymant構成のyamlファイルを介して有効になります。このため、OC autoscaleコマンドは、最小数と最大数のレプリカで使用されます。レプリカは、クラスター内の任意の時点で実行する必要があります。オートスケーラーを作成するには、オブジェクト定義が必要です。以下は、ポッドオートスケーラー定義ファイルの例です。

apiVersion: extensions/v1beta1
kind: HorizontalPodAutoscaler
metadata:
   name: database
spec:
   scaleRef:
      kind: DeploymentConfig
      name: database
      apiVersion: v1
      subresource: scale
   minReplicas: 1
   maxReplicas: 10
   cpuUtilization:
      targetPercentage: 80

ファイルを配置したら、yaml形式で保存し、次のコマンドを実行してデプロイする必要があります。

$ oc create –f <file name>.yaml

画像の実行中

以下を使用して、yamlファイルなしで自動スケーリングすることもできます oc autoscale ocコマンドラインのコマンド。

$ oc autoscale dc/database --min 1 --max 5 --cpu-percent = 75
deploymentconfig "database" autoscaled

このコマンドは、後で参照に使用できる同様の種類のファイルも生成します。

OpenShiftでのデプロイメント戦略

OpenShiftのデプロイメント戦略は、さまざまな利用可能なメソッドを使用したデプロイメントのフローを定義します。OpenShiftでは、以下はimportant types of deployment strategies

  • ローリング戦略
  • 戦略を再作成する
  • カスタム戦略

以下は、主にOpenShiftノードでのデプロイメントに使用されるデプロイメント構成ファイルの例です。

kind: "DeploymentConfig"
apiVersion: "v1"
metadata:
   name: "database"
spec:
   template:
      metadata:
         labels:
            name: "Database1"
spec:
   containers:
      - name: "vipinopenshifttest"
         image: "openshift/mongoDB"
         ports:
            - containerPort: 8080
               protocol: "TCP"
replicas: 5
selector:
   name: "database"
triggers:
- type: "ConfigChange"
- type: "ImageChange"
   imageChangeParams:
      automatic: true
      containerNames:
         - "vipinopenshifttest"
      from:
         kind: "ImageStreamTag"
         name: "mongoDB:latest"
   strategy:
      type: "Rolling"

上記のDeploymentconfigファイルには、Rollingとしての戦略があります。

次のOCコマンドを使用して展開できます。

$ oc deploy <deployment_config> --latest

ローリング戦略

ローリング戦略は、更新または展開のローリングに使用されます。このプロセスは、任意のデプロイメントプロセスにコードを挿入するために使用されるライフサイクルフックもサポートします。

strategy:
   type: Rolling
   rollingParams:
      timeoutSeconds: <time in seconds>
      maxSurge: "<definition in %>"
      maxUnavailable: "<Defintion in %>"
      pre: {}
      post: {}

戦略を再作成する

このデプロイメント戦略には、ローリングデプロイメント戦略の基本的な機能がいくつかあり、ライフサイクルフックもサポートしています。

strategy:
   type: Recreate
   recreateParams:
      pre: {}
      mid: {}
      post: {}

カスタム戦略

これは、独自の展開プロセスまたはフローを提供したい場合に非常に役立ちます。すべてのカスタマイズは、要件に従って行うことができます。

strategy:
   type: Custom
   customParams:
      image: organization/mongoDB
      command: [ "ls -l", "$HOME" ]
      environment:
         - name: VipinOpenshiftteat
         value: Dev1

この章では、ノードの管理方法、サービスアカウントの構成方法などのトピックについて説明します。

マスターとノードの構成

OpenShiftでは、新しいサーバーを起動するために、OCとともにstartコマンドを使用する必要があります。新しいマスターを起動するときは、startコマンドと一緒にマスターを使用する必要がありますが、新しいノードを起動するときは、startコマンドと一緒にノードを使用する必要があります。これを行うには、マスターとノードの構成ファイルを作成する必要があります。次のコマンドを使用して、マスターとノードの基本構成ファイルを作成できます。

マスター構成ファイルの場合

$ openshift start master --write-config = /openshift.local.config/master

ノード構成ファイルの場合

$ oadm create-node-config --node-dir = /openshift.local.config/node-<node_hostname> --node = <node_hostname> --hostnames = <hostname>,<ip_address>

次のコマンドを実行すると、構成の開始点として使用できる基本構成ファイルを取得します。後で、同じファイルを使用して新しいサーバーを起動できます。

apiLevels:
- v1beta3
- v1
apiVersion: v1
assetConfig:
   logoutURL: ""
   masterPublicURL: https://172.10.12.1:7449
   publicURL: https://172.10.2.2:7449/console/
      servingInfo:
         bindAddress: 0.0.0.0:7449
         certFile: master.server.crt
         clientCA: ""
keyFile: master.server.key
   maxRequestsInFlight: 0
   requestTimeoutSeconds: 0
controllers: '*'
corsAllowedOrigins:
- 172.10.2.2:7449
- 127.0.0.1
- localhost
dnsConfig:
   bindAddress: 0.0.0.0:53
etcdClientInfo:
   ca: ca.crt
   certFile: master.etcd-client.crt
   keyFile: master.etcd-client.key
   urls:
   - https://10.0.2.15:4001
etcdConfig:
   address: 10.0.2.15:4001
   peerAddress: 10.0.2.15:7001
   peerServingInfo:
      bindAddress: 0.0.0.0:7001
      certFile: etcd.server.crt
      clientCA: ca.crt
      keyFile: etcd.server.key
   servingInfo:
      bindAddress: 0.0.0.0:4001
      certFile: etcd.server.crt
      clientCA: ca.crt
      keyFile: etcd.server.key
   storageDirectory: /root/openshift.local.etcd
etcdStorageConfig:
   kubernetesStoragePrefix: kubernetes.io
   kubernetesStorageVersion: v1
   openShiftStoragePrefix: openshift.io
   openShiftStorageVersion: v1
imageConfig:
   format: openshift/origin-${component}:${version}
   latest: false
kind: MasterConfig
kubeletClientInfo:
   ca: ca.crt
   certFile: master.kubelet-client.crt
   keyFile: master.kubelet-client.key
   port: 10250
kubernetesMasterConfig:
   apiLevels:
   - v1beta3
   - v1
   apiServerArguments: null
   controllerArguments: null
   masterCount: 1
   masterIP: 10.0.2.15
   podEvictionTimeout: 5m
   schedulerConfigFile: ""
   servicesNodePortRange: 30000-32767
   servicesSubnet: 172.30.0.0/16
   staticNodeNames: []
masterClients:
   externalKubernetesKubeConfig: ""
   openshiftLoopbackKubeConfig: openshift-master.kubeconfig
masterPublicURL: https://172.10.2.2:7449
networkConfig:
   clusterNetworkCIDR: 10.1.0.0/16
   hostSubnetLength: 8
   networkPluginName: ""
   serviceNetworkCIDR: 172.30.0.0/16
oauthConfig:
   assetPublicURL: https://172.10.2.2:7449/console/
   grantConfig:
      method: auto
   identityProviders:
   - challenge: true
   login: true
   name: anypassword
   provider:
      apiVersion: v1
      kind: AllowAllPasswordIdentityProvider
   masterPublicURL: https://172.10.2.2:7449/
   masterURL: https://172.10.2.2:7449/
   sessionConfig:
      sessionMaxAgeSeconds: 300
      sessionName: ssn
      sessionSecretsFile: ""
   tokenConfig:
      accessTokenMaxAgeSeconds: 86400
      authorizeTokenMaxAgeSeconds: 300
policyConfig:
   bootstrapPolicyFile: policy.json
   openshiftInfrastructureNamespace: openshift-infra
   openshiftSharedResourcesNamespace: openshift
projectConfig:
   defaultNodeSelector: ""
   projectRequestMessage: ""
   projectRequestTemplate: ""
   securityAllocator:
      mcsAllocatorRange: s0:/2
      mcsLabelsPerProject: 5
      uidAllocatorRange: 1000000000-1999999999/10000
routingConfig:
   subdomain: router.default.svc.cluster.local
serviceAccountConfig:
   managedNames:
   - default
   - builder
   - deployer
   
masterCA: ca.crt
   privateKeyFile: serviceaccounts.private.key
   privateKeyFile: serviceaccounts.private.key
   publicKeyFiles:
   - serviceaccounts.public.key
servingInfo:
   bindAddress: 0.0.0.0:8443
   certFile: master.server.crt
   clientCA: ca.crt
   keyFile: master.server.key
   maxRequestsInFlight: 0
   requestTimeoutSeconds: 3600

ノード構成ファイル

allowDisabledDocker: true
apiVersion: v1
dnsDomain: cluster.local
dnsIP: 172.10.2.2
dockerConfig:
   execHandlerName: native
imageConfig:
   format: openshift/origin-${component}:${version}
   latest: false
kind: NodeConfig
masterKubeConfig: node.kubeconfig
networkConfig:
   mtu: 1450
   networkPluginName: ""
nodeIP: ""
nodeName: node1.example.com

podManifestConfig:
   path: "/path/to/pod-manifest-file"
   fileCheckIntervalSeconds: 30
servingInfo:
   bindAddress: 0.0.0.0:10250
   certFile: server.crt
   clientCA: node-client-ca.crt
   keyFile: server.key
volumeDirectory: /root/openshift.local.volumes

これは、ノード構成ファイルがどのように見えるかです。これらの構成ファイルを配置したら、次のコマンドを実行してマスターサーバーとノードサーバーを作成できます。

$ openshift start --master-config = /openshift.local.config/master/master-
config.yaml --node-config = /openshift.local.config/node-<node_hostname>/node-
config.yaml

ノードの管理

OpenShiftには、OpenShiftのすべての操作を実行するために主に使用されるOCコマンドラインユーティリティがあります。次のコマンドを使用してノードを管理できます。

ノードを一覧表示する場合

$ oc get nodes
NAME                             LABELS
node1.example.com     kubernetes.io/hostname = vklnld1446.int.example.com
node2.example.com     kubernetes.io/hostname = vklnld1447.int.example.com

ノードに関する詳細の説明

$ oc describe node <node name>

ノードの削除

$ oc delete node <node name>

ノード上のポッドの一覧表示

$ oadm manage-node <node1> <node2> --list-pods [--pod-selector=<pod_selector>] [-o json|yaml]

ノード上のポッドの評価

$ oadm manage-node <node1> <node2> --evacuate --dry-run [--pod-selector=<pod_selector>]

構成認証

OpenShiftマスターには、認証の管理に使用できる組み込みのOAuthサーバーがあります。すべてのOpenShiftユーザーは、このサーバーからトークンを取得します。これは、OpenShiftAPIとの通信に役立ちます。

OpenShiftにはさまざまな種類の認証レベルがあり、メインの設定ファイルと一緒に設定できます。

  • すべて許可
  • すべて拒否
  • HTPasswd
  • LDAP
  • 基本認証
  • リクエストヘッダー

マスター構成を定義するときに、使用するポリシーのタイプを定義できる識別ポリシーを定義できます。

すべて許可

すべて許可

oauthConfig:
   ...
   identityProviders:
   - name: Allow_Authontication
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: AllowAllPasswordIdentityProvider

すべて拒否

これにより、すべてのユーザー名とパスワードへのアクセスが拒否されます。

oauthConfig:
   ...
   identityProviders:
   - name: deny_Authontication
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: DenyAllPasswordIdentityProvider

HTPasswd

HTPasswdは、暗号化されたファイルパスワードに対してユーザー名とパスワードを検証するために使用されます。

暗号化されたファイルを生成するためのコマンドは次のとおりです。

$ htpasswd </path/to/users.htpasswd> <user_name>

暗号化されたファイルを使用します。

oauthConfig:
   ...
   identityProviders:
   - name: htpasswd_authontication
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: HTPasswdPasswordIdentityProvider
         file: /path/to/users.htpasswd

LDAPIDプロバイダー

これは、LDAPサーバーが認証で重要な役割を果たすLDAP認証に使用されます。

oauthConfig:
   ...
   identityProviders:
   - name: "ldap_authontication"
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: LDAPPasswordIdentityProvider
         attributes:
            id:
            - dn
            email:
            - mail
            name:
            - cn
            preferredUsername:
            - uid
         bindDN: ""
         bindPassword: ""
         ca: my-ldap-ca-bundle.crt
         insecure: false
         url: "ldap://ldap.example.com/ou=users,dc=acme,dc=com?uid"

基本認証

これは、ユーザー名とパスワードの検証がサーバー間認証に対して行われる場合に使用されます。認証はベースURLで保護され、JSON形式で表示されます。

oauthConfig:
   ...
   identityProviders:
   - name: my_remote_basic_auth_provider
      challenge: true
      login: true
      provider:
         apiVersion: v1
         kind: BasicAuthPasswordIdentityProvider
         url: https://www.vklnld908.int.example.com/remote-idp
         ca: /path/to/ca.file
         certFile: /path/to/client.crt
         keyFile: /path/to/client.key

サービスアカウントの構成

サービスアカウントは、認証用のユーザー名とパスワードを公開するOpenShiftAPIにアクセスする柔軟な方法を提供します。

サービスアカウントの有効化

サービスアカウントは、認証に公開鍵と秘密鍵の鍵ペアを使用します。APIへの認証は、秘密鍵を使用して行われ、公開鍵に対して検証されます。

ServiceAccountConfig:
   ...
   masterCA: ca.crt
   privateKeyFile: serviceaccounts.private.key
   publicKeyFiles:
   - serviceaccounts.public.key
   - ...

サービスアカウントの作成

次のコマンドを使用して、サービスアカウントを作成します

$ Openshift cli create service account <name of server account>

HTTPプロキシの操作

ほとんどの実稼働環境では、インターネットへの直接アクセスが制限されています。それらはインターネットに公開されていないか、HTTPまたはHTTPSプロキシを介して公開されています。OpenShift環境では、このプロキシーマシン定義は環境変数として設定されます。

これは、下にあるマスターファイルとノードファイルにプロキシ定義を追加することで実行できます。 /etc/sysconfig。これは、他のアプリケーションの場合と同様です。

マスターマシン

/ etc / sysconfig / openshift-master

HTTP_PROXY=http://USERNAME:[email protected]:8080/
HTTPS_PROXY=https://USERNAME:[email protected]:8080/
NO_PROXY=master.vklnld908.int.example.com

ノードマシン

/ etc / sysconfig / openshift-node

HTTP_PROXY=http://USERNAME:[email protected]:8080/
HTTPS_PROXY=https://USERNAME:[email protected]:8080/
NO_PROXY=master.vklnld908.int.example.com

完了したら、マスターマシンとノードマシンを再起動する必要があります。

DockerPullの場合

/ etc / sysconfig / docker

HTTP_PROXY = http://USERNAME:[email protected]:8080/
HTTPS_PROXY = https://USERNAME:[email protected]:8080/
NO_PROXY = master.vklnld1446.int.example.com

ポッドをプロキシ環境で実行するには、-を使用して実行できます。

containers:
- env:
   - name: "HTTP_PROXY"
      value: "http://USER:PASSWORD@:10.0.1.1:8080"

OC環境コマンドを使用して、既存の環境を更新できます。

NFSを使用したOpenShiftストレージ

OpenShiftでは、永続ボリュームと永続ボリュームクレームの概念が永続ストレージを形成します。これは、最初の永続ボリュームが作成され、後で同じボリュームが要求されるという重要な概念の1つです。このためには、基盤となるハードウェアに十分な容量とディスク容量が必要です。

apiVersion: v1
kind: PersistentVolume
metadata:
   name: storage-unit1
spec:
   capacity:
      storage: 10Gi
   accessModes:
   - ReadWriteOnce
   nfs:
      path: /opt
      server: 10.12.2.2
   persistentVolumeReclaimPolicy: Recycle

次に、OCcreateコマンドを使用して永続ボリュームを作成します。

$ oc create -f storage-unit1.yaml

persistentvolume " storage-unit1 " created

作成されたボリュームを要求します。

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
   name: Storage-clame1
spec:
   accessModes:
      - ReadWriteOnce
   resources:
      requests:
         storage: 5Gi

クレームを作成します。

$ oc create -f Storage-claim1.yaml
persistentvolume " Storage-clame1 " created

ユーザーと役割の管理

ユーザーとロールの管理は、さまざまなプロジェクトでのユーザー、ユーザーのアクセスと制御を管理するために使用されます。

ユーザーの作成

事前定義されたテンプレートを使用して、OpenShiftで新しいユーザーを作成できます。

kind: "Template"
apiVersion: "v1"
parameters:
   - name: vipin
   required: true
objects:
   - kind: "User"
   apiVersion: "v1"
   metadata:
   name: "${email}" - kind: "Identity" apiVersion: "v1" metadata: name: "vipin:${email}"
   providerName: "SAML"
   providerUserName: "${email}" - kind: "UserIdentityMapping" apiVersion: "v1" identity: name: "vipin:${email}"
user:
   name: "${email}"

oc create –f <ファイル名>を使用してユーザーを作成します。

$ oc create –f vipin.yaml

次のコマンドを使用して、OpenShiftでユーザーを削除します。

$ oc delete user <user name>

ユーザーアクセスの制限

ResourceQuotasとLimitRangesは、ユーザーのアクセスレベルを制限するために使用されます。これらは、クラスター上のポッドとコンテナーを制限するために使用されます。

apiVersion: v1
kind: ResourceQuota
metadata:
   name: resources-utilization
spec:
   hard:
      pods: "10"

上記の構成を使用して見積もりを作成する

$ oc create -f resource-quota.yaml –n –Openshift-sample

リソース見積もりの​​説明

$ oc describe quota resource-quota  -n  Openshift-sample
Name:              resource-quota
Namespace:                              Openshift-sample
Resource           Used                  Hard
--------           ----                  ----
pods                3                    10

コンテナー制限の定義は、デプロイされたコンテナーによって使用されるリソースを制限するために使用できます。これらは、特定のオブジェクトの最大および最小の制限を定義するために使用されます。

ユーザープロジェクトの制限

これは基本的に、ユーザーが任意の時点で持つことができるプロジェクトの数に使用されます。これらは基本的に、ブロンズ、シルバー、ゴールドのカテゴリでユーザーレベルを定義することによって行われます。

最初に、ブロンズ、シルバー、およびゴールドのカテゴリが持つことができるプロジェクトの数の値を保持するオブジェクトを定義する必要があります。これらはmaster-confif.yamlファイルで行う必要があります。

admissionConfig:
   pluginConfig:
      ProjectRequestLimit:
         configuration:
            apiVersion: v1
            kind: ProjectRequestLimitConfig
            limits:
            - selector:
               level: platinum
            - selector:
               level: gold
            maxProjects: 15
            - selector:
               level: silver
            maxProjects: 10
            - selector:
               level: bronze
            maxProjects: 5

マスターサーバーを再起動します。

ユーザーを特定のレベルに割り当てる。

$ oc label user vipin level = gold

必要に応じて、ユーザーをラベルから移動します。

$ oc label user <user_name> level-

ユーザーへの役割の追加。

$ oadm policy add-role-to-user 
      
        <user_name> 
      

ユーザーからロールを削除します。

$ oadm policy remove-role-from-user 
      
        <user_name> 
      

ユーザーにクラスターの役割を追加します。

$ oadm policy add-cluster-role-to-user 
      
        <user_name> 
      

ユーザーからクラスターの役割を削除します。

$ oadm policy remove-cluster-role-from-user 
      
        <user_name> 
      

グループへの役割の追加。

$ oadm policy add-role-to-user 
      
        <user_name> 
      

グループから役割を削除します。

$ oadm policy remove-cluster-role-from-user 
      
        <user_name> 
      

グループへのクラスターの役割の追加。

$ oadm policy add-cluster-role-to-group 
      
        <groupname> 
      

グループからクラスターの役割を削除します。

$ oadm policy remove-cluster-role-from-group <role> <groupname>

クラスター管理のユーザー

これは、ユーザーがクラスターの作成から削除までの完全なクラスターを管理する機能を持つ最も強力な役割の1つです。

$ oadm policy add-role-to-user admin <user_name> -n <project_name>

究極のパワーを持つユーザー

$ oadm policy add-cluster-role-to-user cluster-admin <user_name>

OpenShiftは、DockerとKubernetesの上に構築されています。すべてのコンテナは、基本的にLinuxマシン上のKubernetesサービスであるDockerクラスター上に構築され、Kubernetesオーケストレーション機能を使用します。

このプロセスでは、すべてのノードを制御し、コンテナをすべてのノードにデプロイするKubernetesマスターを構築します。Kubernetesの主な機能は、異なる種類の設定ファイルを使用してOpenShiftクラスターとデプロイメントフローを制御することです。Kubernetesと同様に、OCコマンドラインユーティリティを使用してクラスターノードにコンテナーをビルドおよびデプロイするのと同じ方法でkubctlを使用します。

以下は、クラスター内のさまざまな種類のオブジェクトの作成に使用されるさまざまな種類の構成ファイルです。

  • Images
  • POD
  • Service
  • レプリケーションコントローラー
  • レプリカセット
  • Deployment

画像

Kubernetes(Docker)イメージは、コンテナ化されたインフラストラクチャの主要な構成要素です。現在のところ、KubernetesはサポートしているだけですDocker画像。ポッド内の各コンテナには、Dockerイメージが実行されています。

apiVersion: v1
kind: pod
metadata:
   name: Tesing_for_Image_pull -----------> 1
   spec:
   containers:
- name: neo4j-server ------------------------> 2
image: <Name of the Docker image>----------> 3
imagePullPolicy: Always ------------->4
command: [“echo”, “SUCCESS”] -------------------> 5

POD

ポッドは、Kubernetesクラスターのノード内のコンテナーとそのストレージのコレクションです。内部に複数のコンテナを含むポッドを作成することができます。以下は、データベースコンテナとWebインターフェイスコンテナを同じポッドに保持する例です。

apiVersion: v1
kind: Pod
metadata:
   name: Tomcat
spec:
   containers:
   - name: Tomcat
      image: tomcat: 8.0
      ports:
- containerPort: 7500
imagePullPolicy: Always

サービス

サービスは、ポッドの論理セットとして定義できます。これは、ポッドにアクセスできる単一のIPアドレスとDNS名を提供するポッド上部の抽象化として定義できます。Serviceを使用すると、負荷分散構成の管理が非常に簡単になります。これは、PODを非常に簡単にスケーリングするのに役立ちます。

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   ports:
   - port: 8080
      targetPort: 31999

レプリケーションコントローラー

レプリケーションコントローラーは、ポッドのライフサイクルの管理を担当するKubernetesの重要な機能の1つです。指定された数のポッドレプリカがいつでも実行されていることを確認する責任があります。

apiVersion: v1
kind: ReplicationController
metadata:
   name: Tomcat-ReplicationController
spec:
   replicas: 3
   template:
   metadata:
      name: Tomcat-ReplicationController
   labels:
      app: App
      component: neo4j
   spec:
      containers:
      - name: Tomcat
      image: tomcat: 8.0
      ports:
      - containerPort: 7474

レプリカセット

レプリカセットは、実行するポッドのレプリカの数を保証します。これは、レプリケーションコントローラーの代替と見なすことができます。

apiVersion: extensions/v1beta1
kind: ReplicaSet
metadata:
   name: Tomcat-ReplicaSet
spec:
   replicas: 3
   selector:
      matchLables:
      tier: Backend
   matchExpression:
      - { key: tier, operation: In, values: [Backend]}
   
   app: App
   component: neo4j
spec:
   containers:
   - name: Tomcat-
image: tomcat: 8.0
   ports:
containerPort: 7474

展開

デプロイメントはアップグレードされ、レプリケーションコントローラーの上位バージョンになります。これらは、レプリケーションコントローラーのアップグレードバージョンでもあるレプリカセットの展開を管理します。レプリカセットを更新する機能があり、以前のバージョンにロールバックすることもできます。

apiVersion: extensions/v1beta1 --------------------->1
kind: Deployment --------------------------> 2
metadata:
   name: Tomcat-ReplicaSet
spec:
   replicas: 3
   template:
      metadata:
lables:
   app: Tomcat-ReplicaSet
   tier: Backend
spec:
   containers:
name: Tomcat-
   image: tomcat: 8.0
   ports:
   - containerPort: 7474

すべての設定ファイルを使用して、それぞれのKubernetesオブジェクトを作成できます。

$ Kubectl create –f <file name>.yaml

次のコマンドを使用して、Kubernetesオブジェクトの詳細と説明を知ることができます。

For POD

$ Kubectl get pod <pod name> $ kubectl delete pod <pod name>
$ kubectl describe pod <pod name>

For Replication Controller

$ Kubectl get rc <rc name>
$ kubectl delete rc <rc name> $ kubectl describe rc <rc name>

For Service

$ Kubectl get svc <svc name> $ kubectl delete svc <svc name>
$ kubectl describe svc <svc name>

DockerとKubernetesの操作方法の詳細については、次のリンクkubernetesを使用してKubernetesチュートリアルにアクセスしてください。

OpenShiftセキュリティは、主にセキュリティ制約を処理する2つのコンポーネントの組み合わせです。

  • セキュリティコンテキスト制約(SCC)
  • サービスアカウント

セキュリティコンテキスト制約(SCC)

これは基本的にポッド制限に使用されます。つまり、ポッドが実行できるアクションやクラスター内でアクセスできるすべてのものなど、ポッドの制限を定義します。

OpenShiftは、管理者が使用、変更、および拡張できる事前定義されたSCCのセットを提供します。

$ oc get scc
NAME              PRIV   CAPS  HOSTDIR  SELINUX    RUNASUSER         FSGROUP   SUPGROUP  PRIORITY
anyuid            false   []   false    MustRunAs  RunAsAny          RunAsAny  RunAsAny  10
hostaccess        false   []   true     MustRunAs  MustRunAsRange    RunAsAny  RunAsAny  <none>
hostmount-anyuid  false   []   true     MustRunAs  RunAsAny          RunAsAny  RunAsAny  <none>
nonroot           false   []   false    MustRunAs  MustRunAsNonRoot  RunAsAny  RunAsAny  <none>
privileged        true    []   true     RunAsAny   RunAsAny          RunAsAny  RunAsAny  <none>
restricted        false   []   false    MustRunAs  MustRunAsRange    RunAsAny  RunAsAny  <none>

事前定義されたsccを使用したい場合は、ユーザーまたはグループをsccグループに追加するだけで実行できます。

$ oadm policy add-user-to-scc <scc_name> <user_name> $ oadm policy add-group-to-scc <scc_name> <group_name>

サービスアカウント

サービスアカウントは基本的に、OpenShiftマスターAPIへのアクセスを制御するために使用されます。これは、マスターマシンまたはノードマシンのいずれかからコマンドまたはリクエストが実行されたときに呼び出されます。

アプリケーションまたはプロセスが制限付きSCCによって付与されていない機能を必要とする場合は常に、特定のサービスアカウントを作成し、そのアカウントをそれぞれのSCCに追加する必要があります。ただし、SCCが要件に合わない場合は、最適なSCCを使用するよりも、要件に固有の新しいSCCを作成することをお勧めします。最後に、デプロイメント構成用に設定します。

$ oc create serviceaccount Cadmin $ oc adm policy add-scc-to-user vipin -z Cadmin

コンテナセキュリティ

OpenShiftでは、コンテナーのセキュリティは、コンテナープラットフォームの安全性と、コンテナーが実行されている場所の概念に基づいています。コンテナのセキュリティと何に注意を払う必要があるかについて話すときに浮かび上がることが複数あります。

Image Provenance −本番環境で稼働しているコンテナがどこから来たのかを正確かつ議論の余地なく特定する安全なラベリングシステムが導入されています。

Security Scanning −イメージスキャナーは、既知の脆弱性についてすべてのイメージを自動的にチェックします。

Auditing −実稼働環境は定期的に監査され、すべてのコンテナーが最新のコンテナーに基づいており、ホストとコンテナーの両方が安全に構成されていることを確認します。

Isolation and Least Privilege−コンテナは、効果的に機能するために必要な最小限のリソースと特権で実行されます。ホストや他のコンテナに過度に干渉することはできません。

Runtime Threat Detection −実行時にコンテナ化されたアプリケーションに対するアクティブな脅威を検出し、それに自動的に応答する機能。

Access Controls − AppArmorやSELinuxなどのLinuxセキュリティモジュールは、アクセス制御を実施するために使用されます。

コンテナのセキュリティをアーカイブするための重要な方法はいくつかあります。

  • oAuthを介したアクセスの制御
  • セルフサービスのWebコンソール経由
  • プラットフォームの証明書による

OAuthによるアクセスの制御

この方法では、API制御アクセスへの認証がアーカイブされ、OpenShiftマスターマシンに組み込まれているOAuthサーバーを介した認証用の保護されたトークンを取得します。管理者は、OAuthサーバー構成の構成を変更することができます。

OAuthサーバー構成の詳細については、このチュートリアルの第5章を参照してください。

セルフサービスWebコンソール経由

このWebコンソールのセキュリティ機能は、OpenShiftWebコンソールに組み込まれています。このコンソールは、一緒に作業しているすべてのチームが認証なしで他の環境にアクセスできないようにします。OpenShiftのマルチテルネットマスターには、以下のセキュリティ機能があります-

  • TCLレイヤーが有効になっている
  • 認証にx.509証明書を使用
  • マスターマシンのetcd構成を保護します

プラットフォームの証明書による

この方法では、Ansibleを介したインストール中に、各ホストの証明書が構成されます。Rest APIを介したHTTPS通信プロトコルを使用するため、さまざまなコンポーネントやオブジェクトへのTCLで保護された接続が必要です。これらは事前定義された証明書ですが、マスターのクラスターにアクセス用にカスタム証明書をインストールすることもできます。マスターの初期セットアップ中に、を使用して既存の証明書をオーバーライドすることにより、カスタム証明書を構成できます。openshift_master_overwrite_named_certificates パラメータ。

Example

openshift_master_named_certificates = [{"certfile": "/path/on/host/to/master.crt", 
"keyfile": "/path/on/host/to/master.key", 
"cafile": "/path/on/host/to/mastercert.crt"}]

カスタム証明書を生成する方法の詳細については、次のリンクにアクセスしてください-

https://www.linux.com/learn/creating-self-signed-ssl-certificates-apache-linux

ネットワークセキュリティー

OpenShiftでは、Software Defined Networking(SDN)が通信に使用されます。ネットワーク名前空間は、クラスター内の各ポッドに使用されます。各ポッドは、独自のIPと、ネットワークトラフィックを取得するためのポートの範囲を取得します。この方法では、他のプロジェクトのポッドと通信できないため、ポッドを分離できます。

プロジェクトの分離

これは、クラスター管理者が以下を使用して実行できます。 oadm command CLIから。

$ oadm pod-network isolate-projects <project name 1> <project name 2>

これは、上記で定義されたプロジェクトがクラスター内の他のプロジェクトと通信できないことを意味します。

ボリュームセキュリティ

ボリュームセキュリティとは、OpenShiftクラスター内のプロジェクトのPVとPVCを保護することを意味します。OpenShiftのボリュームへのアクセスを制御するための主に4つのセクションがあります。

  • 補足グループ
  • fsGroup
  • runAsUser
  • seLinuxOptions

補足グループ-補足グループは通常のLinuxグループです。プロセスがシステムで実行されると、ユーザーIDとグループIDで実行されます。これらのグループは、共有ストレージへのアクセスを制御するために使用されます。

次のコマンドを使用して、NFSマウントを確認します。

# showmount -e <nfs-server-ip-or-hostname>
Export list for f21-nfs.vm:
/opt/nfs *

次のコマンドを使用して、マウントサーバーのNFSの詳細を確認します。

# cat /etc/exports
/opt/nfs *(rw,sync,no_root_squash)
...
# ls -lZ /opt/nfs -d
drwxrws---. nfsnobody 2325 unconfined_u:object_r:usr_t:s0 /opt/nfs
# id nfsnobody
uid = 65534(nfsnobody) gid = 454265(nfsnobody) groups = 454265(nfsnobody)

/ opt / NFS /エクスポートのUIDでアクセス可能です454265 とグループ 2325

apiVersion: v1
kind: Pod
...
spec:
   containers:
   - name: ...
      volumeMounts:
      - name: nfs
         mountPath: /usr/share/...
   securityContext:
      supplementalGroups: [2325]
   volumes:
   - name: nfs
      nfs:
      server: <nfs_server_ip_or_host>
      path: /opt/nfs

fsGroup

fsGroupは、コンテナー補足グループを追加するために使用されるファイルシステムグループを表します。サプリメントグループIDは共有ストレージに使用され、fsGroupはブロックストレージに使用されます。

kind: Pod
spec:
   containers:
   - name: ...
   securityContext:
      fsGroup: 2325

runAsUser

runAsUserは、通信にユーザーIDを使用します。これは、ポッド定義でコンテナイメージを定義する際に使用されます。必要に応じて、単一のIDユーザーをすべてのコンテナーで使用できます。

コンテナの実行中、定義されたIDはエクスポートの所有者IDと照合されます。指定されたIDが外部で定義されている場合、そのIDはポッド内のすべてのコンテナーに対してグローバルになります。特定のポッドで定義されている場合は、単一のコンテナーに固有になります。

spec:
   containers:
   - name: ...
      securityContext:
         runAsUser: 454265