このドキュメントでは、Apigee Edge for Private Cloud のオンプレミス デプロイでサポートされているコンポーネントのモニタリング方法について説明します。
概要
Edge では、サービスの詳細を取得したり、そのステータスを確認したりするために、いくつかの方法がサポートされています。次の表に、対象のサービスで実施可能な確認の種類を示します。
Mgmt API | |||||||
コンポーネント | メモリ使用量 [JMX*] | サービスのチェック | ユーザー/組織/ デプロイのステータス | axstatus | データベースのチェック | apigee-service のステータス |
apigee-monit ** |
Management Server | |||||||
Message Processor | |||||||
ルーター | |||||||
Qpid | |||||||
Postgres | |||||||
詳細 | 詳細 | 詳細 | 詳細 | 詳細 | 詳細 | 詳細 | |
* JMX を使用するには、その前に JMX を有効にするの手順に沿って JMX を有効にする必要があります。 ** |
ポートと構成ファイルのモニタリング
各コンポーネントは、さまざまなポートでの Java Management Extensions(JMX)と Management API のモニタリング呼び出しをサポートしています。次の表に、それぞれの種類のサーバーで使用される JMX と Management API のポートと、構成ファイルの場所を示します。
コンポーネント | JMX ポート | Management API ポート | 構成ファイルの場所 |
---|---|---|---|
管理サーバー | 1099 | 8080 | $APIGEE_ROOT/customer/application/management-server.properties |
Message Processor | 1101 | 8082 | $APIGEE_ROOT/customer/application/message-processor.properties |
ルーター | 1100 | 8081 | $APIGEE_ROOT/customer/application/router.properties |
Qpid | 1102 | 8083 | $APIGEE_ROOT/customer/application/qpid-server.properties |
Postgres | 1103 | 8084 | $APIGEE_ROOT/customer/application/postgres-server.properties |
JMX を使用してコンポーネントをモニタリングする
以降のセクションで、JMX を使用して Edge コンポーネントをモニタリングする方法について説明します。
JMX を有効にする
認証または SSL ベースの通信なしで JMX を有効にするには、次の手順を行います。注: 本番環境システムでは、セキュリティを確保するために暗号化認証と SSL の両方を有効にしてください。
- 該当する構成ファイル(
構成ファイル リファレンスを参照)を編集します。構成ファイルが存在しない場合は作成します。
conf_system_jmxremote_enable=true
- 構成ファイルを保存して、ファイルの所有者が
apigee:apigee
であることを確認します。 - 該当する Edge コンポーネントを再起動します。
apigee-service edge-management-server restart
JMX を無効にするには、conf_system_jmxremote_enable
プロパティを削除するか、値を false
に変更します。そのうえで、該当する Edge コンポーネントを再起動します。
JMX での認証
Edge for Private Cloud は、ファイルに保存されている詳細情報を使用したパスワード ベースの認証をサポートしています。セキュリティを強化するために、パスワードをハッシュとして保存できます。
- edge-* コンポーネントで JMX 認証を有効にするには、該当する構成ファイルを編集します(
構成ファイル リファレンスをご覧ください)。構成ファイルが存在しない場合は作成します。
conf_system_jmxremote_enable=true conf_system_jmxremote_authenticate=true conf_system_jmxremote_encrypted_auth=true conf_system_jmxremote_access_file=/opt/apigee/customer/application/management-server/jmxremote.access conf_system_jmxremote_password_file=/opt/apigee/customer/application/management-server/jmxremote.password
構成ファイルを保存して、ファイルの所有者がapigee:apigee
であることを確認します。 - パスワードの SHA256 ハッシュを作成します。
echo -n '
' | openssl dgst -sha256 - JMX ユーザー認証情報を記載した
jmxremote.password
ファイルを作成します。$JAVA_HOME
ディレクトリ内にある次のファイルを/opt/apigee/customer/application/<component>/
ディレクトリにコピーします。cp ${JAVA_HOME}/lib/management/jmxremote.password.template $APIGEE_ROOT/customer/application/management-server/jmxremote.password
- ファイルをエディタで開き、JMX のユーザー名とパスワードを次の構文で追加します。
USERNAME <HASH-PASSWORD>
- ファイルの所有者を
apigee
に設定し、ファイルのモードを 400 にします。chown apigee:apigee $APIGEE_ROOT/customer/application/management-server/jmxremote.password chmod 400 $APIGEE_ROOT/customer/application/management-server/jmxremote.password
- JMX ユーザー権限を記載した
jmxremote.access
ファイルを作成します。- 次のファイルを $JAVA_HOME ディレクトリからディレクトリ
/opt/apigee/customer/application/<component>/
にコピーします。cp ${JAVA_HOME}/lib/management/jmxremote.access$APIGEE_ROOT/customer/application/management-server/jmxremote.password/jmxremote.access
- ファイルを編集し、JMX ユーザー名に続けて権限(読み取り/書き込み)を追加します。
USERNAME READONLY
- ファイルの所有者を
apigee
に設定し、ファイルのモードを 400 にします。chown apigee:apigee $APIGEE_ROOT/customer/application/management-server/jmxremote.password chmod 400 $APIGEE_ROOT/customer/application/management-server/jmxremote.access
- 次のファイルを $JAVA_HOME ディレクトリからディレクトリ
- 該当する Edge コンポーネントを再起動します。
apigee-service edge-management-server restart
JMX 認証を無効にするには、conf_system_jmxremote_authenticate
プロパティを削除するか、その値を false
に変更してから、該当する Edge コンポーネントを再起動します。
JMX での SSL
edge-* コンポーネントで SSL ベースの JMX を有効にするには、次の手順に従います。
- 該当する構成ファイル(
構成ファイル リファレンスを参照)を編集します。構成ファイルが存在しない場合は作成します。
conf_system_jmxremote_enable=true conf_system_jmxremote_ssl=true conf_system_javax_net_ssl_keystore=/opt/apigee/customer/application/management-server/jmxremote.keystore conf_system_javax_net_ssl_keystorepassword=<keystore-password>
構成ファイルを保存して、ファイルの所有者がapigee:apigee
であることを確認します。 - サーバーキーを格納したキーストアを準備して、上記の構成
conf_system_javax_net_ssl_keystore
で指定されているパスに配置します。apigee:apigee
がキーストア ファイルを読み取れるようにします。 - 該当する Edge コンポーネントを再起動します。
apigee-service edge-management-server restart
SSL ベースの JMX を無効にするには、conf_system_jmxremote_ssl
プロパティを削除するか、その値を false
に変更します。適切な Edge コンポーネントを再起動します。
JConsole でのモニタリング
JConsole でのモニタリング手順は、https://docs.apigee.com/private-cloud/v4.52.01/how-monitor#jconsole で説明されている手順と同じままです。
「JMX で SSL が有効になっている場合は、トラストストアとトラストストア パスワードを使用して JConsole を起動する必要がある」ことを指定する 1 行を追加できます。リファレンス: https://docs.oracle.com/javase/8/docs/technotes/guides/management/jconsole.htmlJConsole によるモニタリング
JConsole(JMX 準拠ツール)を使用して、ヘルスチェックとプロセス統計を管理し、モニタリングします。JConsole では、サーバーによって公開されている JMX 統計情報がグラフィカル インターフェースに表示されます。詳細については、JConsole の使用をご覧ください。
JMX で SSL が有効になっている場合は、トラストストアとトラストストア パスワードを使用して JConsole を起動する必要があります。 JConsole の使用をご覧ください。
JConsole では、次のサービス URL を使用して、JMX 経由で提供される JMX 属性(MBeans)をモニタリングします。
service:jmx:rmi:///jndi/rmi://IP_address:port_number/jmxrmi
ここで
- IP_address は、モニタリングするサーバーの IP アドレスです。
- port_number は、モニタリングするサーバーの JMX ポート番号です。
たとえば、Management Server をモニタリングするには、次のようなコマンドを実行します(サーバーの IP アドレスが 216.3.128.12 の場合)。
service:jmx:rmi:///jndi/rmi://216.3.128.12:1099/jmxrmi
この例では、Management Server の JMX のポート番号(1099)を使用しています。他のポートについては、JMX と Management API のモニタリング ポートをご覧ください。
次の表に、一般的な JMX 統計を示します。
JMX MBeans | JMX 属性 |
---|---|
メモリ |
HeapMemoryUsage |
NonHeapMemoryUsage |
|
用途 |
|
構成ファイル リファレンス
以降のセクションで、JMX 関連の構成を行う際に Edge コンポーネント構成ファイルに加える変更について説明します。詳細については、ポートと構成ファイルのモニタリングをご覧ください。
所定のコンポーネントの構成ファイルに追加する JMX 構成
- Edge コンポーネントで JMX エージェントを有効にするには、次の変更を加えます。デフォルトは false です。
conf_system_jmxremote_enable=true
パスワードに基づく認証の構成
- パスワードに基づく認証を有効にするには、次の変更を加えます。デフォルトは false です。
conf_system_jmxremote_authenticate=true
- アクセス ファイルのパス。このファイルは Apigee ユーザーが所有して、他のユーザーは読み取れないようにする必要があります。
conf_system_jmxremote_access_file=/opt/apigee/customer/application/management-server/jmxremote.access
- パスワード ファイルのパス。このファイルは Apigee ユーザーが所有して、他のユーザーは読み取れないようにする必要があります。
conf_system_jmxremote_password_file=/opt/apigee/customer/application/management-server/jmxremote.password
- パスワードを暗号化形式で保存できるようにするには、次の変更を加えます。デフォルトは false です。
conf_system_jmxremote_encrypted_auth=true
SSL ベースの JMX の構成
- JMX 通信に対して SSL を有効にするには、次の変更を加えます。デフォルトは false です。
conf_system_jmxremote_ssl=true
- キーストアのパス。このファイルは Apigee ユーザーが所有して、他のユーザーは読み取れないようにする必要があります。
conf_system_javax_net_ssl_keystore=/opt/apigee/customer/application/management-server/jmxremote.keystore
- キーストア パスワード:
conf_system_javax_net_ssl_keystorepassword=changeme
オプションの JMX 構成
以下にデフォルト値を記載します。これらのデフォルト値は変更できます。
- JMX ポート。デフォルト値は以下の表に記載されています。
conf_system_jmxremote_port=
- JMX RMI ポート。デフォルトでは、Java プロセスはランダムなポートを選択します。
conf_system_jmxremote_rmi_port=
- リモートスタブのホスト名。localhost のデフォルト IP アドレス。
conf_system_java_rmi_server_hostname=
- JMX レジストリを SSL で保護するには、次の変更を加えます。デフォルトは false です。SSL が有効にされている場合にのみ適用されます。
conf_system_jmxremote_registry_ssl=false
Management API でモニタリングする
Edge には、サーバーのサービス チェックに使用できる API があります。また、ユーザー、組織、デプロイの状況を検査できる API もあります。以下では、これらの API について説明します。
サービス チェックを実行する
Management API には、サービスのモニタリングと問題の診断に使用できるエンドポイントがいくつかあります。エンドポイントには次のようなものがあります。
エンドポイント | 説明 |
---|---|
/servers/self/up |
サービスが実行されているかどうかを検査します。この API 呼び出しに認証は不要です。 サービスが実行中の場合、このエンドポイントは次のレスポンスを返します。 <ServerField> <Up>true</Up> </ServerField> サービスが実行されていない場合、次のようなレスポンスが返されます。検査されるサービスと検査方法によって内容が異なります。 curl: Failed connect to localhost:port_number; Connection refused |
/servers/self |
サービスに関する次の情報を返します。
この API を呼び出すには、Apigee 管理者の認証情報で認証を行う必要があります。 |
これらのエンドポイントを使用するには、curl
などのユーティリティで次の構文を使用してコマンドを実行します。
curl http://host:port_number/v1/servers/self/up -H "Accept: [application/json|application/xml]"
curl http://host:port_number/v1/servers/self -u username:password -H "Accept: [application/json|application/xml]"
ここで
- host は、検査するサーバーの IP アドレスです。サーバーにログインしている場合は、「localhost」を使用できます。ログインしない場合は、サーバーの IP アドレスとユーザー名とパスワードを指定します。
- port_number は、確認するサーバーの Management API ポートです。これは、コンポーネントの種類によって異なります。たとえば、Management Server の Management API ポートは 8080 です。Management API のポート番号の一覧については、JMX と Management API のモニタリング ポートをご覧ください。
レスポンスの形式を変更するには、Accept
ヘッダーを「application/json」または「application/xml」として指定します。
次の例では、Router の localhost(ポート 8081)のステータスを取得しています。
curl http://localhost:8081/v1/servers/self/up -H "Accept: application/xml"
次の例では、216.3.128.12(ポート 8082)にある Message Processor に関する情報を取得します。
curl http://216.3.128.12:8082/v1/servers/self -u sysAdminEmail:password -H "Accept: application/xml"
ユーザー、組織、デプロイのステータスをモニタリングする
Management API を使用して次のコマンドを実行すると、Management Server と Message Processor 上のプロキシのユーザー、組織、デプロイ ステータスをモニタリングできます。
curl http://host:port_number/v1/users -u sysAdminEmail:passwordcurl http://host:port_number/v1/organizations -u sysAdminEmail:password
curl http://host:port_number/v1/organizations/orgname/deployments -u sysAdminEmail:password
port_number は、Management Server の場合は 8080、Message Processor の場合は 8082 です。
この呼び出しでは、システム管理のユーザー名とパスワードで認証を行う必要があります。
すべての呼び出しでサーバーから「デプロイ済み」ステータスが返されるはずです。そうでない場合は、次の操作を行います。
- サーバーのログでエラーを確認します。ログは次の場所にあります。
- Management Server:
opt/apigee/var/log/edge-management-server
- Message Processor:
opt/apigee/var/log/edge-message-processor
- Management Server:
- サーバーに対して呼び出しを行い、正しく機能しているかどうかを確認します。
- サーバーを ELB から削除して再起動します。
/opt/apigee/apigee-service/bin/apigee-service service_name restart
ここで、service_name は次のようになります。
edge-management-server
edge-message-processor
apigee-service
コマンドでステータスを確認する
Edge サービスのトラブルシューティングを行うには、サービスを実行しているサーバーにログインして apigee-service
コマンドを使用できます。
apigee-service
を使用してサービスのステータスを確認するには:
- サーバーにログインして、次のコマンドを実行します。
/opt/apigee/apigee-service/bin/apigee-service service_name status
ここで、service_name は次のいずれかです。
- Management Server:
edge-management-server
- Message Processor:
edge-message-processor
- Postgres:
edge-postgres-server
- Qpid:
edge-qpid-server
- Router:
edge-router
例:
/opt/apigee/apigee-service/bin/apigee-service edge-message-processor status
- Management Server:
- サービスが実行されていない場合は、サービスを起動します。
/opt/apigee/apigee-service/bin/apigee-service service_name start
- サービスを再起動したら、以前に使用した
apigee-service status
コマンドを使用するか、Management API でモニタリングするで説明されている Management API を使用して、サービスが機能していることを確認します。例:
curl -v http://localhost:port_number/v1/servers/self/up
ここで、port_number はサービスの Management API ポートです。
この例では、ユーザーがサーバーにログイン済みで、ホスト名として「localhost」を使用できることを前提としています。Management API を使用してリモートでステータスを確認するには、API 呼び出しにサーバーの IP アドレスを指定し、システム管理者のユーザー名とパスワードを含める必要があります。
Postgres のモニタリング
Postgres は、ステータスの確認に使用できるいくつかのユーティリティをサポートしています。以下では、これらのユーティリティについて説明します。
Postgres の組織と環境を検査する
PostgreSQL サーバーにオンボーディングされている組織名と環境名を確認するには、次の curl
コマンドを実行します。
curl -v http://postgres_IP:8084/v1/servers/self/organizations
システムに組織名と環境名が表示されます。
アナリティクスのステータスを確認する
Postgres と Qpid の分析サーバーのステータスを確認するには、次の curl
コマンドを実行します。
curl -u userEmail:password http://host:port_number/v1/organizations/orgname/environments/envname/provisioning/axstatus
次の例のように、すべての分析サーバーのステータスが「SUCCESS」になっていれば問題ありません。
{ "environments" : [ { "components" : [ { "message" : "success at Thu Feb 28 10:27:38 CET 2013", "name" : "pg", "status" : "SUCCESS", "uuid" : "[c678d16c-7990-4a5a-ae19-a99f925fcb93]" }, { "message" : "success at Thu Feb 28 10:29:03 CET 2013", "name" : "qs", "status" : "SUCCESS", "uuid" : "[ee9f0db7-a9d3-4d21-96c5-1a15b0bf0adf]" } ], "message" : "", "name" : "prod" } ], "organization" : "acme", "status" : "SUCCESS" }
PostgreSQL データベース
このセクションでは、Postgres データベースのモニタリングに使用できる方法について説明します。
check_postgres.pl
スクリプトを使用する
PostgreSQL データベースのモニタリングには、標準のモニタリング スクリプトである check_postgres.pl
を使用できます。詳細については、http://bucardo.org/wiki/Check_postgres をご覧ください。
スクリプトを実行する前に:
- 各 Postgres ノードに check_postgres.pl スクリプトをインストールします。
perl-Time-HiRes.x86_64
がインストールされていることを確認します。これは、高分解能アラーム、スリープ、gettimeofday、インターバル タイマーを実装した Perl モジュールです。たとえば、次のコマンドを使用してこのモジュールをインストールできます。
yum install perl-Time-HiRes.x86_64
- CentOS 7: CentOS v7 で check_postgres.pl を使用する前に、
perl-Data-Dumper.x86_64
RPM をインストールします。
check_postgres.pl の出力
check_postgres.pl
を使用した API 呼び出しのデフォルトの出力は、Nagios と互換性があります。スクリプトをインストールした後、次の検査を行います。
- データベースのサイズを確認します。
check_postgres.pl -H 10.176.218.202 -db apigee -u apigee -dbpass postgres -include=apigee -action database_size --warning='800 GB' --critical='900 GB'
- データベースの受信接続数と最大許容接続数を比較します。
check_postgres.pl -H 10.176.218.202 -db apigee -u apigee -dbpass postgres -action backends
- データベースが実行中で、使用可能な状態であることを確認します。
check_postgres.pl -H 10.176.218.202 -db apigee -u apigee -dbpass postgres -action connection
- ディスク容量を確認します。
check_postgres.pl -H 10.176.218.202 -db apigee -u apigee -dbpass postgres -action disk_space --warning='80%' --critical='90%'
- Postgres ノードにオンボーディングされている組織と環境の数を確認します。
check_postgres.pl -H 10.176.218.202 -db apigee -u apigee -dbpass postgres -action=custom_query --query="select count(*) as result from pg_tables where schemaname='analytics' and tablename like '%fact'" --warning='80' --critical='90' --valtype=integer
データベース チェックを実行する
PostgreSQL データベースに正しいテーブルが作成されていることを検査できます。次のコマンドを使用して、PostgreSQL データベースにログインします。
psql -h /opt/apigee/var/run/apigee-postgresql/ -U apigee -d apigee
次のコマンドを実行します。
\d analytics."org.env.fact"
Postgres プロセスのヘルス ステータスを検査する
API を使用して PostgreSQL マシンの状態を検査するには、次の curl
コマンドを実行します。
curl -v http://postgres_IP:8084/v1/servers/self/health
Postgres プロセスが稼働中であれば ACTIVE
ステータスが返されます。Postgres プロセスが稼働していないときは、INACTIVE
ステータスが返されます。
Postgres リソース
Postgres サービスのモニタリングに関する詳細については、次をご覧ください。
- http://www.postgresql.org/docs/9.0/static/monitoring.html
- http://www.postgresql.org/docs/9.0/static/diskusage.html
- http://bucardo.org/check_postgres/check_postgres.pl.html
Apache Cassandra
Cassandra では、JMX がデフォルトで有効になっています。リモートの JMX から Cassandra にアクセスする場合、パスワードは不要です。
Cassandra で JMX 認証を有効にする
Cassandra の JMX 認証を有効にできます。こうすると、その後、nodetool ユーティリティを呼び出すたびにユーザー名とパスワードを渡すことが必要になります。
Cassandra の JMX 認証を有効にするには:
cassandra.properties
ファイルを作成して編集します。/opt/apigee/customer/application/cassandra.properties
ファイルを編集します。ファイルが存在しない場合は作成します。- ファイルに以下を追加します。
conf_cassandra_env_com.sun.management.jmxremote.authenticate=true conf_cassandra_env_com.sun.management.jmxremote.password.file=${APIGEE_ROOT}/customer/application/apigee-cassandra/jmxremote.password conf_cassandra_env_com.sun.management.jmxremote.access.file=${APIGEE_ROOT}/customer/application/apigee-cassandra/jmxremote.access
cassandra.properties
ファイルを保存します。- 次の例に示すように、ファイルの所有者を
apigee:apigee
に変更します。chown apigee:apigee /opt/apigee/customer/application/cassandra.properties
プロパティ ファイルを使用したトークンの設定について、詳しくは Edge の構成方法をご覧ください。
jmx_auth.sh
を作成して編集します。- ファイルが存在しない場合は、次の場所にファイルを作成します。
/opt/apigee/customer/application/jmx_auth.sh
- 次のプロパティをファイルに追加します。
export CASS_JMX_USERNAME=JMX_USERNAME export CASS_JMX_PASSWORD=JMX_PASSWORD
jmx_auth.sh
ファイルを保存します。- ファイルを読み込みます。
source /opt/apigee/customer/application/jmx_auth.sh
- ファイルが存在しない場合は、次の場所にファイルを作成します。
jmxremote.password
ファイルをコピーして編集します。$JAVA_HOME
ディレクトリにある次のファイルを/opt/apigee/customer/application/apigee-cassandra/
にコピーします。cp ${JAVA_HOME}/lib/management/jmxremote.password.template $APIGEE_ROOT/customer/application/apigee-cassandra/jmxremote.password
jmxremote.password
ファイルをエディタで開き、JMX のユーザー名とパスワードを次の構文で追加します。JMX_USERNAME JMX_PASSWORD
JMX_USERNAME と JMX_PASSWORD は、以前に設定した JMX のユーザー名とパスワードです。
- ファイルの所有者を「apigee」に設定し、ファイルのモードを 400 にします。
chown apigee:apigee /opt/apigee/customer/application/apigee-cassandra/jmxremote.password
chmod 400 /opt/apigee/customer/application/apigee-cassandra/jmxremote.password
jmxremote.access
ファイルをコピーして編集します。$JAVA_HOME
ディレクトリにある次のファイルを/opt/apigee/customer/application/apigee-cassandra/
にコピーします。cp ${JAVA_HOME}/lib/management/jmxremote.access
$APIGEE_ROOT/customer/application/apigee-cassandra/jmxremote.access
jmxremote.access
ファイルを編集して、次のロールを追加します。JMX_USERNAME readwrite
- ファイルの所有者を「apigee」に設定し、ファイルのモードを 400 にします。
chown apigee:apigee /opt/apigee/customer/application/apigee-cassandra/jmxremote.access
chmod 400 /opt/apigee/customer/application/apigee-cassandra/jmxremote.access
- Cassandra で
configure
を実行します。/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra configure
- Cassandra を再起動します。
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra restart
- 他のすべての Cassandra ノードで、この手順を繰り返します。
JMX のパスワード暗号化を有効にする
JMX のパスワード暗号化を有効にする手順は次のとおりです。
source/conf/casssandra-env.sh
ファイルを開きます。cassandra.properties
ファイルを作成して編集します。/opt/apigee/customer/application/cassandra.properties
ファイルを編集します。ファイルが存在しない場合は作成します。- ファイルに以下を追加します。
conf_cassandra_env_com.sun.management.jmxremote.encrypted.authenticate=true
- cassandra.properties ファイルを保存します。
- 次の例に示すように、ファイルの所有者を apigee:apigee に変更します。
chown apigee:apigee /opt/apigee/customer/application/cassandra.properties
- コマンドラインで「
echo -n 'Secret' | openssl dgst -sha1
」と入力して、目的のパスワードの SHA1 ハッシュを生成します。 - 前のセクションで作成した
$APIGEE_ROOT/customer/application/apigee-cassandra/jmxremote.password
のユーザー名に対応するパスワードを設定します。 - Cassandra で configure を実行します。
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra configure
- Cassandra を再起動します。
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra restart
- このプロセスを他のすべての Cassandra ノードで繰り返します。
Cassandra 用に SSL を使用する JMX を有効にする
SSL を使用する JMX を有効にすると、Cassandra との JMX ベースの通信でセキュリティと暗号化が強化されます。SSL で JMX を有効にするには、SSL ベースの JMX 接続を受け入れるための鍵と証明書を Cassandra に提供する必要があります。さらに、nodetool(および JMX を介して Cassandra と通信する他のすべてのツール)を SSL 用に構成する必要もあります。
SSL 対応の JMX では、平文パスワードと暗号化パスワードの両方がサポートされます。
Cassandra 用に SSL を使用する JMX を有効にするには、次の手順に沿います。
- JMX を有効にします。 必要に応じて、パスワードの暗号化を有効にします。
- Cassandra で JMX 認証を有効にします。
必要があります。nodetool が構成済みのユーザー名とパスワードで動作することを確認します。
/opt/apigee/apigee-cassandra/bin/nodetool -u <JMX_USER> -pw <JMX_PASS> ring
キーストアとトラストストアを準備します。
キーストアには鍵と証明書を入れておきます。Cassandra サーバーを構成するときにこれが使用されます。キーストアに複数の鍵ペアが含まれている場合、Cassandra は最初の鍵ペアを使用して SSL を有効にします。
キーストアと鍵のパスワードは同じにする必要があります(keytool を使用して鍵を生成する際のデフォルト)。
- トラストストアには証明書のみを入れておきます。クライアント(apigee-service ベースのコマンドまたは nodetool)はこれを使用して JMX 経由で接続します。
上記の要件を確認した後、次の手順を行います。
- キーストア ファイルを
/opt/apigee/customer/application/apigee-cassandra/
に配置します。 - 「
chown apigee:apigee /opt/apigee/customer/application/apigee-cassandra/keystore.node1
」と入力して、キーストア ファイルを Apigee ユーザーのみが読み取れるようにします。chmod 400 /opt/apigee/customer/application/apigee-cassandra/keystore.node1
- SSL を使用する JMX に対応するように Cassandra を構成するには、次の手順を行います。
-
apigee-service apigee-cassandra stop
と入力して Cassandra ノードを停止します。 - Cassandra で SSL を有効にするには、
/opt/apigee/customer/application/cassandra.properties
ファイルを開いて次の行を追加します。conf_cassandra_env_com.sun.management.jmxremote.ssl=true conf_cassandra_env_javax.net.ssl.keyStore=/opt/apigee/customer/application/apigee-cassandra/keystore.node1 conf_cassandra_env_javax.net.ssl.keyStorePassword=keystore-password ## On FIPS enabled systems, when you are using non standard keystore, set the following: ## These can be skipped otherwise ## Possible values are JKS, PKCS12, BCFKS conf_cassandra_env_javax.net.ssl.keyStoreType=PKCS12 conf_cassandra_env_javax.net.ssl.keyStoreAlias=cassjmx-tls-alias
- 次の例のように、ファイルのオーナーを apigee:apigee に変更します。
chown apigee:apigee /opt/apigee/customer/application/cassandra.properties
- Cassandra で構成を実行します。
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra configure
- Cassandra を再起動します。
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra restart
- このプロセスを他のすべての Cassandra ノードで繰り返します。
-
apigee-service apigee-cassandra start
と入力して Cassandra ノードを起動します。
-
apigee-service
Cassandra コマンドを構成します。apigee-service
コマンドの実行時に、次のような特定の環境変数を設定する必要があります。apigee-service apigee-cassandra stop apigee-service apigee-cassandra wait_for_ready apigee-service apigee-cassandra ring apigee-service apigee-cassandra backup
JMX 認証と SSL に対応するように
apigee-service
を構成する際には、いくつかのオプションがあります。便利さやセキュリティ対策を考慮して、オプションを 1 つ選択してください。オプション 1(SSL 引数をファイルに保存する)
次の環境変数を設定します。
export CASS_JMX_USERNAME=ADMIN # Provide encrypted password here if you have setup JMX password encryption export CASS_JMX_PASSWORD=PASSWORD export CASS_JMX_SSL=Y
Apigee ユーザーのホーム ディレクトリ(
/opt/apigee
)にファイルを作成します。$HOME/.cassandra/nodetool-ssl.properties
ファイルを編集して次の行を追加します。
-Djavax.net.ssl.trustStore=
-Djavax.net.ssl.trustStorePassword= -Dcom.sun.management.jmxremote.registry.ssl=true ## If you are using a non standard truststore, set below, otherwise skip ## Possible values are JKS, PKCS12, BCFKS -Djavax.net.ssl.trustStoreType=PKCS12 Apigee ユーザーがトラストストア ファイルを読み取れることを確認します。
次の
apigee-service
コマンドを実行します。 エラーなしで実行される場合、構成は正常です。apigee-service apigee-cassandra ring
オプション 2(SSL 引数を環境変数に格納する)
次の環境変数を設定します。
export CASS_JMX_USERNAME=ADMIN # Provide encrypted password here if you have setup JMX password encryption export CASS_JMX_PASSWORD=PASSWORD export CASS_JMX_SSL=Y # Ensure the truststore file is accessible by Apigee user. export CASS_JMX_TRUSTSTORE=
export CASS_JMX_TRUSTSTORE_PASSWORD= # If you are using a non standard truststore type, export truststore type as well # Possible values are JKS, PKCS12, BCFKS export CASS_JMX_TRUSTSTORE_TYPE=PKCS12 次の
apigee-service
コマンドを実行します。エラーなしで実行されている場合、構成は適切です。apigee-service apigee-cassandra ring
オプション 3(SSL 引数を
apigee-service
に直接渡す)次のような
apigee-service
コマンドを実行します。環境変数を構成する必要はありません。CASS_JMX_USERNAME=ADMIN CASS_JMX_PASSWORD=PASSWORD CASS_JMX_SSL=Y CASS_JMX_TRUSTSTORE=
CASS_JMX_TRUSTSTORE_PASSWORD= CASS_JMX_TRUSTSTORE_TYPE=PKCS12 /opt/apigee/apigee-service/bin/apigee-service apigee-cassandra ring nodetool を設定します。Nodetool では、JMX パラメータを渡す必要があります。以下の構成オプションで説明するように、SSL 対応の JMX で動作するように nodetool を構成する方法が 2 つあります。
これらのオプションの間では、SSL 関連の構成が nodetool に渡される方法が異なります。いずれの場合も、nodetool を実行するユーザーは、トラストストア ファイルに対する READ 権限を持っている必要があります。 ユーザビリティとセキュリティ対策に基づいて適切なオプションを選択してください。
nodetool パラメータの詳細については、 DataStax のドキュメントをご覧ください。
構成オプション 1
nodetool を実行するユーザーのホーム ディレクトリにファイルを作成します。
$HOME/.cassandra/nodetool-ssl.properties
このファイルに次の行を追加します。
-Djavax.net.ssl.trustStore=
-Djavax.net.ssl.trustStorePassword= -Dcom.sun.management.jmxremote.registry.ssl=true ## If you are using a non standard truststore, set below, otherwise skip ## Possible values are JKS, PKCS12, BCFKS -Djavax.net.ssl.trustStoreType=PKCS12 nodetool を実行するすべてのユーザーが上記のトラストストア パスにアクセスできるようにする必要があります。
--ssl
オプションを指定してnodetool
を実行します。/opt/apigee/apigee-cassandra/bin/nodetool --ssl -u <jmx-user-name> -pw <jmx-user-password> -h localhost ring
構成オプション 2
以下に示す追加のパラメータを指定して、
nodetool
を 1 つのコマンドとして実行します。/opt/apigee/apigee-cassandra/bin/nodetool -Djavax.net.ssl.trustStore=
-Djavax.net.ssl.trustStorePassword= -Dcom.sun.management.jmxremote.registry.ssl=true -Djavax.net.ssl.trustStoreType=PKCS12 -Dssl.enable=true -u -pw -h localhost ring
SSL 構成を元に戻す
上記の手順で説明した SSL 構成を元に戻す必要がある場合は、次の操作を行います。
apigee-cassandra
を停止するには、「apigee-service apigee-cassandra stop
」と入力します- ファイル
/opt/apigee/customer/application/cassandra.properties
から行conf_cassandra-env_com.sun.management.jmxremote.ssl=true
を削除します。 /opt/apigee/apigee-cassandra/source/conf/cassandra-env.sh
# JVM_OPTS="$JVM_OPTS -Djavax.net.ssl.keyStore=/opt/apigee/data/apigee-cassandra/keystore.node0" # JVM_OPTS="$JVM_OPTS -Djavax.net.ssl.keyStorePassword=keypass" # JVM_OPTS="$JVM_OPTS -Dcom.sun.management.jmxremote.registry.ssl=true”
の次の行をコメントアウトします。- 次のコマンドを入力して
apigee-cassandra
を開始します。 - 環境変数
CASS_JMX_SSL
が設定されている場合は、それを削除します。unset CASS_JMX_SSL
ring
、stop
、backup
などのapigee-service
ベースのコマンドが機能していることを確認します。- nodetool で
--ssl
スイッチの使用を停止します。
apigee-service apigee-cassandra start
Cassandra の JMX 認証を無効にする
Cassandra の JMX 認証を無効にするには:
/opt/apigee/customer/application/cassandra.properties
を編集します。- ファイルから次の行を削除します。
conf_cassandra-env_com.sun.management.jmxremote.authenticate=true
- Cassandra で configure を実行します。
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra configure
- Cassandra を再起動します。
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra restart
- 他のすべての Cassandra ノードで、この手順を繰り返します。
JConsole の使用: タスク統計をモニタリングする
JConsole と次のサービス URL を使用して、JMX 経由で提供される JMX 属性(MBeans)をモニタリングします。
service:jmx:rmi:///jndi/rmi://IP_address:7199/jmxrmi
ここで、IP_address は Cassandra サーバーの IP です。
Cassandra JMX の統計情報
JMX MBeans | JMX 属性 |
---|---|
ColumnFamilies/apprepo/environments ColumnFamilies/apprepo/organizations ColumnFamilies/apprepo/apiproxy_revisions ColumnFamilies/apprepo/apiproxies ColumnFamilies/audit/audits ColumnFamilies/audit/audits_ref |
PendingTasks |
MemtableColumnsCount |
|
MemtableDataSize |
|
ReadCount |
|
RecentReadLatencyMicros |
|
TotalReadLatencyMicros |
|
WriteCount |
|
RecentWriteLatencyMicros |
|
TotalWriteLatencyMicros |
|
TotalDiskSpaceUsed |
|
LiveDiskSpaceUsed |
|
LiveSSTableCount |
|
BloomFilterFalsePositives |
|
RecentBloomFilterFalseRatio |
|
BloomFilterFalseRatio |
nodetool でクラスタノードを管理する
nodetool ユーティリティは、クラスタノードを管理する Cassandra 用のコマンドライン インターフェースです。このユーティリティは /opt/apigee/apigee-cassandra/bin
にあります。
次の呼び出しを、すべての Cassandra クラスタノードで実行できます。
- 一般的なリング情報(単一の Cassandra ノードでも可能): すべてのノードで「Up」と「Normal」を探します。
nodetool [-u username -pw password] -h localhost ring
ユーザー名とパスワードを渡す必要があるのは、Cassandra に対して JMX 認証を有効にした場合のみです。
上記のコマンドの出力は次のようになります。
Datacenter: dc-1 ========== Address Rack Status State Load Owns Token 192.168.124.201 ra1 Up Normal 1.67 MB 33,33% 0 192.168.124.202 ra1 Up Normal 1.68 MB 33,33% 5671...5242 192.168.124.203 ra1 Up Normal 1.67 MB 33,33% 1134...0484
- ノードに関する一般情報(ノードごとの呼び出し)
nodetool [-u username -pw password] -h localhost info
上記のコマンドの出力は次のようになります。
ID : e2e42793-4242-4e82-bcf0-oicu812 Gossip active : true Thrift active : true Native Transport active: true Load : 273.71 KB Generation No : 1234567890 Uptime (seconds) : 687194 Heap Memory (MB) : 314.62 / 3680.00 Off Heap Memory (MB) : 0.14 Data Center : dc-1 Rack : ra-1 Exceptions : 0 Key Cache : entries 150, size 13.52 KB, capacity 100 MB, 1520781 hits, 1520923 requests, 1.000 recent hit rate, 14400 save period in seconds Row Cache : entries 0, size 0 bytes, capacity 0 bytes, 0 hits, 0 requests, NaN recent hit rate, 0 save period in seconds Counter Cache : entries 0, size 0 bytes, capacity 50 MB, 0 hits, 0 requests, NaN recent hit rate, 7200 save period in seconds Token : 0
- Thrift サーバーのステータス(クライアント API を提供するサーバー)
nodetool [-u username -pw password] -h localhost statusthrift
上記のコマンドの出力は次のようになります。
running
- データ ストリーミング オペレーションのステータス: Cassandra ノードのトラフィックを監視します。
nodetool [-u username -pw password] -h localhost netstats
上記のコマンドの出力は次のようになります。
Mode: NORMAL Not sending any streams. Read Repair Statistics: Attempted: 151612 Mismatch (Blocking): 0 Mismatch (Background): 0 Pool Name Active Pending Completed Dropped Commands n/a 0 0 0 Responses n/a 0 0 n/a
nodetool の詳細については、nodetool ユーティリティについてをご覧ください。
Cassandra のリリース
http://www.datastax.com/docs/1.0/operations/monitoring をご覧ください。
Apache Qpid Broker-J のモニタリング
Qpid 管理コンソールから Qpid Broker-J をモニタリングできます。このセクションでは、コンソールにアクセスして、基本的なモニタリング機能を実行する方法について説明します。管理コンソールの使用方法について詳しくは、Apache Qpid ドキュメントの ウェブ管理コンソールをご覧ください。
管理コンソールにアクセスする
デフォルトの管理コンソール ポートは 8090 です。このデフォルト ポートでコンソールにアクセスするには、ウェブブラウザで次の URL にアクセスします。
http://QPID_NODE_IP:8090
コンソールにログインするには、Apigee によって設定されたデフォルトの認証情報、または Edge 構成ファイルに設定された認証情報を使用します。詳細については、Edge 構成ファイル リファレンスをご覧ください。
キューとメッセージをモニタリングする
左側のナビゲーション パネルで、[Java-Broker] > [virtualhosts] > [queues] に移動します。キューを選択すると、UI のメイン部分にその詳細が表示されます。詳細ビューには、キュー属性と統計情報(配信されたメッセージ、キューに追加されたメッセージ、メッセージレートなど)が表示されます。
ログファイルを表示、ダウンロードする
左側のナビゲーション パネルで、[Java-Broker] > [brokerloggers] > [logfile] に移動します。メインの UI の詳細ビューでは、ログファイルの詳細を表示したり、ログファイルをダウンロードしたりできます。
Qpid 管理 API の使用
Apache Qpid Broker-J REST API を使用して、管理タスクを自動化し、ブローカーをモニタリングできます。詳細については、 Apache Qpid Broker REST API のドキュメントをご覧ください。
コマンドライン ツールを使用してブローカーをモニタリングすることもできます。例:
curl "QPID_NODE_IP":"8090"/api/latest/broker -u "USERNAME":"PASSWORD"
Qpid で SSL によるモニタリングを有効にする
モニタリングと管理のセキュリティを強化するには、Qpid の管理ポータルと Qpid の管理 API で SSL を有効にします。鍵と証明書を指定するには、以下のガイドラインに従ってください。
Qpid には、Apigee で有効にするファイル キーストアのオプションがあります。このタイプは、Java と keytool などの Java ツールで認識される標準の JKS キーストア形式を受け入れます。
キーストアの準備
keytool を使用するだけでなく、Qpidd のクライアントが使用できるように証明書ファイルを直接指定する必要があります。
キーストアの生成については、Java Keytool のドキュメントをご覧ください。
要件を確認した後
- キーストアと証明書のファイルを
/opt/apigee/customer/application/apigee-qpidd
に配置します。 - キーストア ファイルが Apigee ユーザーのみが読み取れるようにします。
chown apigee:apigee /opt/apigee/customer/application/apigee-qpidd/qpidd.keystore chmod 400 /opt/apigee/customer/application/apigee-qpidd/qpidd.keystore chown apigee:apigee /opt/apigee/customer/application/apigee-qpidd/qpidd-cert.pem chmod 400 /opt/apigee/customer/application/apigee-qpidd/qpidd-cert.pem
Qpid で SSL を有効にする
一度に 1 つの Qpid ノードで次の手順を実行します。
/opt/apigee/customer/application/qpidd.properties
ファイルを開き、次の行を追加します。
conf_qpidd_qpid_management.https.enabled=true conf_qpidd_qpid.keystore.storeUrl=/opt/apigee/customer/application/apigee-qpidd/qpidd.keystore conf_qpidd_qpid.keystore.password=keystore-password conf_qpidd_qpid.keystore.certificateAlias=certificate-alias conf_qpidd_qpid.keystore.certificate=/opt/apigee/customer/application/apigee-qpidd/qpidd-cert.pem
- ファイルの所有者を apigee:apigee に変更します。
chown apigee:apigee /opt/apigee/customer/application/qpidd.properties
- Qpidd を構成します。
apigee-service apigee-qpidd configure
- Qpidd を再起動します。
apigee-service apigee-qpidd restart
- wait_for_ready でステータスを確認します。
apigee-service apigee-qpidd wait_for_ready
SSL 構成を元に戻す
ファイル /opt/apigee/customer/application/qpidd.properties
からプロパティを削除するか、コメントアウトします。
conf_qpidd_qpid_management.https.enabled=true conf_qpidd_qpid.keystore.storeUrl=/opt/apigee/customer/application/apigee-qpidd/keystore
- Qpidd を構成します。
apigee-service apigee-qpidd configure
- Qpidd を再起動します。
apigee-service apigee-qpidd restart
- wait_for_ready でステータスを確認します。
apigee-service apigee-qpidd wait_for_ready
Apache ZooKeeper
ZooKeeper のステータスを検査する
- ZooKeeper プロセスが実行されていることを確認します。ZooKeeper の PID ファイルは
opt/apigee/var/run/apigee-zookeeper/apigee-zookeeper.pid
にあります。 - ZooKeeper のポートをテストします。すべての ZooKeeper サーバーのポート 2181 と 3888 への TCP 接続を確立できることを確認します。
- ZooKeeper データベースから値を読み取れることを確認します。ZooKeeper クライアント ライブラリ(または
/opt/apigee/apigee-zookeeper/bin/zkCli.sh
)を使用して接続し、データベースから値を読み取ります。 - ステータスを確認します。
/opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper status
ZooKeeper の 4 文字コマンドを使用する
netcat(nc)または telnet を使用してポート 2181 に小さなコマンドセット(4 文字コマンド)を送ることで、ZooKeeper をモニタリングできます。
ZooKeeper コマンドの詳細については、Apache ZooKeeper コマンド リファレンスをご覧ください。
例:
srvr
: サーバーの完全な詳細情報を一覧表示します。stat
: サーバーと接続クライアントの簡潔な詳細情報を一覧表示します。
ZooKeeper ポートに対して次のコマンドを発行できます。
- 4 文字コマンド ruok を実行して、サーバーがエラーなしに稼働しているかどうかを検査します。正常な場合は "imok" が返されます。
echo ruok | nc host 2181
戻り値:
imok
- 4 文字コマンド
stat
を実行して、サーバーのパフォーマンスと接続クライアントの統計情報を一覧表示します。echo stat | nc host 2181
戻り値:
Zookeeper version: 3.4.5-1392090, built on 09/30/2012 17:52 GMT Clients: /0:0:0:0:0:0:0:1:33467[0](queued=0,recved=1,sent=0) /192.168.124.201:42388[1](queued=0,recved=8433,sent=8433) /192.168.124.202:42185[1](queued=0,recved=1339,sent=1347) /192.168.124.204:39296[1](queued=0,recved=7688,sent=7692) Latency min/avg/max: 0/0/128 Received: 26144 Sent: 26160 Connections: 4 Outstanding: 0 Zxid: 0x2000002c2 Mode: follower Node count: 283
- netcat(nc)を使用できない場合は、代わりに python を使用します。次の内容を含む
zookeeper.py
という名前のファイルを作成します。import time, socket, sys c = socket.socket(socket.AF_INET, socket.SOCK_STREAM) c.connect((sys.argv[1], 2181)) c.send(sys.argv[2]) time.sleep(0.1) print c.recv(512)
以下の Python 行を実行します。
python zookeeper.py 192.168.124.201 ruok
python zookeeper.py 192.168.124.201 stat
LDAP レベルのテスト
OpenLDAP をモニタリングして、特定のリクエストが適切に処理されているかどうかを確認できます。つまり、特定の検索によって正しい結果が返されるかどうかを検査します。
ldapsearch
(yum install openldap-clients
)を使用してシステム管理者のエントリを検索します。このエントリは、すべての API 呼び出しの認証に使用されます。ldapsearch -b "uid=admin,ou=users,ou=global,dc=apigee,dc=com" -x -W -D "cn=manager,dc=apigee,dc=com" -H ldap://localhost:10389 -LLL
LDAP 管理者のパスワードを入力するように指示されます。
Enter LDAP Password:
パスワードを入力すると、次のようなレスポンスが表示されます。
dn: uid=admin,ou=users,ou=global,dc=apigee,dc=com objectClass: organizationalPerson objectClass: person objectClass: inetOrgPerson objectClass: top uid: admin cn: admin sn: admin userPassword:: e1NTSEF9bS9xbS9RbVNXSFFtUWVsU1F0c3BGL3BQMkhObFp2eDFKUytmZVE9PQ= = mail: opdk@google.com
- 次のコマンドを実行して、Management Server が引き続き LDAP に接続しているかどうか検査します。
curl -u userEMail:password http://localhost:8080/v1/users/ADMIN
戻り値:
{ "emailId" : ADMIN, "firstName" : "admin", "lastName" : "admin" }
また、OpenLDAP キャッシュをモニタリングすることもできます。キャッシュによりディスク アクセス回数が減少し、システム パフォーマンスの向上につながります。OpenLDAP サーバーのキャッシュをモニタリングしてキャッシュ サイズを調整すると、ディレクトリ サーバーのパフォーマンスが大幅に変化する可能性があります。キャッシュに関する情報は、ログファイル(opt/apigee/var/log
)で確認できます。