Directive and ContextBy default, the nginx configuration file can be located in: The location of the configuration file will vary depending on the installation procedure of Nginx. This file has the following content: DirectiveConfiguration options in Nginx are known as directives. This option has name and parameters, and this must end with a semicolon (;) otherwise Nginx will fail to load the configuration and produce an error. Example: ContextWhen we open the core Nginx configuration file in a text editor, the very first thing we will notice that the configurations are organized in a tree-like structure surrounded by curly braces i.e. "{" and "}". These locations surrounded by braces is called context for placing configuration directive. Moreover, the configuration directives along with their parameters, end with a semicolon. This is the section where we can declare directives. It is similar to the scope in a programming language. Context can be nested within other contexts, thereby creating a context hierarchy. Example: The lines padded by # are comments and not interpreted by Nginx. Directive TypesSince the inheritance model differs for different directives, therefore, we have to pay attention when using the same directive in multiple contexts. There is a total of three types of directives, each with its inheritance model. NormalIt has one value per context. And we can define it only once in the context. Subcontexts can override the parent directive, but this override will be valid only in a given subcontext. ArrayAdding too many directives in the same context will add to the values instead of overwriting them altogether. Defining a directive in a subcontext will override all the values of a parent in the given subcontext. Action DirectiveActions are directives that are used to change things. Their behavior of inheritance will depend on the module. For example: In the rewrite directive case, every matching directive will be executed. If we try to fetch /sample:
Let's see a different behavior then what the return directive provides: From the above case, the 200 status is returned immediately. Type of ContextLet's see an example. From the above example, we can see that the HTTP context declares settings for HTTP protocol. Virtual host settings are declared in the server context and also contained in the http context. Locations contexts that are used to store URLs settings are contained within a server context. Main ContextThe most general context is the main context. It is also called the global context. The main context sets the settings for Nginx globally, and is the only context that is not contained within the typical context blocks and that is not surrounded by curly braces. The main context is placed at the beginning of the core Nginx configuration file. The directives for this context cannot be inherited in any other context and therefore can't be overridden. The main context is used to configure details that affect the entire application on a basic level. Some common details that are configured in the main context are the user and group to run the worker processes as, the total number of workers, and the file to save the main process ID. The default error file for the entire application can be set at the main context level. Events ContextThe events context sets global options for connection processing. The events context is contained within the main context. There can be only one event context defined within Nginx configuration. Nginx uses an event-based connection processing model, so the directive defined within this context determines how worker processes should handle connections. HTTP ContextThe HTTP context is used to hold the directives for handling HTTP or HTTPS traffic. The HTTP context is a sibling of the context of the event, so they must be listed side-by-side, rather than nested. They both are the child of the main context. Lower contexts handle the request, and the directives at this level control the defined defaults for every virtual server. Server ContextThe server context is declared within the http context. The server context is used to define the Nginx virtual host settings. There can be multiple server contexts inside the HTTP context. The directives inside the server context handle the processing of requests for resources associated with a particular domain or IP address. The directives in this context can override many of the directives that may be defined in the http context, including the document root, logging, compression, etc. In addition to the directives that are taken from the http context, we can also configure files to try to respond to requests, issue redirects, and rewrites, and set arbitrary variables. Location ContextLocation contexts define directives to handle the request of the client. When any request for resource arrives at Nginx, it will try to match the URI (Uniform Resource Identifier) to one of the locations and handle it accordingly. Multiple location contexts can be defined within the server blocks. Moreover, a location context can also be nested inside another location context. Upstream ContextThe upstream context is used to configure and define an upstream server. This context is allowed to define a pool of backend servers that Nginx can proxy the used when request. This context is usually we are configuring proxies of various types. Upstream context enables Nginx to perform load balancing while proxying the request. This context is defined inside the HTTP context and outside any server context. The upstream context is referenced by name within server or location blocks. And then pass the requests of a certain type to the pool of defined servers. The upstream will then use an algorithm (by default round-robin) to determine which specific server need to be used to handle the request. Mail ContextAlthough Nginx is most often used as a web or reverse proxy server, it can also be used as a high-performance mail proxy server. The context that is used for this type of directives is called the mail context. The mail context is defined inside the main or global context or outside of the http context. The main purpose of the mail context is to provide an area for configuring a mail proxying solution on the server. Nginx can redirect authentication requests to an external authentication server. It can then provide access to POP3, SMTP, and IMAP mail servers for serving the actual mail data. In general, a mail context will look like this: If contextThe if context is used to allow conditional execution of directives defined within it. If the context is just like "if statement" of any other programming languages. The if context will execute the contained instructions if a given condition returns true. The if context should be avoided as far as possible due to some limitations of it. Use this link to know more about why nginx should be avoided, which is discussed here. Limit_except contextThe limit_except context is used to prevent the use of all HTTP methods within the location context except the ones that we explicitly allow. For example, if certain clients should have access to POST content and everyone should have the ability to read the content, then we can use limit_except context for this. The above example allows all the visitors to use the GET header in the location /wp-admin. The other HTTP headers are permitted if it is originated from local addresses only. Miscellaneous ContextsApart from the above contexts, there are few other contexts available in Nginx and are described below. These contexts are dependent on optional modules and are used very rarely.
Next TopicHTTP Health Checks |