nginx常用的命令

常见的正则表达式

代码说明
^匹配搜索字符串开始位置
$匹配搜索字符串结束位置
.匹配除换行符\n之外的任何单个字符
\转义字符,将下一个字符标记为特殊字符
[xyz]字符集,与任意一个指定字符匹配
[a-z]字符范围,匹配指定范围内的任何字符
[^abc]表达式用于查找任何不在方括号之间的字符。
\w与以下任意字符匹配 A-Z a-z 0-9 和下划线,等效于[A-Za-z0-9_]
\d数字字符匹配,等效于[0-9]
{n}正好匹配n次
{n,}至少匹配n次
{n,m}匹配至少n次至多m次
  • | 零次或多次,等效于{0,}
  • | 一次或多次,等效于{1,}
    ? | 零次或一次,等效于{0,1}

全局块

user指令

用于配置运行Nginx服务器的worker进程的用户和用户组。
在这里插入图片描述

work process指令

master_process:用来指定是否开启工作进程。此命令生效必须先关闭nginx,再启动nginx.重启无效
在这里插入图片描述

worker_processes:用于配置Nginx生成工作进程的数量,这个是Nginx服务器实现并发处理服务的关键所在。理论上来说workder process的值越大,可以支持的并发处理量也越多,但事实上这个值的设定是需要受到来自服务器自身的限制,建议将该值和服务器CPU的内核数保存一致。
在这里插入图片描述

其它指令

daemon

daemon:设定Nginx是否以守护进程的方式启动。
守护式进程是linux后台执行的一种服务进程,特点是独立于控制终端,不会随着终端关闭而停止。
在这里插入图片描述

pid

pid:用来配置Nginx当前master进程的进程号ID存储的文件路径。
在这里插入图片描述

error_log

error_log:用来配置Nginx的错误日志存放路径
在这里插入图片描述
其中日志级别的值有:debug|info|notice|warn|error|crit|alert|emerg,翻译过来为试|信息|通知|警告|错误|临界|警报|紧急

include

include:用来引入其他配置文件,使Nginx的配置更加灵活
在这里插入图片描述

events块

accept_mutex

accept_mutex:用来设置Nginx网络连接序列化
在这里插入图片描述

这个配置主要可以用来解决常说的"惊群"问题。大致意思是在某一个时刻,客户端发来一个请求连接,Nginx后台是以多进程的工作模式,也就是说有多个worker进程会被同时唤醒,但是最终只会有一个进程可以获取到连接,如果每次唤醒的进程数目太多,就会影响Nginx的整体性能。如果将上述值设置为on(开启状态),将会对多个Nginx进程接收连接进行序列号,一个个来唤醒接收,就防止了多个进程对连接的争抢。

multi_accept

multi_accept:用来设置是否允许同时接收多个网络连接
在这里插入图片描述

如果multi_accept被禁止了,nginx一个工作进程只能同时接受一个新的连接。否则,一个工作进程可以同时接受所有的新连接。

worker_connections

worker_connections:用来配置单个worker进程最大的连接数
在这里插入图片描述

这里的连接数不仅仅包括和前端用户建立的连接数,而是包括所有可能的连接数。另外,number值不能大于操作系统支持打开的最大文件句柄数量。

use

use:用来设置Nginx服务器选择哪种事件驱动来处理网络消息。
在这里插入图片描述

注意:此处所选择事件处理模型是Nginx优化部分的一个重要内容,method的可选值有select/poll/epoll/kqueue等,之前在准备centos环境的时候,我们强调过要使用linux内核在2.6以上,就是为了能使用epoll函数来优化Nginx。

events指令配置实例

打开Nginx的配置文件 nginx.conf,添加如下配置

events{
accept_mutex on;
multi_accept on;
worker_commections 1024;
use epoll;
}

http块

定义MIME-Type

我们都知道浏览器中可以显示的内容有HTML、XML、GIF等种类繁多的文件、媒体等资源,浏览器为了区分这些资源,就需要使用MIMEType。所以说MIME Type是网络资源的媒体类型。Nginx作为web服务器,也需要能够识别前端请求的资源类型。

