ローカルネットワーク上の他のkubernetesポッドのIPアドレスを取得する最良の方法は何ですか?Kubernetes:ネットワーク上の他のポッドのIPアドレスを取得する
現在、次のコマンドを使用して出力を解析しています:kubectl describe pods
。
残念ながら、上記のコマンドは完了までに多くの時間がかかります(少なくとも3回、多くの場合30秒以上)。ほとんどのリクエストがほぼ同時に発生すると、503スタイルのエラーが発生します。私はローカルのポッドにIPアドレスをキャッシュするためにこのコマンドの周りにキャッシュシステムを構築しましたが、10個程度のポッドが目を覚ましてこのキャッシュを作成する必要がある場合、大きな遅延があり、多くの場合エラーがあります。私は何かが間違っているように感じる。ネットワーク上の他のポッドのIPアドレスを取得することは、簡単なプロセスであるように思えます。だから、それらを得るための最善の方法は何ですか?
詳細については、コンテナエンジンでGoogleのkubernetesシステムを使用しています。標準のUbuntuイメージを実行する。
コンテキスト:コンテキストを追加するには、私が一緒にクラスタ上のポッドの間での共有のmemcachedを入れしようとしています。そうするためには、彼らはお互いのIPアドレスを知る必要があります。 memcachedの目的のためにポッド/インスタンスを簡単にリンクする方法があれば、それも役に立ちます。
Memcacheは、memcacheプールに参加しているネットワーク上のすべてのサーバーを知る必要があります。これが機能するかどうかはわかりません。 – speedplane
StatefulSetを使ってネットワーク内のすべてのアイデンティティを知る必要がある場合、私の答えの2番目の部分を参照してください。 – vascop
StatefulSetのことは聞いたことがなく、かなり新しくなっているようですが、Kubernetesは本当に動くターゲットです! – speedplane