Để định cấu hình Edge sau khi cài đặt, bạn sử dụng kết hợp các tệp .properties
và tiện ích Edge. Ví dụ: để định cấu hình TLS/SSL trên giao diện người dùng Edge, bạn chỉnh sửa các tệp .properties
để đặt các thuộc tính cần thiết. Bạn cần khởi động lại thành phần Edge bị ảnh hưởng khi thay đổi các tệp .properties
.
Apigee gọi kỹ thuật chỉnh sửa tệp .properties
là mã có cấu hình (đôi khi viết tắt là CwC). Về cơ bản, mã có cấu hình là một công cụ tra cứu khoá/giá trị dựa trên các chế độ cài đặt trong tệp .properties
. Trong mã có cấu hình, các khoá được gọi là mã thông báo. Do đó, để định cấu hình Edge, bạn cần đặt mã thông báo trong tệp .properties
.
Mã có cấu hình cho phép các thành phần Edge đặt các giá trị mặc định được vận chuyển cùng với sản phẩm, cho phép nhóm cài đặt ghi đè các chế độ cài đặt đó dựa trên cấu hình cài đặt, sau đó cho phép khách hàng ghi đè bất kỳ thuộc tính nào mà họ chọn.
Nếu bạn coi đây là một hệ phân cấp, thì chế độ cài đặt được sắp xếp như sau, trong đó chế độ cài đặt của khách hàng có mức độ ưu tiên cao nhất để thay thế mọi chế độ cài đặt của nhóm cài đặt hoặc Apigee:
- Khách hàng
- Trình cài đặt
- Thành phần
Xác định giá trị hiện tại của mã thông báo
Trước khi đặt giá trị mới cho mã thông báo trong tệp .properties
, trước tiên, bạn nên xác định giá trị hiện tại của mã thông báo đó bằng cách sử dụng lệnh sau:
/opt/apigee/apigee-service/bin/apigee-service component_name configure -search token
Trong đó component_name là tên của thành phần và token là mã thông báo cần kiểm tra.
Lệnh này tìm kiếm hệ phân cấp của các tệp .properties
của thành phần để xác định giá trị hiện tại của mã thông báo.
Ví dụ sau đây sẽ kiểm tra giá trị hiện tại của mã thông báo conf_http_HTTPRequest.line.limit
cho Bộ định tuyến:
/opt/apigee/apigee-service/bin/apigee-service edge-router configure -search conf_http_HTTPRequest.line.limit
Bạn sẽ thấy kết quả như sau:
Found key conf_http_HTTPRequest.line.limit, with value, 4k, in /opt/apigee/edge-router/token/default.properties
Nếu giá trị của mã thông báo bắt đầu bằng #
, thì mã thông báo đó đã bị ghi chú và bạn phải sử dụng cú pháp đặc biệt để thay đổi mã thông báo đó. Để biết thêm thông tin, hãy xem phần Đặt mã thông báo hiện đang bị ghi chú.
Nếu bạn không biết toàn bộ tên của mã thông báo, hãy sử dụng một công cụ như grep
để tìm kiếm theo tên thuộc tính hoặc từ khoá. Để biết thêm thông tin, hãy xem phần Tìm mã thông báo.
Tệp thuộc tính
Có các tệp cấu hình thành phần có thể chỉnh sửa và không thể chỉnh sửa. Phần này mô tả các tệp này.
Tệp cấu hình thành phần có thể chỉnh sửa
Bảng sau đây liệt kê các thành phần Apigee và tệp thuộc tính mà bạn có thể chỉnh sửa để định cấu hình các thành phần đó:
Thành phần | Tên thành phần | Tệp cấu hình có thể chỉnh sửa |
---|---|---|
Cassandra | apigee-cassandra |
/opt/apigee/customer/application/cassandra.properties |
Apigee SSO | apigee-sso |
/opt/apigee/customer/application/sso.properties |
Máy chủ quản lý | edge-management-server |
/opt/apigee/customer/application/management-server.properties |
Trình xử lý tin nhắn | edge-message-processor |
/opt/apigee/customer/application/message-processor.properties |
apigee-monit |
apigee-monit |
/opt/apigee/customer/application/monit.properties |
Giao diện người dùng cổ điển (không ảnh hưởng đến giao diện người dùng Edge mới) | edge-ui |
/opt/apigee/customer/application/ui.properties |
Giao diện người dùng Edge (chỉ giao diện người dùng Edge mới; không ảnh hưởng đến Giao diện người dùng cổ điển) | apigee-management-ui |
không có (sử dụng tệp cấu hình cài đặt) |
OpenLDAP | apigee-openldap |
/opt/apigee/customer/application/openldap.properties |
Máy chủ Postgres | edge-postgres-server |
/opt/apigee/customer/application/postgres-server.properties |
Cơ sở dữ liệu PostgreSQL | apigee-postgresql |
/opt/apigee/customer/application/postgresql.properties |
Máy chủ Qpid | edge-qpid-server |
/opt/apigee/customer/application/qpid-server.properties |
Qpidd | apigee-qpidd |
/opt/apigee/customer/application/qpidd.properties |
Bộ định tuyến | edge-router |
/opt/apigee/customer/application/router.properties |
Người giữ vườn thú | apigee-zookeeper |
/opt/apigee/customer/application/zookeeper.properties |
Nếu muốn đặt thuộc tính vào một trong các tệp cấu hình thành phần này nhưng thuộc tính đó không tồn tại, thì bạn có thể tạo thuộc tính ở vị trí nêu trên.
Ngoài ra, bạn phải đảm bảo rằng tệp thuộc tính thuộc sở hữu của người dùng "apigee":
chown apigee:apigee /opt/apigee/customer/application/configuration_file.properties
Tệp cấu hình thành phần không thể chỉnh sửa
Ngoài các tệp cấu hình thành phần có thể chỉnh sửa, còn có các tệp cấu hình mà bạn không thể chỉnh sửa.
Tệp thông tin (không thể chỉnh sửa) bao gồm:
Chủ sở hữu | Tên tệp hoặc Thư mục |
---|---|
Cài đặt | /opt/apigee/token |
Thành phần | /opt/apigee/component_name/conf Trong đó, component_name xác định thành phần. Các giá trị có thể là:
|
Đặt giá trị mã thông báo
Bạn chỉ có thể sửa đổi các tệp .properties
trong thư mục /opt/apigee/customer/application
. Mỗi thành phần có một tệp .properties
riêng trong thư mục đó. Ví dụ: router.properties
và management-server.properties
. Để xem danh sách đầy đủ các tệp thuộc tính, hãy xem phần Vị trí của tệp .properties.
Cách tạo tệp .properties
:
- Tạo một tệp văn bản mới trong trình chỉnh sửa. Tên tệp phải khớp với danh sách hiển thị trong bảng ở trên đối với tệp khách hàng.
- 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/router.properties
Nếu bạn đã thay đổi người dùng chạy dịch vụ Edge từ người dùng "apigee", hãy sử dụng
chown
để thay đổi quyền sở hữu thành người dùng đang chạy dịch vụ Edge.
Khi bạn nâng cấp Edge, các tệp .properties
trong thư mục /opt/apigee/customer/application
sẽ được đọc. Điều đó có nghĩa là quá trình nâng cấp sẽ giữ lại mọi thuộc tính mà bạn đặt trên thành phần.
Cách đặt giá trị của mã thông báo:
- Chỉnh sửa tệp
.properties
của thành phần. - Thêm hoặc thay đổi giá trị của mã thông báo. Ví dụ sau đây đặt giá trị của thuộc tính
conf_http_HTTPRequest.line.limit
thành "10k":conf_http_HTTPRequest.line.limit=10k
Nếu mã thông báo nhận nhiều giá trị, hãy phân tách từng giá trị bằng dấu phẩy, như trong ví dụ sau:
conf_security_rbac.restricted.resources=/environments,/environments/*,/environments/*/virtualhosts,/environments/*/virtualhosts/*,/pods,/environments/*/servers,/rebuildindex,/users/*/status,/myuri/*
Để thêm một giá trị mới vào danh sách như thế này, bạn thường nối giá trị mới vào cuối danh sách.
- Khởi động lại thành phần:
/opt/apigee/apigee-service/bin/apigee-service component_name restart
Trong đó, component_name là một trong các giá trị sau:
apigee-cassandra
(Cassandra)apigee-openldap
(OpenLDAP)apigee-postgresql
(Cơ sở dữ liệu PostgreSQL)apigee-qpidd
(Qpidd)apigee-sso
(Edge SSO)apigee-zookeeper
(ZooKeeper)edge-management-server
(Máy chủ quản lý)edge-management-ui
(Giao diện người dùng Edge mới)edge-message-processor
(Bộ xử lý thông báo)edge-postgres-server
(Máy chủ Postgres)edge-qpid-server
(Máy chủ Qid)edge-router
(Bộ định tuyến Edge)edge-ui
(Giao diện người dùng cổ điển)
Ví dụ: sau khi chỉnh sửa
router.properties
, hãy khởi động lại Bộ định tuyến:/opt/apigee/apigee-service/bin/apigee-service edge-router restart
- (Không bắt buộc) Kiểm tra để đảm bảo giá trị mã thông báo được đặt thành giá trị mới bằng cách sử dụng tuỳ chọn
configure -search
. Ví dụ:/opt/apigee/apigee-service/bin/apigee-service edge-router configure -search conf_http_HTTPRequest.line.limit
Để biết thêm thông tin về
configure -search
, hãy xem phần Xác định giá trị hiện tại của mã thông báo.
Tìm mã thông báo
Trong hầu hết các trường hợp, mã thông báo bạn cần đặt đều được xác định trong hướng dẫn này. Tuy nhiên, nếu bạn cần ghi đè giá trị của một mã thông báo hiện có mà bạn không chắc chắn về tên đầy đủ hoặc vị trí, hãy sử dụng grep
để tìm kiếm thư mục source
của thành phần.
Ví dụ: nếu bạn biết rằng trong một bản phát hành Edge trước đó, bạn đã đặt thuộc tính session.maxAge
và muốn biết giá trị mã thông báo dùng để đặt thuộc tính đó, thì grep
cho thuộc tính trong thư mục /opt/apigee/edge-ui/source
:
grep -ri "session.maxAge" /opt/apigee/edge-ui/source
Bạn sẽ thấy kết quả trong biểu mẫu sau:
/opt/apigee/component_name/source/conf/application.conf:property_name={T}token_name{/T}
Ví dụ sau đây cho thấy giá trị của mã thông báo session.maxAge
của giao diện người dùng:
/opt/apigee/edge-ui/source/conf/application.conf:session.maxAge={T}conf_application_session.maxage{/T}
Chuỗi giữa các thẻ {T}{/T} là tên của mã thông báo mà bạn có thể đặt trong tệp .properties
của giao diện người dùng.
Đặt một mã thông báo đang được nhận xét
Một số mã thông báo được chú thích trong tệp cấu hình Edge. Nếu bạn cố đặt một mã thông báo được nhận xét trong tệp cấu hình cài đặt hoặc thành phần, thì chế độ cài đặt của bạn sẽ bị bỏ qua.
Để đặt giá trị của một mã thông báo được chú thích trong tệp cấu hình Edge, hãy sử dụng cú pháp đặc biệt ở dạng sau:
conf/filename+propertyName=propertyValue
Ví dụ: để đặt thuộc tính có tên HTTPClient.proxy.host
trên Trình xử lý thông báo, trước tiên hãy grep
để thuộc tính đó xác định mã thông báo của thuộc tính đó:
grep -ri /opt/apigee/edge-message-processor/ -e "HTTPClient.proxy.host"
Lệnh grep
trả về kết quả bao gồm tên mã thông báo. Hãy lưu ý cách nhận xét tên thuộc tính, như được biểu thị bằng tiền tố #:
source/conf/http.properties:#HTTPClient.proxy.host={T}conf_http_HTTPClient.proxy.host{/T} token/default.properties:conf_http_HTTPClient.proxy.host= conf/http.properties:#HTTPClient.proxy.host=
Để đặt giá trị của thuộc tính này, hãy chỉnh sửa /opt/apigee/customer/application/message-processor.properties
, nhưng sử dụng cú pháp đặc biệt như trong ví dụ sau:
conf/http.properties+HTTPClient.proxy.host=myhost.name.com
Trong trường hợp này, bạn phải thêm tiền tố conf/http.properties+
vào tên thuộc tính. Đây là vị trí và tên của tệp cấu hình chứa thuộc tính, theo sau là "+".
Sau khi khởi động lại Trình xử lý thư, hãy kiểm tra tệp /opt/apigee/edge-message-processor/conf/http.properties
:
cat /opt/apigee/edge-message-processor/conf/http.properties
Vào cuối tệp, bạn sẽ thấy thuộc tính được đặt, trong biểu mẫu:
conf/http.properties:HTTPClient.proxy.host=myhost.name.com
Định cấu hình proxy chuyển tiếp cho các yêu cầu trong phần Gửi yêu cầu của Giao diện người dùng theo dõi
Phần này giải thích cách định cấu hình proxy chuyển tiếp cho các yêu cầu trong phần Gửi yêu cầu của giao diện người dùng Theo dõi bằng thông tin xác thực proxy không bắt buộc. Cách định cấu hình proxy chuyển tiếp:
- Chỉnh sửa
/opt/apigee/customer/application/ui.properties
và đảm bảo tệp thuộc quyền sở hữu củaapigee:apigee
. - Thêm các giá trị ghi đè sau (thay đổi giá trị thành cấu hình proxy cụ thể của bạn):
conf_application_http.proxyhost=proxy.example.com conf_application_http.proxyport=8080 conf_application_http.proxyuser=apigee conf_application_http.proxypassword=Apigee123!
- Lưu và khởi động lại giao diện người dùng cổ điển.
Thêm định dạng nhật ký tuỳ chỉnh trong Trình định tuyến Apigee/Nginx
Trong một số trường hợp, bạn có thể cần thay đổi định dạng nhật ký Apigee Router/Nginx mặc định hoặc thêm biến. Cách cập nhật cấu hình mặc định của Bộ định tuyến Apigee/Nginx cho định dạng nhật ký:
- Tạo tệp
router.properties
(nếu chưa có) bằng đường dẫn dưới đây:/opt/apigee/customer/application/router.properties
- Thêm nội dung sau vào tệp
router.properties
để tạo cấu hìnhlog_format
mới có tênrouter_new
:conf_load_balancing_load.balancing.driver.nginx.global.http.parameters.template.extra=log_format router_new 'time_iso8601\\\\thostname\\\\tremote_addr:remote_port\\\\t'\\\\n\\n 'upstream_addr\\\\trequest_time\\\\t-\\\\t-\\\\t'\\\\n\\n '
status\\\\tupstream_status\\\\trequest_length\\\\t'\\\\n\\n 'body_bytes_sent\\\\t'\\\\n\\n 'request\\\\tupstream_http_x_apigee_message_id\\\\t'\\\\n\\n 'http_user_agent\\\\thost\\thostname-pid-connection-connection_requests\\\\tmy_nginx_var_xff\\t'\\\\n\\n 'upstream_http_x_apigee_fault_flag\\\\tupstream_http_x_apigee_fault_source\\\\tupstream_http_x_apigee_fault_code\\\\t'\\\\n\\n 'upstream_http_x_apigee_fault_policy\\tupstream_http_x_apigee_fault_flow\\tupstream_http_x_apigee_fault_revision\\t'\\\\n\\n 'upstream_http_x_apigee_dp_color\\\\tmy_x_apigee_target_latency\\\\t'\\\\n\\n 'upstream_http_x_apigee_proxy\\\\tupstream_http_x_apigee_proxy_basepath\\\\t'\\\\n\\n 'self_region\\\\tself_pod\\\\tself_color\\\\tssl_protocol\\\\tssl_client_verify\\\\tssl_session_id\\\\tssl_session_reused\\\\tupstream_pod\\\\tupstream_region';\\\\n\\n\n conf_load_balancing_load.balancing.driver.nginx.access.log={conf_load_balancing_load.balancing.driver.nginx.log.dir}/{org}~{env}.{port}_access_log router_new Cập nhật các biến trong các lệnh trên cho phù hợp. Bạn có thể tìm thấy các giá trị cấu hình mặc định cho
log_format
trong tệp dưới đây:/opt/apigee/edge-router/conf/load_balancing.properties
Danh sách biến Nginx được trình bày tại http://nginx.org/en/docs/varindex.html.
- Khởi động lại Bộ định tuyến để áp dụng cấu hình mới:
apigee-service edge-router restart
- Kiểm tra xem cấu hình
log_format
mới (router_new
) đã được thêm vào tệp/opt/nginx/conf.d/0-default.conf
hay chưa:cat /opt/nginx/conf.d/0-default.conf | grep router_new -A 10
- Gửi một số yêu cầu API đến proxy API và xác minh định dạng nhật ký mới trong tệp
/opt/apigee/var/log/edge-router/nginx/${org}~${env}.${port}_access_log file