AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 133711
Accepted
ThatGraemeGuy
ThatGraemeGuy
Asked: 2010-04-20 02:22:20 +0800 CST2010-04-20 02:22:20 +0800 CST 2010-04-20 02:22:20 +0800 CST

在 Apache LogFormat 定义中使用 %v 匹配 ServerName 而不是请求的特定 vhost

  • 772

我们有一个使用 DNS 通配符的应用程序,即 *.app.example.com。我们在 Ubuntu Hardy 上使用 Apache 2.2。Apache 配置的相关部分如下。

在 /etc/apache2/httpd.conf 中:

LogFormat "%v %h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" vlog

在 /etc/apache2/sites-enabled/app.example.com 中:

ServerName app.example.com
ServerAlias *.app.example.com
...
CustomLog "|/usr/sbin/vlogger -s access.log /var/log/apache2/vlogger" vlog

客户使用自己的 URL 访问此应用程序,例如 company1.app.example.com、company2.app.example.com 等。

以前,指令%v中的LogFormat将匹配客户端请求的主机名,我们会在 /var/log/apache2/vlogger 下获得几个子目录,对应于正在使用的各种客户端 URL。

现在,%v似乎与该ServerName值匹配,因此我们仅在 /var/log/apache2/vlogger/app.example.com 下获得一个日志。这破坏了我们的日志文件分析,因为日志文件没有指示该日志与哪个客户端相关。

我可以通过将其更改为以下内容LogFormat来轻松解决此问题:

LogFormat "%{Host}i %h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" vlog

这将使用 HTTP Host: 标头告诉 vlogger 在哪个子目录中创建日志,一切都会好起来的。

我唯一担心的是这在过去是有效的,我找不到任何迹象表明这种情况最近发生了变化。

是否有其他人使用类似的配置,即通配符 + vlogger 并使用%v?它工作正常吗?

apache-2.2
  • 2 2 个回答
  • 6589 Views

2 个回答

  • Voted
  1. Craig Constantine
    2012-06-20T10:22:34+08:002012-06-20T10:22:34+08:00

    还有%V(注意上限)和useCanonicalName选项

    • 6
  2. Best Answer
    Aleksandar Ivanisevic
    2010-04-20T07:55:41+08:002010-04-20T07:55:41+08:00

    %v 一直是虚拟服务器的规范名称,我刚刚检查了 1.3、2.0 和 2.2 的手册,他们都说

    %...v:          The canonical ServerName of the server serving the request.
    

    https://httpd.apache.org/docs/1.3/mod/mod_log_config.html

    https://httpd.apache.org/docs/2.0/mod/mod_log_config.html

    https://httpd.apache.org/docs/2.2/mod/mod_log_config.html

    • 2

相关问题

  • Apache Django Mod_Wsgi - 自动重新加载应用程序

  • Apache:对多个虚拟主机使用相同的目录指令

  • Apache 上的子域不工作 - 找不到服务器

  • PHP 作为 CGI 还是 Apache 模块?

  • 避免将某些丢失的文件记录到 Apache2 错误日志中

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve