我正在编写一个插件,将访问日志放入一个文件中,就像普通的Web服务器一样.作为客户端IP地址的数据源,conn有remote_ip和peer.我应该使用哪种,它们之间有什么区别?
是否有任何文件描述了每个实体conn?
另外,我的插件就像下面的片段一样,从Elixir/Phoenix的角度来看是否自然?
Logger.info(
Enum.join([
"type:" <> "request",
"remoteip:" <> Enum.join(Tuple.to_list(conn.remote_ip), ","),
"method:" <> conn.method,
"path:" <> conn.request_path,
"status:" <> to_string(conn.status),
"size_res:" <> to_string(byte_size(to_string(conn.resp_body))),
], ",")
)
Run Code Online (Sandbox Code Playgroud)
来自Plug.Conn文档:
peer - 连接的实际TCP对等体,例如:{{127,0,0,1},12345}.通常这不是客户端的实际IP和端口,而是负载平衡器或请求路由器.
remote_ip - 客户端的IP,例如:{151,236,219,228}.该字段意味着被插入例如X-Forwarded-For标头或HAProxy的PROXY协议的插头覆盖.它默认为对等的IP.
如果您使用的是负载均衡器(例如http://docs.aws.amazon.com/ElasticLoadBalancing/latest/DeveloperGuide/x-forwarded-headers.html),那么peerIP地址将引用负载均衡器而不是客户端.负载平衡器在标头(X-Forwarded-For用于AWS)中提供客户端的实际IP地址,该标头将存储在Plug.Conn结构中remote_ip.
另见https://tools.ietf.org/html/rfc7239
| 归档时间: |
|
| 查看次数: |
1312 次 |
| 最近记录: |