在Nginx的配置文件中,默认有两行配置

include mime.types;
default_type application/octet-stream;

default_type:用来配置Nginx响应前端请求默认的MIME类型。
在这里插入图片描述

在default_type之前还有一句include mime.types ,include之前我们已经介绍过,相当于把mime.types文件中MIMT类型与相关类型文件的文件后缀名的对应关系加入到当前的配置文件中。

举例来说明:

有些时候请求某些接口的时候需要返回指定的文本字符串或者json字符串,如果逻辑非常简单或者干脆是固定的字符串,那么可以使用nginx快速实现,这样就不用编写程序响应请求了,可以减少服务器资源占用并且响应性能非常快。

如何实现:

location /get_text {
#这里也可以设置成text/plain
default_type text/html;
return 200 "This is nginx's text";
}
location /get_json{
default_type application/json;
return 200 '{"name":"TOM","age":18}';
}

自定义服务日志

Nginx中日志的类型分access.log、error.log。
access.log:用来记录用户所有的访问请求。
error.log:记录nginx本身运行时的错误信息,不会记录用户的访问请求。
Nginx服务器支持对服务日志的格式、大小、输出等进行设置,需要使用到两个指令,分别是access_log和log_format指令。

access_log

access_log:用来设置用户访问日志的相关属性。
在这里插入图片描述

log_format

log_format:用来指定日志的输出格式。
在这里插入图片描述
配置实例

log_format main '$remote_addr - $request - $status-$request_uri  $http_user_agent';
access_log logs/access.log main;

其他配置指令

sendfile

sendfile:用来设置Nginx服务器是否使用sendfile()传输文件,该属性可以大大提高Nginx处理静态资源的性能
在这里插入图片描述

keepalive_timeout

keepalive_timeout:用来设置长连接的超时时间。
在这里插入图片描述
为什么要使用keepalive?

我们都知道HTTP是一种无状态协议,客户端向服务端发送一个TCP请求,服务端响应完毕后断开连接。
如何客户端向服务端发送多个请求,每个请求都需要重新创建一次连接,效率相对来说比较多,使用keepalive模式,可以告诉服务器端在处理完一个请求后保持这个TCP连接的打开状态,若接收到来自这个客户端的其他请求,服务端就会利用这个未被关闭的连接,而不需要重新创建一个新连接,提升效率,但是这个连接也不能一直保持,这样的话,连接如果过多,也会是服务端的性能下降,这个时候就需要我们进行设置其的超时时间。

keepalive_requests

keepalive_requests:用来设置一个keep-alive连接使用的次数。
在这里插入图片描述

server块

listen指令

listen:用来配置监听端口。
在这里插入图片描述

listen的设置比较灵活,我们通过几个例子来把常用的设置方式熟悉下:

listen 127.0.0.1:8000; // listen localhost:8000 监听指定的IP和端口
listen 127.0.0.1; 监听指定IP的所有端口
listen 8000; 监听指定端口上的连接
listen *:8000; 监听指定端口上的连接

default_server属性是标识符,用来将此虚拟主机设置成默认主机。所谓的默认主机指的是如果没有匹配到对应的address:port,则会默认执行的。如果不指定默认使用的是第一个server。

server{
listen 8080 default_server;
server_name localhost;
}

server_name指令

server_name:用来设置虚拟主机服务名称。
127.0.0.1 、 localhost 、域名[www.baidu.com | www.jd.com]
在这里插入图片描述
关于server_name的配置方式有三种,分别是:

  • 精确匹配
  • 通配符匹配
  • 正则表达式匹配

配置方式一:精确匹配

server {
	listen 80;
	server_name www.itcast.cn www.itheima.cn;
...
}

配置方式二:使用通配符配置
server_name中支持通配符"*",但需要注意的是通配符不能出现在域名的中间,只能出现在首段或尾段.如:

server {
	listen 80;
	server_name *.itcast.cn www.itheima.*;
}

下面的配置就会报错

server {
listen 80;
server_name www.*.cn www.itheima.c*
}

配置三:使用正则表达式配置
server_name中可以使用正则表达式,并且使用~ 作为正则表达式字符串的开始标记。

server{
	listen 80;
	server_name ~^www\.(\w+)\.com$;
	default_type text/plain;
	return 200 $1..;
}
注意 ~后面不能加空格,括号可以取值

由于server_name指令支持通配符和正则表达式,因此在包含多个虚拟主机的配置文件中,可能会出现一个名称被多个虚拟主机的server_name匹配成功,当遇到这种情况,当前的请求交给谁来处理呢?

  • No1:准确匹配server_name
  • No2:通配符在开始时匹配server_name成功
  • No3:通配符在结束时匹配server_name成功
  • No4:正则表达式匹配server_name成功
  • No5:被默认的default_server处理,如果没有指定默认找第一个server

error_page指令

error_page:设置网站的错误页面
在这里插入图片描述
当出现对应的响应code后,如何来处理。

举例说明:

(1)可以指定具体跳转的地址

server {
	error_page 404 http://www.itcast.cn;
}

(2)可以指定重定向地址

server{
	error_page 404 /50x.html;
	error_page 500 502 503 504 /50x.html;
	location =/50x.html{
		root html;
	}
}

(3)使用location的@符合完成错误信息展示

server{
	error_page 404 @jump_to_error;
	location @jump_to_error {
		default_type text/plain;
		return 404 'Not Found Page...';
	}
}

可选项=[response] 的作用是用来将相应代码更改为另外一个

server{
	error_page 404 =200 /50x.html;
	location =/50x.html{
		root html;
	}
}
这样的话,当返回404找不到对应的资源的时候,在浏览器上可以看到,最终返回的状态码是200,这块需要注意下,
编写error_page后面的内容,404后面需要加空格,200前面不能加空格

location块

location指令

location指令的作用是根据用户请求的URI来执行不同的应用,也就是根据用户请求的网站URL进行配,匹配成功即进行相关的操作。
在这里插入图片描述

匹配符匹配规则优先级
=精确匹配1
^~以某个字符串开头2
~区分大小写的正则匹配3
~*不区分大小写的正则匹配4
!~区分大小写不匹配的正则5
!~*不区分大小写不匹配的正则6
/通用匹配,任何请求都会匹配到7
uri变量是待匹配的请求字符串,可以不包含正则表达式,也可以包含正则表达式,那么nginx服务器在搜索匹配location的时候,是先使用不包含正则表达式进行匹配,找到一个匹配度最高的一个,然后在通过包含正则表达式的进行匹配,如果能匹配到直接访问,匹配不到,就使用刚才匹配度最高的那个location来处理请求。
location /abc
location =/abc
location ~^/abc\w$ #匹配abc开头,后面还有一个字符结尾的区分大小写
location ~*/abc\w$ #匹配以abc+一个字符结尾的不区分大小写,没加^所以不一定要开始位置匹配
location ^~/abc #这个效果跟/abc是一样的。

root / alias

root:设置请求的根目录
path为Nginx服务器接收到请求以后查找资源的根目录路径。
在这里插入图片描述
alias:用来更改location的URI
在这里插入图片描述
path为修改后的根路径。

以上两个指令都可以来指定访问资源的路径,那么这两者之间的区别是什么?
root的处理结果是: root路径+location路径
alias的处理结果是:使用alias路径替换location路径
alias是一个目录别名的定义,root则是最上层目录的含义。
如果location路径是以/结尾,则alias也必须是以/结尾,root没有要求

index指令

index:设置网站的默认首页
在这里插入图片描述
index后面可以跟多个设置,如果访问的时候没有指定具体访问的资源,则会依次进行查找,找到第一个为止。

location / {
	root /usr/local/nginx/html;
	index index.html index.htm;
}
访问该location的时候,可以通过 http://ip:port/,地址后面如果不添加任何内容,则默认依次访问index.html和index.htm,找到第一个来进行返回

