Tài liệu này mô tả các kỹ thuật giám sát các thành phần được hỗ trợ bằng cách triển khai Apigee Edge tại chỗ.
Tổng quan
Edge hỗ trợ một số cách để nhận thông tin chi tiết về các dịch vụ cũng như kiểm tra trạng thái của các dịch vụ đó. Bảng sau đây liệt kê các loại quy trình kiểm tra mà bạn có thể thực hiện trên từng dịch vụ đủ điều kiện:
Mgmt API | |||||||
Dịch vụ | Mức sử dụng bộ nhớ [JMX*] | Kiểm tra dịch vụ | Trạng thái triển khai/tổ chức/ người dùng | axstatus | Kiểm tra cơ sở dữ liệu | Trạng thái của apigee-service |
apigee-monit ** |
Máy chủ quản lý | |||||||
Trình xử lý thông báo | |||||||
Postgres | |||||||
Qpid | |||||||
Bộ định tuyến | |||||||
Thông tin khác | Thông tin khác | Thông tin khác | Thông tin khác | Thông tin khác | Thông tin khác | Thông tin khác | |
* Để có thể sử dụng JMX, bạn phải bật JMX, như mô tả trong phần Bật JMX. ** Dịch vụ |
Cổng giám sát JMX và API quản lý
Mỗi thành phần hỗ trợ các lệnh gọi giám sát JMX và API quản lý trên các cổng khác nhau. Bảng sau đây liệt kê các cổng JMX và API Quản lý cho từng loại máy chủ:
Thành phần | Cổng JMX | Cổng API Quản lý |
---|---|---|
Máy chủ quản lý | 1099 | 8080 |
Bộ định tuyến | 1100 | 8081 |
Trình xử lý tin nhắn | 1101 | 8082 |
Qpid | 1102 | 8083 |
Postgres | 1103 | 8084 |
Sử dụng JMX để theo dõi
Các quy trình giám sát cho Máy chủ quản lý, Trình xử lý thông báo, Qpid và Postgres đều sử dụng JMX. Tuy nhiên, theo mặc định, JMX chỉ được bật cho Cassandra và bị tắt theo mặc định đối với tất cả các thành phần Edge khác. Do đó, bạn phải bật JMX riêng lẻ cho từng thành phần thì mới có thể giám sát các thành phần đó.
Tính năng xác thực JMX không được bật theo mặc định. Bạn có thể bật tính năng xác thực JMX cho tất cả thành phần. Đối với Cassandra, hãy làm theo hướng dẫn trong bài viết Bật phương thức xác thực JMX cho Cassandra.
Bật JMX
Theo mặc định, JMX chỉ được bật cho Cassandra và bị tắt theo mặc định đối với tất cả thành phần Edge khác. Phần này mô tả cách bật JMX cho các thành phần Edge khác.
Cách bật JMX:
- Chỉnh sửa tệp cấu hình của thành phần. Tệp này nằm ở
opt/apigee/edge-component_name/bin/start
. Trong môi trường phát hành chính thức, các tệp cấu hình này sẽ nằm trên các máy khác nhau.Chọn trong số các vị trí tệp sau đây trên mỗi máy chủ:
- Máy chủ quản lý:
/opt/apigee/edge-management-server/bin/start
- Trình xử lý tin nhắn:
/opt/apigee/edge-message-processor/bin/start
- Postgres:
/opt/apigee/edge-postgres-server/bin/start
- Qpid:
/opt/apigee/edge-qpid-server/bin/start
- Bộ định tuyến:
/opt/apigee/edge-router/bin/start
Ví dụ: tệp cấu hình của Máy chủ quản lý trên máy chủ của nó nằm tại
/opt/apigee/edge-management-server/bin/start
. - Máy chủ quản lý:
- Thêm các tuỳ chọn
com.sun.management.jmxremote
sau vào dòngexec
bắt đầu thành phần:-Dcom.sun.management.jmxremote \ -Dcom.sun.management.jmxremote.port=port_number \ -Dcom.sun.management.jmxremote.local.only=false \ -Dcom.sun.management.jmxremote.authenticate=false \ -Dcom.sun.management.jmxremote.ssl=false
Trong đó port_number là cổng JMX cho dịch vụ. Để lấy số cổng JMX của dịch vụ, hãy xem phần Cổng giám sát JMX và API quản lý.
Ví dụ: để bật JMX trên Máy chủ quản lý, hãy thêm nội dung sau vào tệp cấu hình của Máy chủ quản lý:
exec $JAVA -classpath "$classpath" -Xms$min_mem -Xmx$max_mem $xx_opts \ -Djava.security.auth.login.config=$conf_path/jaas.config \ -Dinstallation.dir=$install_dir $sys_props -Dconf.dir=$conf_path \ -Ddata.dir=$data_dir \ -Dcom.sun.management.jmxremote \ -Dcom.sun.management.jmxremote.port=1099 \ -Dcom.sun.management.jmxremote.local.only=false \ -Dcom.sun.management.jmxremote.authenticate=false \ -Dcom.sun.management.jmxremote.ssl=false \ $* $debug_options com.apigee.kernel.MicroKernel
Ví dụ này chỉ định cổng 1099 cho Máy chủ quản lý. Như đã đề cập trước đó, mỗi dịch vụ đều có số cổng riêng.
Dòng đã chỉnh sửa trong tệp cấu hình sẽ có dạng như sau:
exec $JAVA -classpath "$classpath" -Xms$min_mem -Xmx$max_mem $xx_opts -Djava.security.auth.login.config=$conf_path/jaas.config -Dinstallation.dir=$install_dir $sys_props -Dconf.dir=$conf_path -Ddata.dir=$data_dir -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=1099 -Dcom.sun.management.jmxremote.local.only=false -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false $* $debug_options com.apigee.kernel.MicroKernel
- Lưu tệp cấu hình.
- Khởi động lại thành phần bằng lệnh
restart
.Ví dụ: để khởi động lại Máy chủ quản lý, hãy thực thi lệnh sau:
/opt/apigee/apigee-service/bin/apigee-service edge-management-server restart
Tính năng xác thực cho JMX không được bật theo mặc định. Bạn có thể bật tính năng xác thực JMX cho tất cả các thành phần, như mô tả trong phần Bật tính năng xác thực JMX. Để bật tính năng xác thực JMX cho Cassandra, hãy xem phần Bật tính năng xác thực JMX cho Cassandra.
Bật tính năng xác thực JMX
Tính năng xác thực JMX không được bật theo mặc định. Bạn có thể bật tính năng xác thực JMX cho tất cả thành phần. Đối với Cassandra, hãy sử dụng hướng dẫn trong phần Bật tính năng xác thực JMX cho Cassandra
Để bật tính năng xác thực JMX, hãy thực thi thao tác change_jmx_auth
sau trên tất cả các nút:
/opt/apigee/apigee-service/bin/apigee-service component_name change_jmx_auth [options|-f config_file]
Trong trường hợp:
- component là một trong những quốc gia sau:
edge-management-server
edge-message-processor
edge-postgres-server
edge-qpid-server
edge-router
- options chỉ định những thông tin sau:
-u username
-p password
-e [y|n]
(bật hoặc tắt)
- config_file chỉ định vị trí của tệp cấu hình mà trong đó bạn xác định những thông tin sau:
JMX_USERNAME=username
JMX_ENABLED=y|n
JMX_PASSWORD=password
(nếu không được đặt hoặc không được truyền bằng-p
, bạn sẽ được nhắc)
Bạn có thể sử dụng các tuỳ chọn dòng lệnh hoặc tệp cấu hình để xác định tên người dùng, mật khẩu và trạng thái bật/tắt. Bạn không chỉ định cả một nhóm tuỳ chọn và một tệp cấu hình.
Ví dụ sau đây bật tính năng xác thực JMX cho Máy chủ quản lý bằng các tuỳ chọn dòng lệnh:
/opt/apigee/apigee-service/bin/apigee-service edge-management-server change_jmx_auth -u foo -p bar -e y
Ví dụ sau sử dụng tệp cấu hình thay vì các tuỳ chọn dòng lệnh:
/opt/apigee/apigee-service/bin/apigee-service edge-management-server change_jmx_auth -f /tmp/my-config-file
Nếu bạn đang chạy Edge trên nhiều nút, hãy chạy lệnh trên tất cả các nút, chỉ định cùng một tên người dùng và mật khẩu.
Để tắt tính năng xác thực JMX trên dòng lệnh, hãy sử dụng tuỳ chọn "-e n", như trong ví dụ sau:
/opt/apigee/apigee-service/bin/apigee-service edge-management-server change_jmx_auth -e n
Giám sát bằng JConsole
Sử dụng JConsole (một công cụ tuân thủ JMX) để quản lý và theo dõi tình trạng kiểm tra và thống kê quy trình. Với JConsole, bạn có thể sử dụng số liệu thống kê JMX do máy chủ hiển thị và hiển thị số liệu thống kê đó trong giao diện đồ hoạ. Để biết thêm thông tin, hãy xem bài viết Sử dụng JConsole.
JConsole sử dụng URL dịch vụ sau đây để theo dõi các thuộc tính JMX (MBean) được cung cấp thông qua JMX:
service:jmx:rmi:///jndi/rmi://IP_address:port_number/jmxrmi
Trong trường hợp:
- IP_address là địa chỉ IP của máy chủ mà bạn muốn theo dõi.
- port_number là số cổng JMX của máy chủ bạn muốn giám sát.
Ví dụ: để theo dõi Máy chủ quản lý, hãy đưa ra lệnh như sau (giả sử địa chỉ IP của máy chủ là 216.3.128.12):
service:jmx:rmi:///jndi/rmi://216.3.128.12:1099/jmxrmi
Xin lưu ý rằng ví dụ này chỉ định cổng 1099, là cổng JMX của Máy chủ quản lý. Đối với các cổng khác, hãy xem phần Cổng giám sát JMX và API Quản lý.
Bảng sau đây cho thấy số liệu thống kê JMX chung:
Câu lạc bộ JMX MBean | Thuộc tính JMX |
---|---|
Bộ nhớ |
HeapMemoryUsage |
NonHeapMemoryUsage |
|
Cách sử dụng |
|
Giám sát bằng API Quản lý
Edge bao gồm một số API mà bạn có thể sử dụng để kiểm tra dịch vụ trên máy chủ cũng như kiểm tra người dùng, tổ chức và các bản triển khai. Phần này mô tả các API này.
Kiểm tra dịch vụ
API Quản lý cung cấp một số điểm cuối để theo dõi và chẩn đoán các vấn đề với dịch vụ của bạn. Các điểm cuối này bao gồm:
Điểm cuối | Mô tả |
---|---|
/servers/self/up |
Kiểm tra xem một dịch vụ có đang chạy hay không. Lệnh gọi API này không yêu cầu bạn xác thực. Nếu dịch vụ đang chạy, điểm cuối này sẽ trả về phản hồi sau: <ServerField> <Up>true</Up> </ServerField> Nếu dịch vụ không chạy, bạn sẽ nhận được phản hồi tương tự như sau (tuỳ thuộc vào dịch vụ và cách bạn kiểm tra dịch vụ đó): curl: Failed connect to localhost:port_number; Connection refused |
/servers/self |
Trả về thông tin về dịch vụ, bao gồm:
Lệnh gọi API này yêu cầu bạn xác thực bằng thông tin đăng nhập của quản trị viên Apigee. |
Để sử dụng các điểm cuối này, hãy gọi một tiện ích như curl
bằng các lệnh sử dụng cú pháp sau:
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]"
Trong trường hợp:
- host là địa chỉ IP của máy chủ mà bạn muốn kiểm tra. Nếu đã đăng nhập vào máy chủ, bạn có thể sử dụng "localhost"; nếu không, hãy chỉ định địa chỉ IP của máy chủ cũng như tên người dùng và mật khẩu.
- port_number là cổng API quản lý cho máy chủ mà bạn muốn kiểm tra. Đây là một cổng khác nhau cho mỗi loại thành phần. Ví dụ: cổng API quản lý của Máy chủ quản lý là 8080. Để biết danh sách số cổng API quản lý cần sử dụng, hãy xem phần Cổng giám sát JMX và API quản lý
Để thay đổi định dạng của phản hồi, bạn có thể chỉ định tiêu đề Accept
là "application/json" hoặc "application/xml".
Ví dụ sau đây sẽ lấy trạng thái của Trình định tuyến trên máy chủ cục bộ (cổng 8081):
curl http://localhost:8081/v1/servers/self/up -H "Accept: application/xml"
Ví dụ sau đây lấy thông tin về Trình xử lý thông báo tại 216.3.128.12 (cổng 8082):
curl http://216.3.128.12:8082/v1/servers/self -u sysAdminEmail:password -H "Accept: application/xml"
Theo dõi trạng thái của người dùng, tổ chức và quá trình triển khai
Bạn có thể sử dụng API Quản lý để giám sát người dùng, tổ chức và trạng thái triển khai của các proxy trên Máy chủ quản lý và Bộ xử lý thông báo bằng cách đưa ra các lệnh sau:
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
Trong đó port_number là 8080 đối với Máy chủ quản lý hoặc 8082 đối với Trình xử lý thông báo.
Lệnh gọi này yêu cầu bạn xác thực bằng tên người dùng và mật khẩu quản trị hệ thống.
Máy chủ sẽ trả về trạng thái "đã triển khai" cho tất cả lệnh gọi. Nếu những bước trên không thành công, hãy làm như sau:
- Hãy kiểm tra nhật ký máy chủ để xem có lỗi nào không. Nhật ký nằm ở:
- Máy chủ quản lý:
opt/apigee/var/log/edge-management-server
- Bộ xử lý thông báo:
opt/apigee/var/log/edge-message-processor
- Máy chủ quản lý:
- Gọi đến máy chủ để kiểm tra xem máy chủ có hoạt động đúng cách hay không.
- Xoá máy chủ khỏi ELB rồi khởi động lại:
/opt/apigee/apigee-service/bin/apigee-service service_name restart
Trong đó service_name là:
edge-management-server
edge-message-processor
Kiểm tra trạng thái bằng lệnh apigee-service
Bạn có thể khắc phục sự cố với các dịch vụ Edge bằng cách sử dụng lệnh apigee-service
khi đăng nhập vào máy chủ đang chạy dịch vụ.
Cách kiểm tra trạng thái của một dịch vụ bằng apigee-service
:
- Đăng nhập vào máy chủ và chạy lệnh sau:
/opt/apigee/apigee-service/bin/apigee-service service_name status
Trong đó, service_name là một trong các giá trị sau:
- Máy chủ quản lý:
edge-management-server
- Trình xử lý tin nhắn:
edge-message-processor
- Postgres:
edge-postgres-server
- Qpid:
edge-qpid-server
- Bộ định tuyến:
edge-router
Ví dụ:
/opt/apigee/apigee-service/bin/apigee-service edge-message-processor status
- Máy chủ quản lý:
- Nếu dịch vụ không chạy, hãy khởi động dịch vụ:
/opt/apigee/apigee-service/bin/apigee-service service_name start
- Sau khi khởi động lại dịch vụ, hãy kiểm tra để đảm bảo dịch vụ đang hoạt động bằng lệnh
apigee-service status
bạn đã dùng trước đó hoặc API Quản lý được mô tả trong phần Giám sát bằng API Quản lý.Ví dụ:
curl -v http://localhost:port_number/v1/servers/self/up
Trong đó, port_number là cổng API quản lý cho dịch vụ.
Ví dụ này giả định bạn đã đăng nhập vào máy chủ và có thể sử dụng "localhost" làm tên máy chủ. Để kiểm tra trạng thái từ xa bằng API Quản lý, bạn phải chỉ định địa chỉ IP của máy chủ và đưa tên người dùng và mật khẩu của quản trị viên hệ thống vào lệnh gọi API.
Giám sát Postgres
Postgres hỗ trợ một số tiện ích mà bạn có thể sử dụng để kiểm tra trạng thái của tiện ích. Những phần mềm tiện ích này được mô tả trong các phần tiếp theo.
Kiểm tra các tổ chức và môi trường trên Postgres
Bạn có thể kiểm tra tên tổ chức và môi trường được đưa vào Máy chủ Postgres bằng cách đưa ra lệnh curl
sau:
curl -v http://postgres_IP:8084/v1/servers/self/organizations
Hệ thống sẽ hiển thị tên tổ chức và môi trường.
Xác minh trạng thái của số liệu phân tích
Bạn có thể xác minh trạng thái của máy chủ phân tích Postgres và Qpid bằng cách đưa ra lệnh curl
sau:
curl -u userEmail:password http://host:port_number/v1/organizations/orgname/environments/envname/provisioning/axstatus
Hệ thống sẽ hiển thị trạng thái thành công cho tất cả máy chủ phân tích, như trong ví dụ sau:
{ "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" }
Cơ sở dữ liệu PostgreSQL
Phần này mô tả các kỹ thuật mà bạn có thể sử dụng riêng để theo dõi cơ sở dữ liệu Postgres.
Sử dụng tập lệnh check_postgres.pl
Để giám sát cơ sở dữ liệu PostgreSQL, bạn có thể sử dụng tập lệnh giám sát chuẩn, check_postgres.pl
. Để biết thêm thông tin, hãy xem http://bucardo.org/wiki/Check_postgres.
Trước khi chạy tập lệnh:
- Bạn phải cài đặt tập lệnh check_postgres.pl trên mỗi nút Postgres.
- Đảm bảo bạn đã cài đặt
perl-Time-HiRes.x86_64
, một mô-đun Perl triển khai chuông báo, ngủ, gettimeofday và bộ hẹn giờ khoảng thời gian có độ phân giải cao. Ví dụ: bạn có thể cài đặt gói này bằng cách sử dụng lệnh sau:
yum install perl-Time-HiRes.x86_64
- CentOS 7: Trước khi sử dụng check_postgres.pl trên CentOS v7, hãy cài đặt RPM
perl-Data-Dumper.x86_64
.
Kết quả của check_postgres.pl
Đầu ra mặc định của các lệnh gọi API sử dụng check_postgres.pl
là tương thích với Nagios. Sau khi bạn cài đặt tập lệnh, hãy kiểm tra những điều sau:
- Kiểm tra kích thước cơ sở dữ liệu:
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'
- Kiểm tra số lượng kết nối đến cơ sở dữ liệu và so sánh với số lượng kết nối tối đa được phép:
check_postgres.pl -H 10.176.218.202 -db apigee -u apigee -dbpass postgres -action backends
- Kiểm tra xem cơ sở dữ liệu có đang chạy và có sẵn hay không:
check_postgres.pl -H 10.176.218.202 -db apigee -u apigee -dbpass postgres -action connection
- Kiểm tra dung lượng ổ đĩa:
check_postgres.pl -H 10.176.218.202 -db apigee -u apigee -dbpass postgres -action disk_space --warning='80%' --critical='90%'
- Kiểm tra số lượng tổ chức và môi trường được đưa vào trong một nút 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
Chạy quy trình kiểm tra cơ sở dữ liệu
Bạn có thể xác minh rằng các bảng thích hợp đã được tạo trong cơ sở dữ liệu PostgreSQL. Đăng nhập vào cơ sở dữ liệu PostgreSQL bằng lệnh sau:
psql -h /opt/apigee/var/run/apigee-postgresql/ -U apigee -d apigee
Sau đó chạy:
\d analytics."org.env.fact"
Kiểm tra tình trạng của quy trình Postgres
Bạn có thể kiểm tra API trên máy Postgres bằng cách gọi lệnh curl
sau:
curl -v http://postgres_IP:8084/v1/servers/self/health
Lệnh này trả về trạng thái ACTIVE
khi quy trình postgres đang hoạt động. Nếu quy trình Postgres không khởi động và chạy, quy trình này sẽ trả về trạng thái INACTIVE
.
Tài nguyên Postgres
Để biết thêm thông tin về cách giám sát dịch vụ Postgres, hãy xem những nội dung sau:
- 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
JMX được bật theo mặc định cho Cassandra và quyền truy cập từ xa của JMX vào Cassandra mà không yêu cầu mật khẩu.
Bật tính năng xác thực JMX cho Cassandra
Bạn có thể bật tính năng xác thực JMX cho Cassandra. Sau đó, bạn sẽ được yêu cầu truyền tên người dùng và mật khẩu cho tất cả lệnh gọi đến tiện ích nodetool.
Cách bật tính năng xác thực JMX cho Cassandra:
- Tạo và chỉnh sửa tệp
cassandra.properties
:- Chỉnh sửa tệp
/opt/apigee/customer/application/cassandra.properties
. Nếu tệp chưa tồn tại, hãy tạo tệp đó. - Thêm phần sau vào tệp:
conf_cassandra-env_com.sun.management.jmxremote.authenticate=true conf_cassandra-env_com.sun.management.jmxremote.password.file=${APIGEE_ROOT}/data/apigee-cassandra/jmxremote.password conf_cassandra-env_com.sun.management.jmxremote.access.file=${APIGEE_ROOT}/data/apigee-cassandra/jmxremote.access
- Lưu tệp
cassandra.properties
. - Thay đổi chủ sở hữu của tệp thành
apigee:apigee
, như trong ví dụ sau:chown apigee:apigee /opt/apigee/customer/application/cassandra.properties
Để biết thêm thông tin về cách sử dụng tệp thuộc tính để đặt mã thông báo, hãy xem phần Cách định cấu hình Edge.
- Chỉnh sửa tệp
- Tạo và chỉnh sửa
jmx_auth.sh
:- Tạo tệp ở vị trí sau nếu tệp không tồn tại:
/opt/apigee/customer/application/jmx_auth.sh
- Thêm các thuộc tính sau vào tệp:
export CASS_JMX_USERNAME=JMX_USERNAME export CASS_JMX_PASSWORD=JMX_PASSWORD
- Lưu tệp
jmx_auth.sh
. - Tệp nguồn:
source /opt/apigee/customer/application/jmx_auth.sh
- Tạo tệp ở vị trí sau nếu tệp không tồn tại:
- Sao chép và chỉnh sửa tệp
jmxremote.password
:- Sao chép tệp sau từ thư mục
$JAVA_HOME
vào/opt/apigee/data/apigee-cassandra/
:cp ${JAVA_HOME}/lib/management/jmxremote.password.template $APIGEE_ROOT/data/apigee-cassandra/jmxremote.password
- Chỉnh sửa tệp
jmxremote.password
và thêm tên người dùng và mật khẩu JMX bằng cú pháp sau:JMX_USERNAME JMX_PASSWORD
Trong đó JMX_USERNAME và JMX_PASSWORD là tên người dùng và mật khẩu JMX mà bạn đã đặt trước đó.
- Đảm bảo tệp thuộc sở hữu của "apigee" và chế độ tệp là 400:
chown apigee:apigee /opt/apigee/data/apigee-cassandra/jmxremote.password
chmod 400 /opt/apigee/data/apigee-cassandra/jmxremote.password
- Sao chép tệp sau từ thư mục
- Sao chép và chỉnh sửa tệp
jmxremote.access
:- Sao chép tệp sau từ thư mục
$JAVA_HOME
vào/opt/apigee/data/apigee-cassandra/
:cp ${JAVA_HOME}/lib/management/jmxremote.access $APIGEE_ROOT/data/apigee-cassandra/jmxremote.access
- Chỉnh sửa tệp jmxremote.access và thêm vai trò sau:
JMX_USERNAME readwrite
- Đảm bảo tệp thuộc sở hữu của "apigee" và chế độ tệp là 400:
chown apigee:apigee /opt/apigee/data/apigee-cassandra/jmxremote.access
chmod 400 /opt/apigee/data/apigee-cassandra/jmxremote.access
- Sao chép tệp sau từ thư mục
- Chạy
configure
trên Cassandra:/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra configure
- Khởi động lại Cassandra:
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra restart
- Lặp lại quy trình này trên tất cả các nút Cassandra khác.
Bật tính năng mã hoá mật khẩu JMX
Để bật tính năng mã hoá mật khẩu JMX, hãy làm theo các bước sau:
- Mở tệp
source/conf/casssandra-env.sh
. - Bỏ ghi chú các dòng sau trong tệp:
-
JVM_OPTS="$JVM_OPTS -Djava.security.auth.login.config={T}conf_cassandra-env_java.security.auth.login.config{/T}"
JVM_OPTS="$JVM_OPTS -Dcom.sun.management.jmxremote.login.config=ApigeeSecureFileLoginModule"
-
- Trên dòng lệnh, hãy tạo(các) hàm băm SHA1 của(các) mật khẩu mong muốn bằng cách nhập
echo -n 'Secret' | openssl dgst -sha1
- Đặt(các) mật khẩu trùng với tên người dùng trong
jmxremote.password
. - Thay đổi lại tệp
cassandra-env.sh
để chỉ đọc sau khi cập nhật.
Bật JMX bằng SSL cho Cassandra
Việc bật JMX bằng SSL sẽ tăng cường bảo mật và mã hoá cho hoạt động giao tiếp dựa trên JMX với Cassandra. Để bật JMX bằng SSL, bạn cần cung cấp khoá và chứng chỉ cho Cassandra để chấp nhận các kết nối JMX dựa trên SSL. Bạn cũng cần định cấu hình nodetool (và mọi công cụ khác giao tiếp với Cassandra qua JMX) cho SSL.
JMX hỗ trợ SSL hỗ trợ cả mật khẩu JMX ở dạng văn bản thô và mật khẩu JMX đã mã hoá.
Để bật JMX bằng SSL cho Cassandra, hãy sử dụng quy trình sau:
- Bật JMX. Bật tính năng mã hoá mật khẩu nếu cần.
- Bật tính năng xác thực JMX cho Cassandra.
như mô tả ở trên. Đảm bảo nodetool đang hoạt động với tên người dùng và mật khẩu đã định cấu hình.
/opt/apigee/apigee-cassandra/bin/nodetool -u <JMX_USER> -pw <JMX_PASS> ring
Chuẩn bị kho khoá và Truststore.
Kho khoá phải chứa một khoá và chứng chỉ, đồng thời được dùng để định cấu hình máy chủ Cassandra. Nếu kho khoá chứa nhiều cặp khoá, Cassandra sẽ sử dụng cặp khoá đầu tiên để bật SSL.
Lưu ý rằng mật khẩu cho kho khoá và khoá phải giống nhau (mật khẩu mặc định khi bạn tạo khoá bằng keytool).
- Truststore chỉ chứa chứng chỉ và được các ứng dụng (lệnh dựa trên dịch vụ apigee hoặc nodetool) sử dụng để kết nối qua JMX.
Sau khi xác minh các yêu cầu nêu trên:
- Đặt tệp kho khoá vào
/opt/apigee/data/apigee-cassandra
. - Đảm bảo chỉ người dùng Apigee mới có thể đọc tệp kho khoá bằng cách nhập
chown apigee:apigee /opt/apigee/data/apigee-cassandra/keystore.node1 chmod 400 /opt/apigee/data/apigee-cassandra/keystore.node1
- Định cấu hình Cassandra cho JMX bằng SSL bằng cách làm theo các bước sau:
- Dừng nút Cassandra bằng cách nhập
apigee-service apigee-cassandra stop
- Bật SSL trong Cassandra bằng cách mở tệp
/opt/apigee/customer/application/cassandra.properties
và thêm dòng sau:conf_cassandra-env_com.sun.management.jmxremote.ssl=true
Tệp phải thuộc sở hữu của
apigee:apigee
. - Bật cấu hình liên quan đến SSL trong Cassandra như sau.
Mở tệp
/opt/apigee/apigee-cassandra/source/conf/cassandra-env.sh
và huỷ nhận xét các dòng sau, thay đổi đường dẫn/opt/apigee/data/apigee-cassandra/keystore.node1
và mật khẩu kho khoá nếu cần.JVM_OPTS="$JVM_OPTS -Djavax.net.ssl.keyStore=/opt/apigee/data/apigee-cassandra/keystore.node1" JVM_OPTS="$JVM_OPTS -Djavax.net.ssl.keyStorePassword=keystore-password" JVM_OPTS="$JVM_OPTS -Dcom.sun.management.jmxremote.registry.ssl=true"
Đảm bảo rằngapigee:apigee
sở hữu tệp. - Bắt đầu nút Cassandra bằng cách nhập
apigee-service apigee-cassandra start
- Dừng nút Cassandra bằng cách nhập
- Định cấu hình các lệnh Cassandra
apigee-service
. Bạn cần thiết lập một số biến môi trường nhất định trong khi chạy các lệnhapigee-service
, bao gồm cả các biến dưới đây:apigee-service apigee-cassandra stop apigee-service apigee-cassandra wait_for_ready apigee-service apigee-cassandra ring apigee-service apigee-cassandra backup
Có một số tuỳ chọn để định cấu hình
apigee-service
cho việc xác thực JMX và SSL. Hãy chọn một phương thức dựa trên khả năng hữu dụng và các biện pháp bảo mật bạn dùng.- Tuỳ chọn 1 (Đối số SSL được lưu trữ trong tệp)
- Cách 2 (Đối số SSL được lưu trữ trong biến môi trường)
- Lựa chọn 3 (đối số SSL được truyền trực tiếp đến
apigee-service
)
Tuỳ chọn 1 (Đối số SSL được lưu trữ trong tệp)
Thiết lập các biến môi trường sau:
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
Tạo một tệp trong thư mục gốc của người dùng Apigee (
/opt/apigee
).$HOME/.cassandra/nodetool-ssl.properties
Chỉnh sửa tệp và thêm các dòng sau:
-Djavax.net.ssl.trustStore=<path-to-truststore.node1> -Djavax.net.ssl.trustStorePassword=<truststore-password> -Dcom.sun.management.jmxremote.registry.ssl=true
Đảm bảo người dùng Apigee có thể đọc tệp trustore.
Chạy lệnh
apigee-service
sau. Nếu ứng dụng chạy mà không có lỗi, thì cấu hình của bạn là chính xác.apigee-service apigee-cassandra ring
Cách 2 (Các đối số SSL được lưu trữ trong biến môi trường)
Thiết lập các biến môi trường sau:
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=<path-to-trustore.node1> export CASS_JMX_TRUSTSTORE_PASSWORD=<truststore-password>
Chạy lệnh
apigee-service
sau. Nếu ứng dụng chạy mà không có lỗi, thì cấu hình của bạn là chính xác.apigee-service apigee-cassandra ring
Tuỳ chọn 3 (các đối số SSL được truyền trực tiếp đến
apigee-service
)Chạy lệnh
apigee-service
bất kỳ như lệnh bên dưới. Bạn không cần định cấu hình bất kỳ biến môi trường nào.CASS_JMX_USERNAME=ADMIN CASS_JMX_PASSWORD=PASSWORD CASS_JMX_SSL=Y CASS_JMX_TRUSTSTORE=<path-to-trustore.node1> CASS_JMX_TRUSTSTORE_PASSWORD=<trustore-password> /opt/apigee/apigee-service/bin/apigee-service apigee-cassandra ring
Thiết lập nodetool. Nodetool yêu cầu truyền các tham số JMX đến nó. Bạn có thể định cấu hìnhnodetool để chạy với JMX hỗ trợ SSL theo 2 cách như mô tả trong các tuỳ chọn cấu hình bên dưới:
Các tuỳ chọn khác nhau ở cách cấu hình liên quan đến SSL được truyền đến nodetool. Trong cả hai trường hợp, người dùng chạy nodetool phải có quyền ĐỌC trên tệp kho tin cậy. Chọn một tuỳ chọn phù hợp dựa trên khả năng hữu dụng và các phương pháp bảo mật của bạn.
Để tìm hiểu thêm về các tham số nodetool, hãy xem tài liệu về DataStax.
Tuỳ chọn cấu hình 1
Tạo một tệp trong thư mục gốc của người dùng đang chạy nodetool.
$HOME/.cassandra/nodetool-ssl.properties
Thêm các dòng sau vào tệp:
-Djavax.net.ssl.trustStore=<path-to-truststore.node1> -Djavax.net.ssl.trustStorePassword=<truststore-password> -Dcom.sun.management.jmxremote.registry.ssl=true
Mọi người dùng chạy nodetool đều có thể truy cập vào đường dẫn kho tin cậy được chỉ định ở trên.
Chạy
nodetool
bằng tuỳ chọn--ssl
./opt/apigee/apigee-cassandra/bin/nodetool --ssl -u <jmx-user-name> -pw <jmx-user-password> -h localhost ring
Tuỳ chọn cấu hình 2
Chạy
nodetool
dưới dạng một lệnh duy nhất với các tham số bổ sung được liệt kê bên dưới./opt/apigee/apigee-cassandra/bin/nodetool -Djavax.net.ssl.trustStore=<path-to-truststore.node1> -Djavax.net.ssl.trustStorePassword=<truststore-password> -Dcom.sun.management.jmxremote.registry.ssl=true -Dssl.enable=true -u <jmx-user-name> -pw <jmx-user-password> -h localhost ring
Huỷ bỏ cấu hình SSL
Nếu bạn cần huỷ bỏ các cấu hình SSL được mô tả trong quy trình ở trên, hãy làm theo các bước sau:
- Dừng
apigee-cassandra
bằng cách nhậpapigee-service apigee-cassandra stop
- Xoá dòng
conf_cassandra-env_com.sun.management.jmxremote.ssl=true
khỏi tệp/opt/apigee/customer/application/cassandra.properties
. - Chú thích các dòng sau trong
/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”
- Bắt đầu
apigee-cassandra
bằng cách nhập - Xoá biến môi trường
CASS_JMX_SSL
nếu bạn đã đặt biến này.unset CASS_JMX_SSL
- Kiểm tra để đảm bảo các lệnh dựa trên
apigee-service
nhưring
,stop
,backup
, v.v. đang hoạt động. - Ngừng sử dụng nút chuyển
--ssl
bằng nodetool
apigee-service apigee-cassandra start
Tắt tính năng xác thực JMX cho Cassandra
Cách tắt tính năng xác thực JMX cho Cassandra:
- Chỉnh sửa
/opt/apigee/customer/application/cassandra.properties
. - Xoá dòng sau trong tệp:
conf_cassandra-env_com.sun.management.jmxremote.authenticate=true
- Chạy cấu hình trên Cassandra:
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra configure
- Khởi động lại Cassandra:
/opt/apigee/apigee-service/bin/apigee-service apigee-cassandra restart
- Lặp lại quy trình này trên tất cả các nút Cassandra khác.
Sử dụng JConsole: Theo dõi số liệu thống kê về tác vụ
Sử dụng JConsole và URL dịch vụ sau đây để giám sát các thuộc tính JMX (MBean) được cung cấp thông qua JMX:
service:jmx:rmi:///jndi/rmi://IP_address:7199/jmxrmi
Trong đó, IP_address là địa chỉ IP của máy chủ Cassandra.
Số liệu thống kê của Cassandra JMX
MBean JMX | Thuộc tính JMX |
---|---|
Cột Gia đình/ứng dụng/môi trường Cột Gia đình/ứng dụng/tổ chức ColumnFamilies/apprepo/apiproxy_revisions ColumnFamilies/apprepo/apiproxies Cột Gia đình/kiểm tra/kiểm tra ColumnFamilies/audit/audits_ref |
PendingTasks |
MemtableColumnsCount |
|
MemtableDataSize |
|
ReadCount |
|
RecentReadLatencyMicros |
|
TotalReadLatencyMicros |
|
WriteCount |
|
RecentWriteLatencyMicros |
|
TotalWriteLatencyMicros |
|
TotalDiskSpaceUsed |
|
LiveDiskSpaceUsed |
|
LiveSSTableCount |
|
BloomFilterFalsePositives |
|
RecentBloomFilterFalseRatio |
|
BloomFilterFalseRatio |
Sử dụng nodetool để quản lý các nút cụm
Tiện ích nodetool là một giao diện dòng lệnh cho Cassandra giúp quản lý các nút cụm. Bạn có thể tìm thấy tiện ích này tại /opt/apigee/apigee-cassandra/bin
.
Bạn có thể thực hiện các lệnh gọi sau trên tất cả các nút cụm Cassandra:
- Thông tin chung về vòng quay (cũng có thể áp dụng cho một nút Cassandra): Tìm trạng thái "Up" (Đang hoạt động) và "Normal" (Bình thường) cho tất cả các nút.
nodetool [-u username -pw password] -h localhost ring
Bạn chỉ cần truyền tên người dùng và mật khẩu nếu bạn đã bật tính năng xác thực JMX cho Cassandra.
Kết quả của lệnh trên có dạng như sau:
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
- Thông tin chung về các nút (lệnh gọi trên mỗi nút)
nodetool [-u username -pw password] -h localhost info
Kết quả của lệnh trên sẽ có dạng như sau:
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
- Trạng thái của máy chủ tiết kiệm (phân phát API ứng dụng)
nodetool [-u username -pw password] -h localhost statusthrift
Kết quả của lệnh trên sẽ có dạng như sau:
running
- Trạng thái của các hoạt động truyền trực tuyến dữ liệu: Quan sát lưu lượng truy cập cho các nút cassandra:
nodetool [-u username -pw password] -h localhost netstats
Kết quả của lệnh trên sẽ có dạng như sau:
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
Để biết thêm thông tin vềnodetool, hãy xem phần Giới thiệu về tiện íchnodetool.
Tài nguyên Cassandra
Hãy tham khảo URL sau: http://www.datastax.com/docs/1.0/operations/monitoring.
Apache ZooKeeper
Kiểm tra trạng thái ZooKeeper
- Đảm bảo quy trình ZooKeeper đang chạy. ZooKeeper sẽ ghi tệp PID vào
opt/apigee/var/run/apigee-zookeeper/apigee-zookeeper.pid
. - Kiểm thử các cổng ZooKeeper để đảm bảo rằng bạn có thể thiết lập kết nối TCP với các cổng 2181 và 3888 trên mọi máy chủ ZooKeeper.
- Đảm bảo rằng bạn có thể đọc các giá trị từ cơ sở dữ liệu ZooKeeper. Kết nối bằng thư viện ứng dụng ZooKeeper (hoặc
/opt/apigee/apigee-zookeeper/bin/zkCli.sh
) và đọc một giá trị từ cơ sở dữ liệu. - Kiểm tra trạng thái:
/opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper status
Sử dụng các từ gồm 4 chữ cái trong ZooKeeper
Bạn có thể theo dõi ZooKeeper thông qua một nhóm nhỏ các lệnh (từ gồm 4 chữ cái) được gửi đến cổng 2181 bằng netcat (nc) hoặc telnet.
Để biết thêm thông tin về các lệnh ZooKeeper, hãy xem: Tài liệu tham khảo về lệnh Apache ZooKeeper.
Ví dụ:
srvr
: Liệt kê toàn bộ thông tin chi tiết về máy chủ.stat
: Liệt kê thông tin chi tiết ngắn gọn về máy chủ và ứng dụng khách đã kết nối.
Bạn có thể đưa ra các lệnh sau cho cổng ZooKeeper:
- Chạy lệnh ruok gồm 4 chữ cái để kiểm tra xem máy chủ có đang chạy ở trạng thái không có lỗi hay không. Phản hồi thành công sẽ trả về "imok".
echo ruok | nc host 2181
Trả về:
imok
- Chạy lệnh gồm bốn chữ cái,
stat
, để liệt kê hiệu suất của máy chủ và số liệu thống kê về các ứng dụng được kết nối:echo stat | nc host 2181
Trả về:
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
- Nếu không có netcat (nc), bạn có thể sử dụng python để thay thế. Tạo một tệp có tên là
zookeeper.py
chứa nội dung sau: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)
Bây giờ, hãy chạy các dòng python sau:
python zookeeper.py 192.168.124.201 ruok
python zookeeper.py 192.168.124.201 stat
Kiểm thử cấp độ LDAP
Bạn có thể theo dõi OpenLDAP để xem liệu các yêu cầu cụ thể có được phân phát đúng cách hay không. Nói cách khác, hãy kiểm tra một cụm từ tìm kiếm cụ thể trả về kết quả chính xác.
- Sử dụng
ldapsearch
(yum install openldap-clients
) để truy vấn mục nhập của quản trị viên hệ thống. Mục này dùng để xác thực tất cả các lệnh gọi 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
Sau đó, bạn được nhắc nhập mật khẩu quản trị viên LDAP:
Enter LDAP Password:
Sau khi nhập mật khẩu, bạn sẽ thấy một phản hồi trong biểu mẫu:
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
- Kiểm tra xem Máy chủ quản lý có còn kết nối với LDAP hay không bằng lệnh sau:
curl -u userEMail:password http://localhost:8080/v1/users/ADMIN
Trả về:
{ "emailId" : ADMIN, "firstName" : "admin", "lastName" : "admin" }
Bạn cũng có thể theo dõi bộ nhớ đệm OpenLDAP, nhờ đó giúp giảm số lượng lượt truy cập vào ổ đĩa, từ đó cải thiện hiệu suất của hệ thống. Việc theo dõi rồi điều chỉnh kích thước bộ nhớ đệm trong máy chủ OpenLDAP có thể ảnh hưởng nặng nề đến hiệu suất của máy chủ thư mục. Bạn có thể xem các tệp nhật ký (opt/apigee/var/log
) để lấy thông tin về bộ nhớ đệm.