Which nginx variable does location match?
$request_uri
What are the matching types of location?
=
starts with Indicates an exact match starting with
^~
. Note that this is not a regular expression (it is a string match with increased priority) – its purpose is to take precedence over regular expression matching. If the location is the best match, regular expression detection is no longer performed.
~ The beginning of
indicates case-sensitive regular matching;
~* The beginning of
indicates case-insensitive regular matching
!~ && !~*
: Indicates case-sensitive non-matching regular and case-insensitive non-matching regular
String matching
/Universal matching, if there is no other match, any request will match
location search order
Exact match first =
Secondly match ^~
Then perform regular matching according to the order of the configuration file
Finally, hand it over to/for general matching
Note:
When a match is successful, the matching will be stopped immediately and the request will be processed according to the current matching rules.
Special note: String matching will be searched first, but only the most recent will be recorded. Long match, and then continue to search for regular matches. If there is a regular match, the regular match is hit. If there is no regular match, the longest string match is hit. (If ^~ is the longest match, it will hit directly and stop searching for regular expressions)
Exact match
location = /images/test.png { echo 'config1'; } location /images/test.png { echo 'config2'; } location \/images\/test\.png$ { echo 'config3'; }
If requested at this timehttp:/ /127.0.0.1/images/test.png
What will be output?
Output config1
, there is no doubt that exact matching has the highest priority!
Special case of exact matching
location = / { index index.html; } location / { echo 'config2'; }
At this time, what will be output if http://127.0.0.1
is entered?
is the output of config2. Why does the exact matching priority not work?
Yes, exact matching still works. When requesting a directory (not a specific file), nginx will internally direct the request to the index file.
The real request at this time is http://127.0.0.1/index.html
, this is config2
and it is hit!
, so exact matching should not be used to match /
characters String search and regular search
location /images/test.png { echo 'config1'; } location ^~ /images/ { echo 'config2'; } location ~ \/images\/test\.png$ { echo 'config3'; } location ~ \/images\/ { echo 'config4'; }
If you request http://127.0.0.1/images/test.png
at this time, what will be output?
is of course config3
, and the regular pattern hits
(although config1 is the longest matching string, only recording is done at this time, and the regular matching must be searched later, then config3 Regular match hits),
If you look carefully, you can find that config4 is also matched successfully, but the regular matching order is matched according to the definition order of location, so config3 hits the .
character Improvement of string matching priority (^~)
location /images/ { echo 'config1'; } location ^~ /images/test.png { echo 'config2'; } location ~ /images/test\.png$ { echo 'config3'; } location ~ \/images\/ { echo 'config4'; }
If you request http://127.0.0.1/images/test.png
at this time, what will be output?
is of course config2
, the first match hits
(because string matching is searched first, at this time it is found that config2 is the longest string match and is ^~ Matching method, so stop searching for regular expressions and hit directly!)
So the ^~
symbols here are special, in order to increase the priority of string matching and take precedence over regular matching.
Related recommendations: "Nginx Tutorial"
The above is the detailed content of Detailed explanation of nginx location directive. For more information, please follow other related articles on the PHP Chinese website!

NGINXserveswebcontentandactsasareverseproxy,loadbalancer,andmore.1)ItefficientlyservesstaticcontentlikeHTMLandimages.2)Itfunctionsasareverseproxyandloadbalancer,distributingtrafficacrossservers.3)NGINXenhancesperformancethroughcaching.4)Itofferssecur

NGINXUnit simplifies application deployment with dynamic configuration and multilingual support. 1) Dynamic configuration can be modified without restarting the server. 2) Supports multiple programming languages, such as Python, PHP, and Java. 3) Adopt asynchronous non-blocking I/O model to improve high concurrency processing performance.

NGINX initially solved the C10K problem and has now developed into an all-rounder who handles load balancing, reverse proxying and API gateways. 1) It is well-known for event-driven and non-blocking architectures and is suitable for high concurrency. 2) NGINX can be used as an HTTP and reverse proxy server, supporting IMAP/POP3. 3) Its working principle is based on event-driven and asynchronous I/O models, improving performance. 4) Basic usage includes configuring virtual hosts and load balancing, and advanced usage involves complex load balancing and caching strategies. 5) Common errors include configuration syntax errors and permission issues, and debugging skills include using nginx-t command and stub_status module. 6) Performance optimization suggestions include adjusting worker parameters, using gzip compression and

Diagnosis and solutions for common errors of Nginx include: 1. View log files, 2. Adjust configuration files, 3. Optimize performance. By analyzing logs, adjusting timeout settings and optimizing cache and load balancing, errors such as 404, 502, 504 can be effectively resolved to improve website stability and performance.

NGINXUnitischosenfordeployingapplicationsduetoitsflexibility,easeofuse,andabilitytohandledynamicapplications.1)ItsupportsmultipleprogramminglanguageslikePython,PHP,Node.js,andJava.2)Itallowsdynamicreconfigurationwithoutdowntime.3)ItusesJSONforconfigu

NGINX can be used to serve files and manage traffic. 1) Configure NGINX service static files: define the listening port and file directory. 2) Implement load balancing and traffic management: Use upstream module and cache policies to optimize performance.

NGINX is suitable for handling high concurrency and static content, while Apache is suitable for dynamic content and complex URL rewrites. 1.NGINX adopts an event-driven model, suitable for high concurrency. 2. Apache uses process or thread model, which is suitable for dynamic content. 3. NGINX configuration is simple, Apache configuration is complex but more flexible.

NGINX and Apache each have their own advantages, and the choice depends on the specific needs. 1.NGINX is suitable for high concurrency, with simple deployment, and configuration examples include virtual hosts and reverse proxy. 2. Apache is suitable for complex configurations and is equally simple to deploy. Configuration examples include virtual hosts and URL rewrites.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Dreamweaver Mac version
Visual web development tools

Dreamweaver CS6
Visual web development tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.
