Apigee Edge のドキュメントを表示しています。
Apigee X のドキュメントに移動。 情報
はじめに
このトピックでは、Kubernetes クラスタで Edge Microgateway をサイドカー プロキシとして実行する方法について説明します。サイドカーのデプロイには、手動と自動の 2 つのオプションがあります。このトピックでは、両方のオプションについて説明します。
詳細については、Kubernetes での Edge Microgateway の概要をご覧ください。
始める前に
前提条件に記載されている手順を完了します。
テストサービスをデプロイする
シンプルな「hello」サービスをデプロイして、デプロイを確認します。
サンプルをデプロイする
kubectl apply -f samples/helloworld/helloworld.yaml --namespace=default
サービスが実行されていることを確認します。Pod が実行状態になるまで数分かかることがあります。
kubectl get pods --namespace=default
出力例:
NAME READY STATUS RESTARTS AGE helloworld-569d6565f9-lwrrv 1/1 Running 0 17m
テストサービス デプロイメントを削除します。サイドカー インジェクションを有効にした後で、後で再インストールします。
kubectl delete -f samples/helloworld/helloworld.yaml --namespace=default
手動サイドカー インジェクションを使用する
2 つのサイドカー インジェクション オプションのうち、手動サイドカー インジェクションはよりシンプルで簡単な方法であり、1 つの kubectl
コマンドで行うことができます。
Edge Microgateway を構成する
次のコマンドは、Apigee 組織用に Edge Microgateway を構成し、プロキシ edgemicro-auth
をデプロイします。
次のコマンドを実行します。
edgemicro configure -o [org] -e [env] -u [username]
ここで
org
: Edge 組織名(組織管理者である必要があります)。env
: 組織の環境(テスト環境や本番環境など)。username
: Apigee アカウントに関連付けられているメールアドレス。
例
edgemicro configure -o myorg -e test -u jdoe@example.com
出力(例を以下に示します)がファイルに保存されます。
$HOME/.edgemicro/org_name-env_name-config.yaml
。current nodejs version is v6.9.1 current edgemicro version is 2.5.25 password: file doesn't exist, setting up Give me a minute or two... this can take a while... App edgemicro-auth deployed. checking org for existing KVM KVM already exists in your org configuring host edgemicroservices.apigee.net for region us-west1 saving configuration information to: /Users/jdoe/.edgemicro/myorg-test-config.yaml vault info: -----BEGIN CERTIFICATE----- MIICpDCCAYwCCQCV9eBcO9a5WzANBgkqhkiG9w0BAQsFADAUMRIwEAYDVQQDDAls b2NhbGhvc3QwHhcNMagwODA5MDAzMDEzWhcNMTgwODEwMDAzMDEzWjAUMRIwEAYD VQQDDBlsb2NhbGhvc3QwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDh nAHT7JHX/WvWHRFb8FLm53SPIDld5LyPOUfINdEyhSIEeXoOUKg4EPweJPVSC9Vm Hw4ZMtEqWJM/XsQWvLe8ylRJa5wgmzmFCqAsuzs9+rmc9KvJqjpOh2uRTUf7KKfT iXL2UEseprcI5g8zNyqKyEf/ecWIwz3AkkPAZebVTsrdDfIDHvkyhhvlAHZAB9kn GtqP3N8kOlv4KQto9Gr7GYUGUIDugt7gM1F611+RBS+fYRi32GUAq/UQDkhYL8cp oIJiF7UYkk2+9t9CdOCDuIUCvJioHJQd0xvDpkC9f6LvwjwnCwku+4F2Q63+av5I mJoZJQPvW5aP53Qkk+kHAgMBAAEwDKYJKoZIhvcNAQELBQADggEBALyUBolXUFN8 1bf268nR+gS8MOFDTxO1bUz+bKuT/g3K1PuNUJTueT+0L1H2OiZUzazAqwn2sqzN lQuvLg6LjxjlNkqTJGiJvGDcYVq45dv7UyxAZxhqxTxhlQ+Yu5R9pbQnzujezHpH 6gtCoCkSt/QqiJ3YsmsVu5is+HpIJepMt0CyMh5tK9j87hl46QhHklaVfQ3ycMVm /wNPR/pjizg1FDUeq4nj/7DBVbMf9net/BDaZLeSW1HJ1vcsCXIcSZfQd4QymGFn 8ADrND7ydVjwO/s23soPDTy0g4yLIZvky2tpT8d7YahNqSv2n7sXsLxruzcyCoQ4 w+e3Z3F7IKI= -----END CERTIFICATE----- The following credentials are required to start edge micro key: 1a3b2754c7f20614817b86e09895825ecc252d34df6c4be21ae24356f09e6eb4 secret: 16ad2431de73f07f57a6d44048f08d93b63f783bf1f2ac4221182aa7289c7cef edgemicro configuration complete!
Edge Microgateway をサイドカーとして挿入する
Edge Microgateway をサイドカー プロキシとして Service Pod に手動で挿入するには、次のコマンドを実行します。
kubectl apply -f <(edgemicroctl -org=your_org -env=your_env -key=your_key -sec=your_secret -conf=config_file_path -svc=service_deployment_file)
ここで
your_org
-edgemicro configure
コマンドで指定した Apigee 組織。your_env
-edgemicro configure
コマンドで指定した環境。your_key
-edgemicro configure
コマンドから返された鍵。your_secret
-edgemicro configure
コマンドから返されたシークレット。config_file_path
-edgemicro configure
コマンドから返された Edge Micro 構成ファイルのパス。service_deployment_file
- コンパニオン サイドカー サービスを取得する Pod を持つサービスのデプロイ ファイルのパス。例:samples/helloworld/helloworld.yaml
。
次に例を示します。
kubectl apply -f <(edgemicroctl -org=myorg -env=test-key=0e3ecea28a64099410594406b30e54439af5265f8 -sec=e3919250bee37c69cb2e5b41170b488e1c1d -conf=/Users/jdoe/.edgemicro/myorg-test-config.yaml -svc=samples/helloworld/helloworld.yaml)
構成のテスト
サービスのデプロイを確認します。
kubectl get services -n default
出力例:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE helloworld NodePort 10.15.254.163 <none> 8081:32401/TCP 56s kubernetes ClusterIP 10.15.240.1 <none> 443/TCP 41m
これで、Edge Microgateway のサイドカーのデプロイをテストする準備が整いました。詳細な手順については、プロキシをテストするをご覧ください。
自動サイドカー インジェクションの使用
次の手順では、Kubernetes クラスタの自動サイドカー インジェクションを構成します。この設定により、Edge Microgateway をサイドカー プロキシとして Kubernetes に挿入できます。
サイドカー インジェクタをインストールする
Edge Microgateway のサイドカー インジェクションを有効にする ConfigMap をインストールします。
kubectl apply -f install/kubernetes/edgemicro-sidecar-injector-configmap-release.yaml
次のスクリプトを実行して webhook サービスをインストールします。Webhook サービスは、自動サイドカー インジェクションに必要です。
./install/kubernetes/webhook-create-signed-cert.sh \ --service edgemicro-sidecar-injector \ --namespace edgemicro-system \ --secret sidecar-injector-certs
CA バンドルを Webhook インストール ファイルに追加します。Kubernetes api-server は、このファイルを使用して Webhook を呼び出します。
cat install/kubernetes/edgemicro-sidecar-injector.yaml | \ ./install/kubernetes/webhook-patch-ca-bundle.sh > \ install/kubernetes/edgemicro-sidecar-injector-with-ca-bundle.yaml
Edge Microgateway sidecar injector Webhook をインストールします。
kubectl apply -f install/kubernetes/edgemicro-sidecar-injector-with-ca-bundle.yaml
出力例:
service "edgemicro-sidecar-injector" created serviceaccount "edgemicro-sidecar-injector-service-account" created deployment "edgemicro-sidecar-injector" created mutatingwebhookconfiguration "edgemicro-sidecar-injector" created
Edge Microgateway サイドカー インジェクタ Webhook が実行されていることを確認します。
kubectl -n edgemicro-system get deployment -ledgemicro=sidecar-injector
出力例:
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE edgemicro-sidecar-injector 1 1 1 1 12m
サイドカー インジェクション Pod がクラスタで実行されていることを確認します。名前空間
edgemicro-system
には、Ingress コントローラ、デフォルトの HTTP バックエンド、サイドカー インジェクタなどのシステム サービスがインストールされます。kubectl get pods -n edgemicro-system
出力例:
NAME READY STATUS RESTARTS AGE default-http-backend-55c6c69b88-gfnfd 1/1 Running 0 1h edgemicro-ingress-controller-64444469bf-jhn8b 1/1 Running 3 1h edgemicro-sidecar-injector-7d95698fbf-cq84q 1/1 Running 0 3m
Edge Microgateway を構成して挿入する
次のステップでは、インタラクティブ スクリプトを実行して、Kubernetes Namespace に関連付けられた Edge Microgateway 構成を作成します。次に、構成を Kubernetes クラスタに挿入します。
次のインタラクティブ スクリプトを実行し、必要なパラメータを指定します。このコマンドは、次のステップで使用する構成プロファイルを生成します。
./install/kubernetes/webhook-edgemicro-patch.sh
入力パラメータの詳細については、リファレンスをご覧ください。
入力例:
Namespace to deploy application [default]:
Enter キーを押します。
Authenticate with OAuth Token ("n","Y") [N/y]
[n] と入力します。
Apigee username [required]:
Apigee のユーザー名(メールアドレス)を入力します。例:
jdoe@google.com
。Apigee password [required]:
Apigee のパスワードを入力します。
Apigee organization [required]:
Apigee 組織名を入力します。
Apigee environment [required]:
組織の環境名を入力します。たとえば「test」です。
Virtual Host [default]:
Enter キーを押します。
Is this Private Cloud ("n","y") [N/y]:
Public Cloud を使用している場合は「n」と入力します。
Edgemicro Key. Press Enter to generate:
Enter キーを押します。
Edgemicro Secret. Press Enter to generate:
Enter キーを押します。
Edgemicro org-env-config.yaml. Press Enter to generate:
Enter キーを押します。
出力例:
current nodejs version is v6.9.1 current edgemicro version is 2.5.25 config initialized to /Users/jdoe/.edgemicro/default.yaml Configure for Cloud ****************************************************************************************** Config file is Generated in /Users/jdoe/Work/GITHUB/microgateway_2.5.25_Darwin_x86_64/config directory. Please make changes as desired. *****************************************************************************************
Do you agree to proceed("n","y") [N/y]:
「y」と入力します。
出力例:
Configuring Microgateway with key:daacf75dd660d160b801c9117fb1ec0935896615479e39dbbae88be81a2d84 secret:a60fd57c1db9f3a06648173fb541cb9c59188d3b6037a76f490ebf7a6584b0 config:~/.edgemicro/jdoe-test-config.yaml ******************************************************************************************************** kubectl apply -f install/kubernetes/edgemicro-config-namespace-bundle.yaml ********************************************************************************************************
出力の最後の行に示されているコマンドを実行します。この
kubectl
コマンドは、生成された Edge Microgateway 構成プロファイルを Kubernetes に挿入します。kubectl apply -f install/kubernetes/edgemicro-config-namespace-bundle.yaml
Webhook 挿入のステータスを確認します。現時点では有効になっていません。
kubectl get namespace -L edgemicro-injection
出力例:
NAME STATUS AGE EDGEMICRO-INJECTION default Active 1d edgemicro-system Active 1d kube-public Active 1d kube-system Active 1d
次のコマンドを実行して、Webhook の Webhook 挿入を有効にします。
kubectl label namespace default edgemicro-injection=enabled
Webhook 挿入のステータスをもう一度確認します。有効になっていることを確認します。
kubectl get namespace -L edgemicro-injection
出力例:
NAME STATUS AGE EDGEMICRO-INJECTION default Active 1d enabled edgemicro-system Active 1d kube-public Active 1d kube-system Active 1d
テストサービスをデプロイする
次に、テストサービスを再デプロイします。Edge Microgateway は、サービスの Pod に自動的に挿入されます。
kubectl apply -f samples/helloworld/helloworld.yaml --namespace=default
Edge Microgateway がテストサービスとともに Pod に挿入されていることを確認します。
kubectl get pods --namespace=default --watch
出力例:
NAME READY STATUS RESTARTS AGE
helloworld-6987878fc4-pkw8h 0/2 PodInitializing 0 12s
helloworld-6987878fc4-pkw8h 2/2 Running 0 26s
ステータスが Running
に変わったら、ctrl-c
を押してコマンドを終了します。
これで、Edge Microgateway の自動サイドカー デプロイをテストする準備が整いました。詳細な手順については、プロキシをテストするをご覧ください。
プロキシをテストする
サイドカー デプロイを使用すると、サービスの API プロキシが自動的に作成されます。「Edge Microgateway 対応」プロキシを作成する必要はありません。
Ingress の IP アドレスを取得する
Ingress の外部 IP を使用すると、クラスタの外部からサービスを呼び出すことができます。
Ingress コントローラの外部 IP アドレスを取得します。
kubectl get ing -o wide
出力例:
NAME HOSTS ADDRESS PORTS AGE gateway * 35.238.13.54 80 1m
Ingress の
EXTERNAL-IP
値をコピーして変数にエクスポートします。変数を手動で設定できます。export GATEWAY_IP=external_ip
次に例を示します。
export GATEWAY_IP=35.238.249.62
または、次のコマンドを使用して設定します。
export GATEWAY_IP=$(kubectl describe ing gateway --namespace default | grep "Address" | cut -d ':' -f2 | tr -d "[:space:]")
変数がエクスポートされたことを確認します。次に例を示します。
echo $GATEWAY_IP
出力例:
35.238.249.62
サービスを呼び出します。
curl $GATEWAY_IP
出力:
{"error":"missing_authorization","error_description":"Missing Authorization header"}
次に、Edge で API プロダクトとデベロッパー アプリを構成して有効な API キーを取得できるようにし、認可エラーを解決します。API 呼び出しの認可ヘッダーにキーを追加すると、呼び出しは成功し、このエラーは表示されなくなります。
Apigee Edge でコンポーネントを作成する
次に、Apigee Edge で API プロダクトとデベロッパー アプリを作成します。
API プロダクトを作成する
- Apigee Edge にログインします。
- サイド ナビゲーション メニューで、[Publish] > [API Products] を選択します。
- [+ API Product] をクリックします。商品ページが表示されます。
[Product] ページに、次のように入力します。以下に記載されていないフィールドには、デフォルト値を使用できます。指示があるまで、保存しないでください。
名前 hello-world-product
表示名 Edge Micro hello product
環境 test
[パス] セクションで、[+ カスタム リソース] をクリックします。
パス
/
を追加します。もう一度 [+ Custom Resource] をクリックし、パス
/**
を追加します。[API Proxies] セクションで、[+ API Proxy] をクリックし、edgemicro-auth を追加します。
API プロダクトを保存します。
デベロッパー アプリを作成する
- サイド ナビゲーション メニューで [アプリ] を選択します。
- [+ App] をクリックします。[Developer App Details] ページが表示されます。
[Developer App] ページに、次のように入力します。指示があるまで、保存しないでください。
名前 hello-world-app
表示名 Edge Micro hello app
デベロッパー プルダウン メニューからデベロッパーを選択します。 [Credentials] セクションで [+ Product] をクリックし、作成した
hello-world-product
を選択します。[保存] をクリックします。
すべてのデベロッパー アプリを一覧表示するページに戻ります。
作成したアプリ(
hello-world-app
)を選択します。[Consumer Key] の横にある [Show] をクリックします。
コンシューマ キーの値をコピーします。この値は、
helloworld
サービスに対して安全な API 呼び出しを行うために使用する API キーです。数分待って、Apigee Edge で行った変更が、クラスタにデプロイされた Edge Microgateway のインスタンスと同期されるまで、数分ほどかかります。
API を呼び出す
構成変更がマイクロゲートウェイに pull されたら、次のテストを実行できます。
API キーなしで API を呼び出します。次のようなエラー メッセージが表示されます。
curl $GATEWAY_IP
予想される出力:
{"error":"missing_authorization","error_description":"Missing Authorization header"}
API 呼び出しを正常に行うには、API キーが必要です。
作成したデベロッパー アプリからコンシューマ キーを取得します。この値は、テスト プロキシを呼び出すために必要な API キーです。
curl -H 'x-api-key:your-edge-api-key' $GATEWAY_IP
次に例を示します。
curl -H "x-api-key:DeX2eEesYAdRJ5Gdbo77nT9uUfJZql19" $GATEWAY_IP
出力:
Hello world
「Hello world」レスポンスは、Pod にデプロイされた helloworld サービスによって返されます。そのサービスへの呼び出しは、まず Edge Microgateway を通過し、そこで認証が行われました。「Hello world」レスポンスが表示されたら、helloworld Service Pod でサイドカー プロキシとして機能するように Edge Microgateway が正常に構成されています。
次のステップ
カスタム プラグインの追加、デプロイのスケーリング、構成の変更などのタスクについては、タスクのセクションをご覧ください。