add_header指令

add_header指令是用来添加指定的响应头和响应值。
在这里插入图片描述

其它功能相关指令

Rewrite相关指令

Rewrite是Nginx服务器提供的一个重要基本功能,是Web服务器产品中几乎必备的功能。主要的作用是用来实现URL的重写。注意:Nginx服务器的Rewrite功能的实现依赖于PCRE的支持,因此在编译安装Nginx服务器之前,需要安装PCRE库。Nginx使用的是ngx_http_rewrite_module模块来解析和处理Rewrite功能的相关配置。

重写和转发的区别:
地址重写浏览器地址会发生变化而地址转发则不变
一次地址重写会产生两次请求而一次地址转发只会产生一次请求
地址重写到的页面必须是一个完整的路径而地址转发则不需要
地址重写因为是两次请求所以request范围内属性不能传递给新页面而地
址转发因为是一次请求所以可以传递值
地址转发速度快于地址重写

set指令

set指令用来设置一个新的变量。
在这里插入图片描述
variable:变量的名称,该变量名称要用"$"作为变量的第一个字符,且不能与Nginx服务器预设的全局变量同名。
value:变量的值,可以是字符串、其他变量或者变量的组合等。

Rewrite全局变量

变量含义
$args这个变量等于请求行中的参数,同$query_string
$content length请求头中的Content-length字段。
$content_type请求头中的Content-Type字段。
$document_root当前请求在root指令中指定的值。
$host请求主机头字段,否则为服务器名称。
$http_user_agent客户端agent信息
$http_cookie客户端cookie信息
$limit_rate这个变量可以限制连接速率。
$request_method客户端请求的动作,通常为GET或POST。
$remote_addr客户端的IP地址。
$remote_port客户端的端口。
$remote_user已经经过Auth Basic Module验证的用户名。
$request_filename当前请求的文件路径,由root或alias指令与URI请求生成。
$schemeHTTP方法(如http,https)。
$server_protocol请求使用的协议,通常是HTTP/1.0或HTTP/1.1。
$server_addr服务器地址,在完成一次系统调用后可以确定这个值。
$server_name服务器名称。
$server_port请求到达服务器的端口号。
$request_uri包含请求参数的原始URI,不包含主机名,如”/foo/bar.php?arg=baz”。
$uri不带请求参数的当前URI,$uri不包含主机名,如”/foo/bar.html”。
$document_uri与$uri相同。

if指令

if指令用来支持条件判断,并根据条件判断结果选择不同的Nginx配置。
在这里插入图片描述
condition为判定条件,可以支持以下写法:
(1)变量名。如果变量名对应的值为空字符串或"0",if都判断为false,其他条件为true。

if ($param){
}

注意if跟前括号之间要有空格

(2)使用"=“和”!="比较变量和字符串是否相等,满足条件为true,不满足为false

if ($request_method = POST){
	return 405;
}

注意:此处和Java不太一样的地方是字符串不需要添加引号,并且等号和不等号前后到需要加空格。

(3)使用正则表达式对变量进行匹配,匹配成功返回true,否则返回false。变量与正则表达式之间使用
在这里插入图片描述来连接。

if ($http_user_agent ~ MSIE){
	#$http_user_agent的值中是否包含MSIE字符串,如果包含返回
	true
}

注意:正则表达式字符串一般不需要加引号,但是如果字符串中包
含"}“或者是”;"等字符时,就需要把引号加上。

(4)判断请求的文件是否存在使用"-f"和"!-f"

if (-f $request_filename){
	#判断请求的文件是否存在
}
if (!-f $request_filename){
	#判断请求的文件是否不存在
}

(5)判断请求的目录是否存在使用"-d"和"!-d"
(6)判断请求的目录或者文件是否存在使用"-e"和"!-e"
(7)判断请求的文件是否可执行使用"-x"和"!-x"

break指令

