Implementation of Nginx filtering access logs of static resource files

Implementation of Nginx filtering access logs of static resource files

Messy log

Nginx in daily use is mostly used as both a static resource server and a reverse proxy server. In particular, considering cross-domain issues, the same listening port is used for static resources and backend interfaces. If no filtering is performed, a large number of requests for static resources such as js, css, jpg, etc. will be seen in access_log, which will affect the viewing of backend interface call logs.

I didn't pay much attention to this thing at first, but when I was browsing an article about Nginx optimization, I found a method to use map to define a parameter of whether to write logs. Combined with the recent use of map for dynamic cross-domain configuration, I simply learned and recorded another usage scenario of map.

Use map to filter logs for accessing static resource files

http {
  log_format main '$remote_addr [$time_local] $request $status '
           'uct="$upstream_connect_time" rt="$request_time"';

  map $uri $not_static {
    default 1;
    ~^(.*\.(gif|jpg|jpeg|png|bmp|swf|js|css|woff|ttf)$) 0;
  }

  server {
    listen 23456;
    server_name localhost;
    access_log logs/test.log main if=$not_static;
  }
}

Explanation:

  • Customize a log_format, marked as main
  • Match the URI in the request. If the resource ends with gif, jpg, css, js, etc., $not_static is 0, otherwise it is 1
  • For requests to access port 23456, access_log specifies the use of a custom log format identified as main, and logs are recorded only when $not_static is 1. For more information about the if parameter, refer to the official documentation.
  • One thing to note is that when using the if parameter in access_log, you must explicitly specify a log_format, otherwise an error will be reported: nginx: [emerg] unknown log format "if=$not_static"

Another way to write dynamic and static separated logs

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|js|css|woff|ttf)$ {
  #access_log off; #Do not output the log of access to static resources access_log logs/static_resources.log;
}

This is the end of this article about the implementation of Nginx access log filtering of static resource files. For more relevant Nginx access log content, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Use nginx-http-concat module to merge static resource files in nginx
  • How to deploy nginx with Docker and modify the configuration file
  • Detailed explanation of how to find the location of the nginx configuration file
  • Solution to the unknown directive that cannot be opened due to Nginx configuration file problems
  • How to view nginx configuration file path and resource file path

<<:  Vue uses the video tag to implement video playback

>>:  MySQL uses the truncate command to quickly clear all tables in a database

Recommend

Html easily implements rounded rectangle

Question: How to achieve a rounded rectangle usin...

js development plug-in to achieve tab effect

This article example shares the specific code of ...

How to set up the use of Chinese input method in Ubuntu 18.04

In the latest version of Ubuntu, users no longer ...

Getting Started Tutorial for Beginners ⑨: How to Build a Portal Website

Moreover, an article website built with a blog pro...

More Features of the JavaScript Console

Table of contents Overview console.log console.in...

Use nexus as a private library to proxy docker to upload and download images

1. Nexus configuration 1. Create a docker proxy U...

MySQL database implements OLTP benchmark test based on sysbench

Sysbench is an excellent benchmark tool that can ...

Things to note when writing self-closing XHTML tags

The img tag in XHTML is so-called self-closing, w...

Detailed explanation of the role of explain in MySQL

1. MYSQL index Index: A data structure that helps...

React introduces antd-mobile+postcss to build mobile terminal

Install antd-mobile Global import npm install ant...

Optimal web page width and its compatible implementation method

1. When designing a web page, determining the widt...

HTML table markup tutorial (2): table border attributes BORDER

By default, the border of the table is 0, and we ...

How to set up FTP server in CentOS7

FTP is mainly used for file transfer, and is gene...