{"id":61275,"date":"2025-04-29T10:09:14","date_gmt":"2025-04-29T02:09:14","guid":{"rendered":"https:\/\/fwq.ai\/blog\/61275\/"},"modified":"2025-04-29T10:09:14","modified_gmt":"2025-04-29T02:09:14","slug":"nginx%e6%97%a5%e5%bf%97%e5%88%87%e5%89%b2%e9%85%8d%e7%bd%ae%e8%a7%a3%e6%9e%90%ef%bc%8c%e7%ae%a1%e7%90%86%e7%bd%91%e7%ab%99%e6%97%a5%e5%bf%97%e5%ad%98%e5%82%a8-2","status":"publish","type":"post","link":"https:\/\/fwq.ai\/blog\/61275\/","title":{"rendered":"Nginx\u65e5\u5fd7\u5207\u5272\u914d\u7f6e\u89e3\u6790\uff0c\u7ba1\u7406\u7f51\u7ad9\u65e5\u5fd7\u5b58\u50a8"},"content":{"rendered":"<p>\u65e5\u5fd7\u5207\u5272\u914d\u7f6e\u89e3\u6790\uff0c\u7ba1\u7406\u7f51\u7ad9\u65e5\u5fd7\u5b58\u50a8<\/p>\n<p>\u5728\u4e00\u4e2a\u7f51\u7ad9\u7684\u8fd0\u884c\u8fc7\u7a0b\u4e2d\uff0c\u65e5\u5fd7\u662f\u975e\u5e38\u91cd\u8981\u7684\u3002\u5b83\u53ef\u4ee5\u4e3a\u7f51\u7ad9\u7684\u8fd0\u884c\u72b6\u6001\u63d0\u4f9b\u8be6\u7ec6\u7684\u8bb0\u5f55\uff0c\u5e2e\u52a9\u5f00\u53d1\u8005\u548c\u7ba1\u7406\u5458\u5206\u6790\u95ee\u9898\uff0c\u4f18\u5316\u6027\u80fd\u3002\u7136\u800c\uff0c\u968f\u7740\u7f51\u7ad9\u7684\u4e0d\u65ad\u53d1\u5c55\uff0c\u65e5\u5fd7\u6587\u4ef6\u4f1a\u8d8a\u6765\u8d8a\u5927\uff0c\u8fd9\u4f1a\u5bf9\u670d\u52a1\u5668\u7684\u5b58\u50a8\u7a7a\u95f4\u548c\u6027\u80fd\u4ea7\u751f\u8d1f\u62c5\u3002\u4e3a\u4e86\u89e3\u51b3\u8fd9\u4e2a\u95ee\u9898\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528Nginx\u7684\u65e5\u5fd7\u5207\u5272\u529f\u80fd\uff0c\u5c06\u65e5\u5fd7\u6587\u4ef6\u6309\u65f6\u95f4\u6216\u5927\u5c0f\u8fdb\u884c\u62c6\u5206\uff0c\u4ece\u800c\u5b9e\u73b0\u65e5\u5fd7\u7684\u6709\u6548\u7ba1\u7406\u4e0e\u5b58\u50a8\u3002<\/p>\n<p>Nginx\u662f\u4e00\u6b3e\u9ad8\u6027\u80fd\u7684Web\u670d\u52a1\u5668\uff0c\u5e76\u4e14\u53ef\u4ee5\u901a\u8fc7\u914d\u7f6e\u6587\u4ef6\u7075\u6d3b\u5730\u8c03\u6574\u5176\u529f\u80fd\u548c\u884c\u4e3a\u3002\u4e0b\u9762\uff0c\u6211\u4eec\u5c06\u4f7f\u7528\u4e00\u4e2a\u7b80\u5355\u7684\u4f8b\u5b50\u6765\u6f14\u793a\u5982\u4f55\u914d\u7f6eNginx\u5b9e\u73b0\u65e5\u5fd7\u7684\u5207\u5272\u3002<\/p>\n<p>\u9996\u5148\uff0c\u6211\u4eec\u9700\u8981\u5728Nginx\u7684\u914d\u7f6e\u6587\u4ef6\u4e2d\u6307\u5b9a\u65e5\u5fd7\u7684\u683c\u5f0f\u548c\u5b58\u50a8\u8def\u5f84\u3002\u5728Nginx\u7684http\u6a21\u5757\u4e2d\uff0c\u53ef\u4ee5\u901a\u8fc7\u6dfb\u52a0\u4ee5\u4e0b\u4ee3\u7801\u6765\u5b9a\u4e49\u65e5\u5fd7\u683c\u5f0f\uff1a<\/p>\n<pre>http {\n    ...\n    log_format access '$remote_addr - $remote_user [$time_local] \"$request\" '\n                    '$status $body_bytes_sent \"$http_referer\" '\n                    '\"$http_user_agent\" \"$http_x_forwarded_for\"';\n    ...\n}<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>\u5728\u4e0a\u8ff0\u4ee3\u7801\u4e2d\uff0clog_format\u6307\u4ee4\u5b9a\u4e49\u4e86\u4e00\u4e2a\u540d\u4e3aaccess\u7684\u65e5\u5fd7\u683c\u5f0f\uff0c\u5176\u4e2d\u5305\u542b\u4e86\u4e00\u4e9b\u5e38\u7528\u7684\u65e5\u5fd7\u53d8\u91cf\uff0c\u5982\u5ba2\u6237\u7aefIP\u5730\u5740\u3001\u8bbf\u95ee\u65f6\u95f4\u3001\u8bf7\u6c42URL\u3001\u8fd4\u56de\u72b6\u6001\u7801\u7b49\u3002<\/p>\n<p>\u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u9700\u8981\u5c06\u8fd9\u4e2a\u65e5\u5fd7\u683c\u5f0f\u5e94\u7528\u5230\u5177\u4f53\u7684\u8bbf\u95ee\u65e5\u5fd7\u4e2d\u3002\u5728Nginx\u7684server\u5757\u4e2d\uff0c\u53ef\u4ee5\u901a\u8fc7\u6dfb\u52a0\u4ee5\u4e0b\u4ee3\u7801\u6765\u6307\u5b9a\u8bbf\u95ee\u65e5\u5fd7\u7684\u5b58\u50a8\u8def\u5f84\u548c\u683c\u5f0f\uff1a<\/p>\n<pre>server {\n    ...\n    access_log \/var\/log\/nginx\/access.log access;\n    ...\n}<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>\u5728\u4e0a\u8ff0\u4ee3\u7801\u4e2d\uff0caccess_log\u6307\u4ee4\u6307\u5b9a\u4e86\u8bbf\u95ee\u65e5\u5fd7\u7684\u5b58\u50a8\u8def\u5f84\u548c\u683c\u5f0f\u3002\u5176\u4e2d\uff0c\/var\/log\/nginx\/access.log\u4e3a\u65e5\u5fd7\u6587\u4ef6\u7684\u5b58\u50a8\u8def\u5f84\uff0caccess\u4e3a\u4e4b\u524d\u5b9a\u4e49\u7684\u65e5\u5fd7\u683c\u5f0f\u540d\u79f0\u3002<\/p>\n<p>\u9ed8\u8ba4\u60c5\u51b5\u4e0b\uff0cNginx\u4f1a\u628a\u6240\u6709\u7684\u8bbf\u95ee\u65e5\u5fd7\u5199\u5165\u5230\u540c\u4e00\u4e2a\u6587\u4ef6\u4e2d\u3002\u4f46\u662f\uff0c\u5f53\u8fd9\u4e2a\u6587\u4ef6\u53d8\u5f97\u975e\u5e38\u5927\u65f6\uff0c\u6211\u4eec\u53ef\u80fd\u4f1a\u5e0c\u671b\u5c06\u5b83\u62c6\u5206\u6210\u591a\u4e2a\u5c0f\u6587\u4ef6\u3002\u4e3a\u4e86\u5b9e\u73b0\u8fd9\u4e2a\u529f\u80fd\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528Nginx\u63d0\u4f9b\u7684logrotate\u5de5\u5177\u3002<\/p>\n<p>logrotate\u662f\u4e00\u4e2a\u5e38\u7528\u7684\u65e5\u5fd7\u5207\u5272\u5de5\u5177\uff0c\u53ef\u4ee5\u6839\u636e\u6307\u5b9a\u7684\u89c4\u5219\u6765\u62c6\u5206\u65e5\u5fd7\u6587\u4ef6\u3002\u6211\u4eec\u53ef\u4ee5\u7f16\u5199\u4e00\u4e2a\u540d\u4e3anginx\u7684\u914d\u7f6e\u6587\u4ef6\uff0c\u5176\u4e2d\u5b9a\u4e49\u4e86Nginx\u8bbf\u95ee\u65e5\u5fd7\u7684\u62c6\u5206\u89c4\u5219\u3002\u4e0b\u9762\u662f\u4e00\u4e2a\u793a\u4f8b\uff1a<\/p>\n<pre>\/var\/log\/nginx\/access.log {\n    daily\n    rotate 7\n    missingok\n    notifempty\n    compress\n    postrotate\n        \/usr\/sbin\/nginx -s reopen\n    endscript\n}<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>\u5728\u4e0a\u8ff0\u4ee3\u7801\u4e2d\uff0c\/var\/log\/nginx\/access.log\u4e3a\u9700\u8981\u88ab\u62c6\u5206\u7684\u65e5\u5fd7\u6587\u4ef6\u8def\u5f84\u3002daily\u6307\u5b9a\u4e86\u6309\u5929\u62c6\u5206\uff0crotate 7\u8868\u793a\u4fdd\u75597\u5929\u7684\u65e5\u5fd7\u6587\u4ef6\u3002missingok\u8868\u793a\u5982\u679c\u65e5\u5fd7\u6587\u4ef6\u4e0d\u5b58\u5728\uff0c\u4e5f\u4e0d\u62a5\u9519\u3002notifempty\u8868\u793a\u5982\u679c\u65e5\u5fd7\u6587\u4ef6\u4e3a\u7a7a\uff0c\u4e5f\u4e0d\u62a5\u9519\u3002compress\u8868\u793a\u5bf9\u65b0\u751f\u6210\u7684\u65e5\u5fd7\u6587\u4ef6\u8fdb\u884c\u538b\u7f29\u3002postrotate\u548cendscript\u4e4b\u95f4\u7684\u4ee3\u7801\u4f1a\u5728\u65e5\u5fd7\u6587\u4ef6\u5207\u5272\u5b8c\u6210\u540e\u6267\u884c\uff0c\u8fd9\u91cc\u4f7f\u7528\/usr\/sbin\/nginx -s reopen\u6765\u901a\u77e5Nginx\u91cd\u65b0\u6253\u5f00\u65e5\u5fd7\u6587\u4ef6\u3002<\/p>\n<p>\u6700\u540e\uff0c\u6211\u4eec\u9700\u8981\u5c06\u8fd9\u4e2anginx\u914d\u7f6e\u6587\u4ef6\u653e\u7f6e\u5230\/etc\/logrotate.d\/\u76ee\u5f55\u4e0b\u3002logrotate\u4f1a\u5b9a\u671f\u626b\u63cf\u8fd9\u4e2a\u76ee\u5f55\uff0c\u7136\u540e\u6309\u7167\u5176\u4e2d\u7684\u914d\u7f6e\u6587\u4ef6\u8fdb\u884c\u65e5\u5fd7\u5207\u5272\u3002<\/p>\n<p>\u4ee5\u4e0a\u5c31\u662f\u4f7f\u7528Nginx\u5b9e\u73b0\u65e5\u5fd7\u5207\u5272\u7684\u7b80\u5355\u793a\u4f8b\u3002\u901a\u8fc7\u5408\u7406\u914d\u7f6eNginx\u7684\u65e5\u5fd7\u683c\u5f0f\u548c\u5207\u5272\u89c4\u5219\uff0c\u6211\u4eec\u53ef\u4ee5\u6709\u6548\u5730\u7ba1\u7406\u548c\u5b58\u50a8\u7f51\u7ad9\u7684\u8bbf\u95ee\u65e5\u5fd7\u3002\u8fd9\u4e0d\u4ec5\u53ef\u4ee5\u8282\u7701\u5b58\u50a8\u7a7a\u95f4\uff0c\u8fd8\u80fd\u63d0\u9ad8\u670d\u52a1\u5668\u7684\u6574\u4f53\u6027\u80fd\u3002\u5e0c\u671b\u672c\u6587\u5bf9\u60a8\u6709\u6240\u5e2e\u52a9\u3002<\/p>\n<p>\u4ee5\u4e0a\u5c31\u662fNginx\u65e5\u5fd7\u5207\u5272\u914d\u7f6e\u89e3\u6790\uff0c\u7ba1\u7406\u7f51\u7ad9\u65e5\u5fd7\u5b58\u50a8\u7684\u8be6\u7ec6\u5185\u5bb9\uff0c\u66f4\u591a\u8bf7\u5173\u6ce8FDCServers\u5176\u5b83\u76f8\u5173\u6587\u7ae0\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u65e5\u5fd7\u5207\u5272\u914d\u7f6e\u89e3\u6790\uff0c\u7ba1\u7406\u7f51\u7ad9\u65e5\u5fd7\u5b58\u50a8 \u5728\u4e00\u4e2a\u7f51\u7ad9\u7684\u8fd0\u884c\u8fc7\u7a0b\u4e2d\uff0c\u65e5\u5fd7\u662f\u975e\u5e38\u91cd\u8981\u7684\u3002\u5b83\u53ef\u4ee5\u4e3a\u7f51\u7ad9\u7684\u8fd0\u884c\u72b6\u6001\u63d0\u4f9b\u8be6\u7ec6\u7684\u8bb0\u5f55\uff0c\u5e2e\u52a9\u5f00\u53d1\u8005\u548c\u7ba1\u7406\u5458\u5206\u6790\u95ee\u9898\uff0c\u4f18\u5316\u6027\u80fd\u3002\u7136\u800c\uff0c\u968f\u7740\u7f51\u7ad9\u7684\u4e0d\u65ad\u53d1\u5c55\uff0c\u65e5\u5fd7\u6587\u4ef6\u4f1a\u8d8a\u6765\u8d8a\u5927\uff0c\u8fd9\u4f1a\u5bf9\u670d\u52a1\u5668\u7684\u5b58\u50a8\u7a7a\u95f4\u548c\u6027\u80fd\u4ea7\u751f\u8d1f\u62c5\u3002\u4e3a\u4e86\u89e3\u51b3\u8fd9\u4e2a\u95ee\u9898\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528Nginx\u7684\u65e5\u5fd7\u5207\u5272\u529f\u80fd\uff0c\u5c06\u65e5\u5fd7\u6587\u4ef6\u6309\u65f6\u95f4\u6216\u5927\u5c0f\u8fdb\u884c\u62c6\u5206\uff0c\u4ece\u800c\u5b9e\u73b0\u65e5\u5fd7\u7684\u6709\u6548\u7ba1\u7406\u4e0e\u5b58\u50a8\u3002 Nginx\u662f\u4e00\u6b3e\u9ad8\u6027\u80fd\u7684Web\u670d\u52a1\u5668\uff0c\u5e76\u4e14\u53ef\u4ee5\u901a\u8fc7\u914d\u7f6e\u6587\u4ef6\u7075\u6d3b\u5730\u8c03\u6574\u5176\u529f\u80fd\u548c\u884c\u4e3a\u3002\u4e0b\u9762\uff0c\u6211\u4eec\u5c06\u4f7f\u7528\u4e00\u4e2a\u7b80\u5355\u7684\u4f8b\u5b50\u6765\u6f14\u793a\u5982\u4f55\u914d\u7f6eNginx\u5b9e\u73b0\u65e5\u5fd7\u7684\u5207\u5272\u3002 \u9996\u5148\uff0c\u6211\u4eec\u9700\u8981\u5728Nginx\u7684\u914d\u7f6e\u6587\u4ef6\u4e2d\u6307\u5b9a\u65e5\u5fd7\u7684\u683c\u5f0f\u548c\u5b58\u50a8\u8def\u5f84\u3002\u5728Nginx\u7684http\u6a21\u5757\u4e2d\uff0c\u53ef\u4ee5\u901a\u8fc7\u6dfb\u52a0\u4ee5\u4e0b\u4ee3\u7801\u6765\u5b9a\u4e49\u65e5\u5fd7\u683c\u5f0f\uff1a http { &#8230; log_format access &#8216;$remote_addr &#8211; $remote_user [$time_local] &#8220;$request&#8221; &#8216; &#8216;$status $body_bytes_sent &#8220;$http_referer&#8221; &#8216; &#8216;&#8221;$http_user_agent&#8221; &#8220;$http_x_forwarded_for&#8221;&#8216;; &#8230; } \u767b\u5f55\u540e\u590d\u5236 \u5728\u4e0a\u8ff0\u4ee3\u7801\u4e2d\uff0clog_format\u6307\u4ee4\u5b9a\u4e49\u4e86\u4e00\u4e2a\u540d\u4e3aaccess\u7684\u65e5\u5fd7\u683c\u5f0f\uff0c\u5176\u4e2d\u5305\u542b\u4e86\u4e00\u4e9b\u5e38\u7528\u7684\u65e5\u5fd7\u53d8\u91cf\uff0c\u5982\u5ba2\u6237\u7aefIP\u5730\u5740\u3001\u8bbf\u95ee\u65f6\u95f4\u3001\u8bf7\u6c42URL\u3001\u8fd4\u56de\u72b6\u6001\u7801\u7b49\u3002 \u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u9700\u8981\u5c06\u8fd9\u4e2a\u65e5\u5fd7\u683c\u5f0f\u5e94\u7528\u5230\u5177\u4f53\u7684\u8bbf\u95ee\u65e5\u5fd7\u4e2d\u3002\u5728Nginx\u7684server\u5757\u4e2d\uff0c\u53ef\u4ee5\u901a\u8fc7\u6dfb\u52a0\u4ee5\u4e0b\u4ee3\u7801\u6765\u6307\u5b9a\u8bbf\u95ee\u65e5\u5fd7\u7684\u5b58\u50a8\u8def\u5f84\u548c\u683c\u5f0f\uff1a server { &#8230; access_log \/var\/log\/nginx\/access.log access; &#8230; } \u767b\u5f55\u540e\u590d\u5236 \u5728\u4e0a\u8ff0\u4ee3\u7801\u4e2d\uff0caccess_log\u6307\u4ee4\u6307\u5b9a\u4e86\u8bbf\u95ee\u65e5\u5fd7\u7684\u5b58\u50a8\u8def\u5f84\u548c\u683c\u5f0f\u3002\u5176\u4e2d\uff0c\/var\/log\/nginx\/access.log\u4e3a\u65e5\u5fd7\u6587\u4ef6\u7684\u5b58\u50a8\u8def\u5f84\uff0caccess\u4e3a\u4e4b\u524d\u5b9a\u4e49\u7684\u65e5\u5fd7\u683c\u5f0f\u540d\u79f0\u3002 \u9ed8\u8ba4\u60c5\u51b5\u4e0b\uff0cNginx\u4f1a\u628a\u6240\u6709\u7684\u8bbf\u95ee\u65e5\u5fd7\u5199\u5165\u5230\u540c\u4e00\u4e2a\u6587\u4ef6\u4e2d\u3002\u4f46\u662f\uff0c\u5f53\u8fd9\u4e2a\u6587\u4ef6\u53d8\u5f97\u975e\u5e38\u5927\u65f6\uff0c\u6211\u4eec\u53ef\u80fd\u4f1a\u5e0c\u671b\u5c06\u5b83\u62c6\u5206\u6210\u591a\u4e2a\u5c0f\u6587\u4ef6\u3002\u4e3a\u4e86\u5b9e\u73b0\u8fd9\u4e2a\u529f\u80fd\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528Nginx\u63d0\u4f9b\u7684logrotate\u5de5\u5177\u3002 logrotate\u662f\u4e00\u4e2a\u5e38\u7528\u7684\u65e5\u5fd7\u5207\u5272\u5de5\u5177\uff0c\u53ef\u4ee5\u6839\u636e\u6307\u5b9a\u7684\u89c4\u5219\u6765\u62c6\u5206\u65e5\u5fd7\u6587\u4ef6\u3002\u6211\u4eec\u53ef\u4ee5\u7f16\u5199\u4e00\u4e2a\u540d\u4e3anginx\u7684\u914d\u7f6e\u6587\u4ef6\uff0c\u5176\u4e2d\u5b9a\u4e49\u4e86Nginx\u8bbf\u95ee\u65e5\u5fd7\u7684\u62c6\u5206\u89c4\u5219\u3002\u4e0b\u9762\u662f\u4e00\u4e2a\u793a\u4f8b\uff1a \/var\/log\/nginx\/access.log { daily rotate 7 missingok notifempty compress postrotate \/usr\/sbin\/nginx -s reopen endscript } \u767b\u5f55\u540e\u590d\u5236 \u5728\u4e0a\u8ff0\u4ee3\u7801\u4e2d\uff0c\/var\/log\/nginx\/access.log\u4e3a\u9700\u8981\u88ab\u62c6\u5206\u7684\u65e5\u5fd7\u6587\u4ef6\u8def\u5f84\u3002daily\u6307\u5b9a\u4e86\u6309\u5929\u62c6\u5206\uff0crotate 7\u8868\u793a\u4fdd\u75597\u5929\u7684\u65e5\u5fd7\u6587\u4ef6\u3002missingok\u8868\u793a\u5982\u679c\u65e5\u5fd7\u6587\u4ef6\u4e0d\u5b58\u5728\uff0c\u4e5f\u4e0d\u62a5\u9519\u3002notifempty\u8868\u793a\u5982\u679c\u65e5\u5fd7\u6587\u4ef6\u4e3a\u7a7a\uff0c\u4e5f\u4e0d\u62a5\u9519\u3002compress\u8868\u793a\u5bf9\u65b0\u751f\u6210\u7684\u65e5\u5fd7\u6587\u4ef6\u8fdb\u884c\u538b\u7f29\u3002postrotate\u548cendscript\u4e4b\u95f4\u7684\u4ee3\u7801\u4f1a\u5728\u65e5\u5fd7\u6587\u4ef6\u5207\u5272\u5b8c\u6210\u540e\u6267\u884c\uff0c\u8fd9\u91cc\u4f7f\u7528\/usr\/sbin\/nginx [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[8],"tags":[],"class_list":["post-61275","post","type-post","status-publish","format-standard","hentry","category-os"],"_links":{"self":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/61275","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/comments?post=61275"}],"version-history":[{"count":0,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/61275\/revisions"}],"wp:attachment":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/media?parent=61275"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/categories?post=61275"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/tags?post=61275"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}