返回介绍

介绍

其他

How-To

开发

模块参考

ngx_http_session_log_module

发布于 2024-08-13 23:46:27 字数 6800 浏览 0 评论 0 收藏 0

ngx_http_session_log_module 模块启用会话日志(多个 HTTP 请求的聚合),而不是单个 HTTP 请求。

该模块作为我们商业订阅的一部分提供。

示例配置

以下配置根据请求客户端的地址和 User-Agent 请求头字段设置会话日志并将请求映射到会话:

session_log_zone /path/to/log format=combined
          zone=one:1m timeout=30s
          md5=$binary_remote_addr$http_user_agent;

location /media/ {
  session_log one;
}

指令

session_log

-说明
语法session_log name | off;
默认session_log off;
上下文http、server、location

允许使用指定的会话日志。特殊值 off 取消从先前配置级别继承的所有 session_log 指令。

session_log_format

-说明
语法session_log_format name string ...;
默认session_log_format combined "...";
上下文http

指定日志的输出格式。$body_bytes_sent 变量的值聚合在会话的所有请求中。可用于记录的所有其他变量的值对应于会话中的第一个请求。

session_log_zone

-说明
语法session_log_zone path zone=name:size [format=format] [timeout=time] [id=id] [md5=md5];
默认——
上下文http

设置日志文件的路径,并配置用于存储当前活动会话的共享内存区域。

只要会话中的最后一个请求经过的时间不超过指定的 timeout(默认为 30 秒),会话就被视为活动状态。会话不再处于活动状态后将被写入日志。

id 参数标识请求映射到的会话。id 参数设置为 MD5 哈希的十六进制形式(例如,使用变量从 cookie 中获取)。如果未指定此参数或不是有效的 MD5 哈希,则 nginx 将根据 md5 参数的值计算 MD5 哈希,并使用此哈希创建新会话。idmd5 参数都可以包含变量。

format 参数设置 session_log_format 指令配置的自定义会话日志格式。如果未指定 format,则使用预定义的 combined格式。

内嵌变量

ngx_http_session_log_module 模块支持两个内嵌变量:

  • $session_log_id

    当前会话 ID

  • $session_log_binary_id

    二进制形式的当前会话 ID(16字节)。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文