该指令用于中断当前相同作用域中的其他Nginx配置。与该指令处于同一作用域的Nginx配置中,位于它前面的指令配置生效,位于后面的指令配置无效。并且break还有另外一个功能就是终止当前的匹配并把当前的URI在本location进行重定向访问处理。
在这里插入图片描述

return指令

该指令用于完成对请求的处理,直接向客户端返回。在return后的所有Nginx配置都是无效的。
在这里插入图片描述
code:为返回给客户端的HTTP状态代理。可以返回的状态代码为0~999的任意HTTP状态代理
text:为返回给客户端的响应体内容,支持变量的使用
URL:为返回给客户端的URL地址

location 1 /testreturn {
	return 200 success;
}
location /testreturn {
	return https://www.baidu.com; // 302重定向到百度
}
location /testreturn {
	return 302 https://www.baidu.com;
}
location /testreturn {
	return 302 www.baidu.com;//不允许这么写
}

rewrite指令

该指令通过正则表达式的使用来改变URI。可以同时存在一个或者多个指令,按照顺序依次对URL进行匹配和处理。
在这里插入图片描述
regex:用来匹配URI的正则表达式
replacement:匹配成功后,用于替换URI中被截取内容的字符串。如果该字符串是以"http://"或者"https://"开头的,则不会继续向下对URI进行其他处理,而是直接返回重写后的URI给客户端。

location /rewrite {
	rewrite ^/rewrite/url\w*$ https://www.baidu.com;
	rewrite ^/rewrite/(test)\w*$ /$1;
	rewrite ^/rewrite/(demo)\w*$ /$1;
}
location /test{
	default_type text/plain;
	return 200 test_success;
}
location /demo{
	default_type text/plain;
	return 200 demo_success;
}

flag:用来设置rewrite对URI的处理行为,可选值有如下:

  • last:终止继续在本location块中处理接收到的URI,并将此处重写的URI作为一个新的URI,使用各location块进行处理。该标志将重写后的URI重写在server块中执行,为重写后的URI提供了转入到其他location块的机会。

    location /rewrite {
    	rewrite ^/rewrite/(test)\w*$ /$1 last;
    	rewrite ^/rewrite/(demo)\w*$ /$1 last;
    }
    location /test{
    	default_type text/plain;
    	return 200 test_success;
    }
    location /demo{
    	default_type text/plain;
    	return 200 demo_success;
    }
    

    访问 http://192.168.200.133:8081/rewrite/testabc ,能正确访问
    在这里插入图片描述

  • break:将此处重写的URI作为一个新的URI,在本块中继续进行处理。该标志将重写后的地址在当前的location块中执行,不会将新的URI转向其他的location块。

    location /rewrite {
    	rewrite ^/rewrite/(test)\w*$ /$1 break;
    	rewrite ^/rewrite/(demo)\w*$ /$1 break;
    }
    location /test{
    	default_type text/plain;
    	return 200 test_success;
    }
    location /demo{
    	default_type text/plain;
    	return 200 demo_success;
    }
    

    访问 http://192.168.200.133:8081/rewrite/demoabc ,页面报404错误
    在这里插入图片描述
    原因是因为会在本location块处理,不会再去找/demo的location块了,而本location块如果不指定默认是去html文件夹下+重写后的路径去寻找资源。上述案例默认重写的路径就是(/test|/demo);就会去html文件夹下寻找test/demo;切记test和demo必须是文件,不能是文件夹否则会连接超时

  • redirect:将重写后的URI返回给客户端,状态码为302,指明是临时重定向URI,主要用在replacement变量不是以"http://"或者"https://"开头的情况。

  • permanent:将重写后的URI返回给客户端,状态码为301,指明是永久重定向URI,主要用在replacement变量不是以"http://"或者"https://"开头的情况。

rewrite_log指令

rewrite_log指令配置是否开启URL重写日志的输出功能。
在这里插入图片描述
开启后,URL重写的相关日志将以notice级别输出到error_log指令配置的日志文件汇总。

rewrite_log on;
error_log logs/error.log notice;

反向代理的配置指令

proxy_pass

