程序员 第38章 nginx

2022-07-21

1、常见配置

①、使用 Nginx 时请求 .well-known 路径时提示 403 错误

在进行 https 证书申请时提示需要进行域名验证,需要上传文件到 /.well-known/pki-validation/ 目录,上传之后打开网址发现提示 403 错误。

解决方法在 nginx.conf 中增加

location ~ /.well-known {
  allow all;
}

2、windows 下 PHP + Nginx curl 访问本地超时

①、问题分析

出现以上原因是因为windows 下 nginx+php环境,不支持并发的原因。
当同时访问多个域名,并且同时指向你本地服务的时候,就不支持并发了。

②、解决方法

A、vhosts.conf 里面 对需要修改的 server 修改其 fastcgi_pass 的端口号

由 fastcgi_pass   127.0.0.1:9000;
修改为 fastcgi_pass   127.0.0.1:9001;

B、启动另一个 php-cgi

打开cmd命令行运行: "你的路径/php-cgi.exe" -b 127.0.0.1:9001 -c "你的路径/php.ini"(不能关闭窗口)

https://file.lulublog.cn/images/3/2022/08/pV9HUUYHIzvquhbQ54uUDzji544iQy.png

上面用cmd命令行窗口是不是很麻烦,还不能关闭窗口,稍微不注意就悲剧了。

可以用下面的一个小工具:RunHiddenConsole.exe

首先你需要下载一个小文件RunHiddenConsole 然后复制到nginx目录,新建 start.bat 批处理文件

https://file.lulublog.cn/images/3/2022/08/QQuhdzUnRDpyqh2Sy0QM0YhWynDP0L.png

start.bat 代码(根据你的路径进行修改)

echo Starting PHP FastCGI...
"F:\Program Files\phpStudy\PHPTutorial\nginx\RunHiddenConsole" "F:\Program Files\phpStudy\PHPTutorial\php\php-7.0.12-nts\php-cgi.exe" -b 127.0.0.1:9001 -c "F:\Program Files\phpStudy\PHPTutorial\php\php-7.0.12-nts\php.ini"

保存后直接运行 start.bat ,你会发现 cmd 窗口消失了,但一切正常运行。

3、nginx查看日志

①、日志格式

nginx的log日志分为access log 和 error log

其中access log 记录了哪些用户,哪些页面以及用户浏览器、ip和其他的访问信息

error log 则是记录服务器错误日志

错误日志的形式如下:

10.1.1.1 - - [22/Aug/2014:16:48:14 +0800] "POST /ajax/MbpRequest.do HTTP/1.1" 200 367 "-" "Dalvik/1.6.0 (Linux; U; Android 4.1.1; ARMM7K Build/JRO03H)" "119.189.56.175" 127.0.0.1:8090 0.022 0.022 
10.1.1.1 - - [22/Aug/2014:16:48:19 +0800] "POST /ajax/MbpRequest.do HTTP/1.1" 200 616 "-" "Dalvik/1.6.0 (Linux; U; Android 4.0.4; GT-I9103 Build/IMM76D)" "36.250.89.22" 127.0.0.1:8090 0.036 0.036

从上面我们可以看出几部分信息:

  • 1.客户端(用户)IP地址。如:上例中的 10.1.1.1 (内网负载均衡地址)

  • 2.访问时间。如:上例中的 [22/Aug/2014:16:48:19 +0800]

  • 3.访问端口。如:上例中的 127.0.0.1:8080

  • 4.响应时间。如:上例中的 0.022

  • 5.请求时间。如:上例中的 0.022

  • 6.用户地理位置代码(国家代码)。

  • 7.请求的url地址(目标url地址)的host。如:上例中的 /....

  • 8.请求方式(GET或者POST等)。如:上例中的 GET

  • 9.请求url地址(去除host部分)。如:上例中的 /html/test.html

  • 10.请求状态(状态码,200表示成功,404表示页面不存在,301表示永久重定向等,具体状态码可以在网上找相关文章,不再赘述)。如:上例中的 "200"

  • 11.请求页面大小,默认为B(byte)。如:上例中的 2426

  • 12.来源页面,即从哪个页面转到本页,专业名称叫做“referer”。如:上例中的 "http://a.com"

  • 13.用户浏览器语言。如:上例中的 "es-ES,es;q=0.8"

  • 14. 用户浏览器其他信息,浏览器版本、浏览器类型等。如:上例中的  "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.97 Safari/537.11"

