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