该指令用来设置被代理服务器地址,可以是主机名称、IP地址加端口号形式。
在这里插入图片描述
URL:为要设置的被代理服务器地址,包含传输协议( http , https:// )、主机名称或IP地址加端口号、URI等要素。

在编写proxy_pass的时候,后面的值要不要加"/"?

server {
	listen 80;
	server_name localhost;
	location /{
		#proxy_pass http://192.168.200.146;
		proxy_pass http://192.168.200.146/;
	}
}
当客户端访问 http://localhost/index.html,效果是一样的

server{
	listen 80;
	server_name localhost;
	location /server{
		#proxy_pass http://192.168.200.146;
		proxy_pass http://192.168.200.146/;
	}
}
当客户端访问 http://localhost/server/index.html 这个时候,
第一个proxy_pass就变成了http://localhost/server/index.html
第二个proxy_pass就变成了http://localhost/index.html效果就不一样了。

proxy_set_header

该指令可以更改Nginx服务器接收到的客户端请求的请求头信息,然后将新的请求头发送给代理的服务器
在这里插入图片描述
需要注意的是,如果想要看到结果,必须在被代理的服务器上来获取添加的头信息。

被代理服务器: [192.168.200.146]

server {
	listen 8080;
	server_name localhost;
	default_type text/plain;
	return 200 $http_username;
}

代理服务器: [192.168.200.133]

server {
	listen 8080;
	server_name localhost;
	location /server {
		proxy_pass http://192.168.200.146:8080/;
		proxy_set_header username TOM;
	}
}

proxy_redirect

该指令是用来重置头信息中的"Location"和"Refresh"的值。
在这里插入图片描述
proxy_redirect redirect replacement;

redirect:目标,Location的值
replacement:要替换的值

proxy_redirect default;

default;
将location块的uri变量作为replacement,
将proxy_pass变量作为redirect进行替换

proxy_redirect off;

关闭proxy_redirect的功能

负载均衡相关的指令

upstream指令

该指令是用来定义一组服务器,它们可以是监听不同端口的服务器,并且也可以是同时监听TCP和Unix socket的服务器。服务器可以指定不同的权重,默认为1。
在这里插入图片描述

server指令

该指令用来指定后端服务器的名称和一些参数,可以使用域名、IP、端口或者unix socket
在这里插入图片描述

upstream backend{
        server 192.168.50.206:9001;
        server 192.168.50.206:9002;
        server 192.168.50.206:9003;
}
server {
	listen 8083;
	server_name localhost;
	location / {
			proxy_pass http://backend/;
	}
}

负载均衡状态

代理服务器在负责均衡调度中的状态有以下几个:

状态概述
down当前的server暂时不参与负载均衡
backup预留的备份服务器
max_fails允许请求失败的次数
fail_timeout经过max_fails失败后, 服务暂停时间
max_conns限制最大的接收连接数
down

down:将该服务器标记为永久不可用,那么该代理服务器将不参与负载均衡。该状态一般会对需要停机维护的服务器进行设置。

upstream backend{
	server 192.168.200.146:9001 down;
	server 192.168.200.146:9002
	server 192.168.200.146:9003;
}
backup

backup:将该服务器标记为备份服务器,当主服务器不可用时,将用来传递请求。

upstream backend{
	server 192.168.200.146:9001 down;
	server 192.168.200.146:9002 backup;
	server 192.168.200.146:9003;
}
max_conns

max_conns=number:用来设置代理服务器同时活动链接的最大数量,默认为0,表示不限制,使用该配置可以根据后端服务器处理请求的并发量来进行设置,防止后端服务器被压垮。

max_fails和fail_timeout

max_fails=number:设置允许请求代理服务器失败的次数,默认为1。
fail_timeout=time:设置经过max_fails失败后,服务暂停的时间,默认是10秒。

upstream backend{
	server 192.168.200.133:9001 down;
	server 192.168.200.133:9002 backup;
	server 192.168.200.133:9003 max_fails=3 fail_timeout=15;
}
  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值