②、自定义日志配置

其实nginx access日志的格式不是一成不变的,是可以自定义的。

在nginx的nginx.conf配置文件找到:log_format 这里就是日志的格式

看一下和上述日志匹配的log格式设置:

#access日志格式配置,具体参数不再细说,上面都已经说过了,自己对应一下即可
log_format  main  "$remote_addr - $remote_user [$time_local] "$request" "
                  "$status $body_bytes_sent "$http_referer" "
                  ""$http_user_agent" "$http_x_forwarded_for""
                   "$upstream_addr $upstream_response_time $request_time ";
access_log  logs/access.log  main;
#配置access log日志的存储位置及文件,注意:access.log文件是可以按日期进行分割的,方便查看及处理
access_log  /usr/local/nginx/log/access.log  main;

相关说明解释

  • 1.$remote_addr 与$http_x_forwarded_for 用以记录客户端的ip地址;

  • 2.$remote_user :用来记录客户端用户名称;

  • 3.$time_local : 用来记录访问时间与时区;

  • 4.$request : 用来记录请求的url与http协议;

  • 5.$status : 用来记录请求状态;成功是200,

  • 6.$body_bytes_s ent :记录发送给客户端文件主体内容大小;

  • 7.$http_referer :用来记录从那个页面链接访问过来的;

  • 8.$http_user_agent :记录客户端浏览器的相关信息;

4、伪静态配置

TP框架的rewrite配置
location / {
    if (!-e $request_filename) {
        rewrite ^(.*)$ /index.php?s=$1 l
        break;
    }
}
yii站点中运行执行命令的伪静态配置
location / {
     try_files $uri $uri/ /index.php$is_args$args;
}

5、nginx pc 域名 移动端切换配置

// 在server字段添加:pc切换H5
if ( $http_user_agent ~* "(Android|iPhone|Windows Phone|UC|Kindle)" ){
    rewrite  ^/(.*)$  https://wap.demo.cn redirect;
}

// 在server字段添加:H5切换PC
if ( $http_user_agent !~* "(Android|iPhone|Windows Phone|UC|Kindle)" ){
    rewrite  ^/(.*)$  https://pc.demo.cn redirect;
}

6、设置跨域后 options返回状态405

在对应的网站配置文件里配置以下代码即可

location / {
    error_page 405 =200  $request_uri;
}

7、$request_uri 和 $uri 详解

  • $request_uri:这个变量等于从客户端发送来的原始请求URI(最原始的),包括参数,它不可以进行修改。$uri变量反映的是重写后/改变的URI(最终的),不包括主机名。例如:"/foo/bar.php?arg=baz"

  • $uri:这个变量指当前的请求URI,不包括任何参数(见$args)。这个变量反映任何内部重定向或index模块所做的修改。注意,这和$request_uri不同,因$request_uri是浏览器发起的不做任何修改的原生URI。不包括协议及主机名。例如:"/foo/bar.html"

  • 案例1:访问:http://127.0.0.1/test/

    • $uri:/test/test.html

    • $request_uri:/test/

  • 案例2:

    • 访问:http://127.0.0.1/

    • $uri:/index.html

    • $request_uri:/

  • 案例3(服务器上不存在res目录)

    • 访问:http://127.0.0.1/res

    • $uri:/res

    • $request_uri:/res

阅读 116

程序员文章

带到手机上看