配置从边缘到后端服务器的转发代理

适用于私有云的 Edge v. 4.17.01

如果要在 Edge 和后端目标服务器之间使用 HTTP 转发代理,则必须在边缘消息处理器节点上配置出站代理设置属性。这些属性会将消息处理器配置为将目标请求从 Edge 路由到 HTTP 转发代理。

如需配置消息处理器,请修改 /opt/apigee/customer/application/message-processor.properties,然后重启消息处理器。如果 message-processor.properties 文件不存在,请创建该文件。

设置以下属性以配置消息处理器:

属性

说明

conf_http_HTTPClient.use.proxy

指定所有 API 代理是否默认使用转发代理(true)或不默认使用转发代理(false)。

conf_http_HTTPClient.use.tunneling

默认情况下,Edge 会对所有流量使用隧道传输。如需默认停用隧道传输,请将此属性设置为 false

conf/http.properties+HTTPClient.proxy.type

将 HTTP 代理的类型指定为 HTTPHTTPS。默认情况下,它使用 HTTP

conf/http.properties+HTTPClient.proxy.host

指定运行 HTTP 代理的主机名或 IP 地址。

conf/http.properties+HTTPClient.proxy.port

指定运行 HTTP 代理的端口。如果省略此属性,默认情况下,它将使用端口 80(用于 HTTP)和端口 443(用于 HTTPS)。

conf/http.properties+HTTPClient.proxy.user
conf/http.properties+HTTPClient.proxy.password

如果 HTTP 代理需要基本身份验证,则使用这些属性提供授权详细信息。

例如:

conf_http_HTTPClient.use.proxy=true
conf_http_HTTPClient.use.tunneling=false
conf/http.properties+HTTPClient.proxy.type=HTTP
conf/http.properties+HTTPClient.proxy.host=my.host.com
conf/http.properties+HTTPClient.proxy.port=3128
conf/http.properties+HTTPClient.proxy.user=uName
conf/http.properties+HTTPClient.proxy.password=pWord

请务必在设置以下属性后重启消息处理器:

/opt/apigee/apigee-service/bin/apigee-service edge-message-processor restart

如果为消息处理程序配置了转发代理,则从 API 代理到后端目标的所有流量都将通过指定的 HTTP 转发代理。如果 API 代理的特定目标的流量应直接流向后端目标,从而绕过转发代理,请在 Target Endpoint 中设置以下属性以替换 HTTP 转发代理:

<Property name="use.proxy">false</Property> 

如需详细了解如何在目标端点上设置属性,请参阅端点属性参考文档

如果您不希望任何目标默认使用 HTTP 转发代理,可以按如下所示在 http.properties 中指定:

conf_http_HTTPClient.use.proxy=false

然后,对于您要通过 HTTP 转发代理的任何 Target 端点,请将 use.proxy 设置为 true:

<Property name="use.proxy">true</Property>

默认情况下,Edge 会对流向代理的流量使用隧道。如需默认停用隧道传输,请在 message-processor.properties 文件中设置以下属性:

conf_http_HTTPClient.use.tunneling=false 

如果您想为特定目标停用隧道,请在目标端点中设置 use.proxy.tunneling 属性。如果目标使用 TLS/SSL,则该属性会被忽略,并且始终通过隧道发送消息:

<Property name="use.proxy.tunneling">false</Property>

为了让 Edge 本身充当转发代理(从后端服务接收请求并将其路由到企业外部的互联网),首先在 Edge 上设置 API 代理。然后,后端服务可以向 API 代理发出请求,然后 API 代理可以连接到外部服务。