Windows 服务器Nginx 下载、部署、配置流程(图文教程)

不定期更新

目录

一、下载Nginx安装包

二、上传安装包

三、启动Nginx

四、Nginx常用命令

五、Nginx(最小)配置详解

 六、Nginx(基础)配置详解

七、反向代理

八、负载均衡

九、动静分离

十、报错


 

一、下载Nginx安装包

四个网址,根据自己的情况选择,我是用Nginx开源版的。

1、下载网址

1)Nginx开源版

nginx newshttp://nginx.org/

2)Openresty

OpenResty® - 开源官方站https://openresty.org/cn/

3)Tengine

Tengine Web 服务器 (taobao.org)https://tengine.taobao.org/

4)Nginx plus 商业版(收费)

F5 | 多云安全和应用交付https://www.f5.com.cn/

2、下载

在Nginx开源版选择对应系统下载nginx安装包

20fbb724ad794a769dbb9d9497db6e49.png

e5d7d92c0ed44fdfafddd4974071b387.png

二、上传安装包

将下载的Nginx安装包上传到Windows虚拟机中并解压到想安装的路径,我就直接在桌面操作了

如果没有Windows Server 虚拟机的,可以看一下这一篇安装一个。
VMware Windows Server 虚拟机安装 详细教程_vmware安装windows server-CSDN博客https://blog.csdn.net/weixin_68547003/article/details/135177616
常用目录结构
1、 conf
存放相关配置文件
2、html
存放静态文件的默认目录 html、css等
3、logs
存放Nginx相关日志

9e898ede4447453aa42a8b5c636a1466.png

三、启动Nginx

1、双击nginx.exe启动

双击后窗口会一闪而过。b41c394d120b4d8fa2f8979e86dae4e5.png

2、查看是否启动成功

77712dbe4ba6434f8d41735b4a82bde1.png

13ec53cbdf424891a39c64d0624087b3.png

3、访问默认页面确认

先查看服务器ip

dac4036241ea416b81c534a1ede0c734.png

5034d3fc285440efb4adea1e1f5df8a3.png

2613001b9222465b90b7a1bb9e583661.png

打开服务器浏览器访问ip地址,默认端口是80,可以不用写。直访问ip,出现下图界面,则表示已经成功启动。

ccbd552ac4c94bf48433f43c20726253.png

4、防火墙配置

在自己电脑访问,要么关闭防火墙,要么开通80端口访问权限,下面是允许通过80端口权限添加操作流程,后面增加端口也是这么配置的相对应的策略。

baf0527c11574fb18045a4e18268c4ab.png

也可以通过控制面板→系统和安全→Windows防火墙→高级设置流程。

4c2ee324898c4c74ae9f660608d2ef48.png

添加入站规则

86b0f254c57e44c0a3096301d152af1e.png

允许通过80端口访问

cf6db22b5d494f889b773be2e6602cec.png

ea6db3072fc0464fa20073b602e2e17d.png

1e8d125e7d4b4346b8ec354ab0317181.png

4c520c9c97e84875acbc5be1aa635e1f.png

添加完成后,在自己电脑访问服务器ip,出现下图界面表示成功。

d0877758c6c34dfba515bee88fc3a59a.png

 

四、Nginx常用命令

Nginx常用命令
命令说明
start nginx 启动nginx
nginx -s stop停用Nginx
nginx -s quit 停用Nginx(处理完正在进行中请求后停用)
nginx -t验证新的配置是否正确
nginx -s reload重新加载配置,并重启进程
nginx -s reopen重启日志文件
nginx -h查看帮助信息
nginx -v查看Nginx版本
taskkill /f /t /im nginx.exe彻底关闭nginx(关闭nginx其他服务,这样才能彻底关闭)

 

 

 

 

 

 

 

 

 

 

 

 

演示:

在nginx文件夹上的路径直接输入cmd然后回车,打开命令窗口,或者通过其他方法打开命令窗口,然后到nginx文件夹路径下

3efad193846f4f27bff76d2c4f076ca0.png
   ee61711fa8404005b9f36fe4007aa5b1.png

命令启动并查看版本信息

6f74de3d40ce488781357765605a5cee.png

 

五、Nginx(最小)配置详解

Nginx配置文件是nginx文件夹路径下的 conf中的 nginx.conf
可以先将该配置文件复制备份,防止后面写错了,还能对照格式修改回来。

c60ff12e3bde47fa833aca5c2fab0f23.png

这是一个nginx最常规的配置代码,替换掉原nginx.conf的代码,重启nginx或重新nginx加载配置,去浏览器访问,也能访问到默认页面。


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#vhost虚拟主机server {#监听端口号listen       80;#主机名\域名server_name  localhost;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#文件根目录,相对于nginx安装根目录路径root   html;#默认页名称,访问先到访页面index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

替换测试

#重新加载配置命令
nginx -s reload


6c7191d7b80e4e41b5283521ab5b85a4.png

访问IP地址,也能成功访问
   33ee65183c974850938b00aa7c98cdce.png

 

 

 六、Nginx(基础)配置详解

1、域名解析

域名解析是为了后面 ,进行域名配置时 ,进行练习。

1)购买域名解析(要花点钱)

建议用这个,可以熟悉一下,后面自己有服务器了,也还可以用,不想花钱的,可以选下面第2个

域名注册_域名查询_域名申请_域名购买_域名续费_国际域名-万网-阿里云品牌 (aliyun.com)https://wanwang.aliyun.com/domain/?spm=5176.100251.111252.18.1cb84f15FEfsCm在阿里云官网购买一个域名注册(购买要实名认证的)

a976b070079d4c7eacb49727bfd108fe.png

选一个便宜的购买就行,购买后一年有效期。

2b067409a74f4c2dad7158b402da7981.png购买后到域名控制台配置

c0d3127d17374b3292ea2ffe713a1586.png

5d1e83a5f07d483681e20d181ecfbe50.png

b5abd652dff34785a4f2dcb861440681.png

 

050d0b6ceedd4eca91d7af64b0b047c3.png

 

测试是否成功,ping一下域名。因为是虚拟机,只有在自己电脑上才能ping到,想在互联上访问,就要购买一个服务器,用服务器ip做域名解析。

如果ping不到,可能是防火墙拦截了,记得关一下防火墙

650da47598ab46498d37871e2bb68af3.png

解析后也能直接通过域名访问网页了。如果端口不是80,要在域名后加上端口号

3a2d4d58b83e4a77838fd066e8b9d21b.png

2)自己电脑配置hosts解析(免费)

因为是虚拟机,所以解析后只能在自己电脑上访问。

在自己电脑c盘上搜索hosts,找到并到该路径下。

#一般都在这路径下
C:\Windows\System32\drivers\etc

b0cb42a2a19446449998b16ee5b3284b.png

73ad69de9e214ec99ed7c289ab2fef1f.png

在桌面编辑保存后,并复制粘贴替换到原路径上的文件。这个只能匹配对应的前缀+域名,练习完后可把该文件加的解析删了。

0c33ddb7089c4801b489572fe5b286bb.png

5fc1cd9ff25a4021b29f5b8e0587c5c6.png

打开命令窗口,ping一下,看能不能通。

 

2、同一IP用不同端口访问不同页面

1)桌面新建两个文件夹

这两个文件用来放两个不同html页面

c79eb7e1051848398b3fe537003cb6b1.png

2)创建html文件

在新的两个文件夹中,都新建一个文本文档,然后将名称和后缀改成index.html,右键编辑,随便在里面写点什么,能区分两个页面就行

#www
Hello Wlorld!1-1#web
Hello Wlorld!2-2

9e1a76a7bebd467e8fc777891ac6ccdd.png

613b4bb9b3ad4845a89a3a4c9c7863c2.png

3)nginx.conf代码

自行跟上面的常规配置对比,主要多了一个虚拟主机server代码,给了888和899端口,修改了匹配展示页面的路径。

baeeeba9c37146af843f03f7f1f00be5.png


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#vhost虚拟主机-1server {#监听端口号listen       888;#主机名\域名server_name  localhost;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#文件根目录,相对于nginx安装根目录路径root   C:/Users/Administrator/Desktop/web;#默认页名称,访问先到访页面index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}#vhost虚拟主机-2server {#监听端口号listen       899;#主机名\域名server_name  localhost;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#文件根目录,相对于nginx安装根目录路径root   C:/Users/Administrator/Desktop/www;#默认页名称,访问先到访页面index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

4)重启

把代码加进配置文件中,在nginx安装路径下执行nginx -t 命令测试配置是否生效,。看不懂英文的,翻译软件翻译一下,提示正确,重新加载配置。

#。测试配置是否正确,实际环境中都会先测试一下,再重启弎或重新加载配置
nginx -t
#重新加载配置
nginx -s reload

090094eef58a4def846fccf889b6dbdf.png

5)访问地址测试

IP后面加端口,ip:888,ip:899。

注意防火墙,开通一下端口,要么直接关闭防火墙。这为了方便就直接关闭防火墙了。

b7b9eb45682b4c03837cabb3ab59c1c7.png

35c42c9d683449c3804f9b3ee2e956f2.png

 

3、同一IP同一端口用不同域名访问不同页面

1)html页面文件夹还是用上面那两个

 

2)nginx.conf代码

端口号改回80,更改域名,根据域名前缀来匹配。

也可不更改端口,域名后加上端口,即可访问。

17d8f7ac3496467eb8f1e6e25608f6ac.png


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#vhost虚拟主机-1server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  www.lingran.website;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#文件根目录,相对于nginx安装根目录路径root   C:/Users/Administrator/Desktop/www;#默认页名称,访问先到访页面index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}#vhost虚拟主机-2server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  aaa.lingran.website;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#文件根目录,相对于nginx安装根目录路径root   C:/Users/Administrator/Desktop/web;#默认页名称,访问先到访页面index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

3)重启

把代码加进配置文件中,在nginx安装路径下执行nginx -t 命令测试配置是否生效。看不懂英文的,翻译软件翻译一下,提示正确,重新加载配置。

#。测试配置是否正确,实际环境中都会先测试一下,再重启弎或重新加载配置
nginx -t
#重新加载配置
nginx -s reload

b43e4ca442564580890e96a24fbf114d.png

4)访问地址测试

域名直接访问,端口如果不是80要加上端口号。

因为配置域名解析的时候是配置解析全部的,所以除了第二个vhost虚拟主机-2的配置的aaa.lingran.website域名会到第二个页面,其他的域名默认到第一个页面即vhost虚拟主机-1的页面。

如果想其他域名默认到vhost虚拟主机-2的页面,可将域名改为通配符 *.lingran.website ,。这样除了www.lingran.website会到vhost虚拟主机-1的页面,其他的都到vhost虚拟主机-2的页面。

匹配为顺序精准匹配→域名后缀通配符匹配→域名前缀通配符匹配→正则匹配,匹配到则停止

8a556204b40c421399d8e75872cfbe28.png

ad2488a950494c6aa469d4964da450e1.png

7581d52682a84256a8f535ce93819cce.png

七、反向代理

1、概念

反向代理的代理服务器在服务端,请求是被动的被代理了。反向代理客户端看不到真正的业务服务器。

1c9794c5e0884a509a80a5130b750a2c.png

正向代理的代理服务器在客户端,请求是主动要求被代理的。正向代理服务器看不到真正的客户端。
6528ab1395a7482091af04644d7e6c63.png

2、反向代理nginx.conf代码配置

proxy_pass配置,代理b站和百度这两个网址。

ac1328c4f2f1496a885431cc3afa8cb7.png

nginx.conf代码


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#vhost虚拟主机-1server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  www.lingran.website;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#proxy_pass代理其它域名网址,proxy_pass和root只能二选一。proxy_pass https://www.bilibili.com;#文件根目录,相对于nginx安装根目录路径#root   C:/Users/Administrator/Desktop/www;#默认页名称,访问先到访页面#index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}#vhost虚拟主机-2server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  aaa.lingran.website;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#proxy_pass代理其它域名网址,proxy_pass和root只能二选一。proxy_pass https://www.baidu.com;#文件根目录,相对于nginx安装根目录路径#root   C:/Users/Administrator/Desktop/www;#默认页名称,访问先到访页面#index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

3、重启

把代码加进配置文件中,在nginx安装路径下执行nginx -t 命令测试配置是否生效。看不懂英文的,翻译软件翻译一下,提示正确,重新加载配置。

#。测试配置是否正确,实际环境中都会先测试一下,再重启弎或重新加载配置
nginx -t
#重新加载配置
nginx -s reload

ebdf8131288841acab2a9dac22891d68.png

 

4、访问地址测试

访问ip地址、域名可访问到代理配置对应的地址。

198c903aa0dd46d6918fdb63a1403a3b.png

ee8510d1f3794ae8b68e5bc6c8a13b6b.png

eb010b66702c41448c7756e87820b06b.png

 

八、负载均衡

 

1、克隆

为了演示,要再加2台服务器,这边从原来演示的那一台虚拟机服务器再克隆两台。

b4ca822168104e89a817ce09e8cbf799.png

6672608ccde6431b8167836753c8acfd.png

3e63678afda243b59fad1d8d3e64f288.png

5cc246da4f864ac987b6a94f8b76992b.png

3c72d054c94443979da310522b1b89b2.png

按照上面的流程,再克隆一台出来

6c259a89b6ca4ec784c9310c43adbb37.png

2、启动服务器

把3台服务器都启动,并查看ip(记一下,后面要用)。

0290d2ae7ded41fc80ffe65a8d8e6395.png

9e3a79b3a38049338b0ff791389935eb.png

2ba42ffcd1d943ce842a0019944418cd.png

 

3、修改新增的两台服务nginx.conf配置

1)新增的两台服务器配置

一个台服务器配一个server就行,记得修改一下路径,让两个服务器的页面不一样。

929e8b892fd7456397c200243529db39.png

5ef1d5392c564d5abb7b1ee528dc5aae.png


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#vhost虚拟主机-1server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  localhost;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#proxy_pass代理其它域名网址,proxy_pass和root只能二选一。#proxy_pass https://www.bilibili.com;#文件根目录,相对于nginx安装根目录路径root   C:/Users/Administrator/Desktop/www;#默认页名称,访问先到访页面index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

2)启动nginx并查看页面

启动成功后,去浏览器访问新的两个服务器ip。

f5366d29c313408ebc572ae9a1b24423.png

dd10923a87904f4a8de556474c0fcf10.png

4、原服务器配置负载均衡

1)自动轮询nginx.conf代码配置

轮流访问每个服务器

0ab54b7c91d14c53a4fb635bc83b288e.png


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#负载均衡服务器定义upstream  asd{server 192.168.222.131;server 192.168.222.132;}#vhost虚拟主机-1server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  www.lingran.website;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#proxy_pass代理其它域名网址,proxy_pass和root只能二选一。proxy_pass http://asd;#文件根目录,相对于nginx安装根目录路径#root   C:/Users/Administrator/Desktop/www;#默认页名称,访问先到访页面#index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

2)测试

访问服务器ip,能轮流访问到两个新增服务器的页面

2331706cc3dd400db2cdb6143843aeec.png

fa2163f5d3254d2d82b17f7dac6f909c.png

3)权重轮询(weight)

weight:默认为1.weight越大,负载的权重就越大,按分配的权重比例分配访问次数。

6d8d34247ffd42808a08dfd13d1db5dc.png


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#upstream负载均衡服务器定义,weight权重分配upstream  asd{server 192.168.222.131 weight=8;server 192.168.222.132 weight=2;}#vhost虚拟主机-1server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  www.lingran.website;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#proxy_pass代理其它域名网址,proxy_pass和root只能二选一。proxy_pass http://asd;#文件根目录,相对于nginx安装根目录路径#root   C:/Users/Administrator/Desktop/www;#默认页名称,访问先到访页面#index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

4)down和backup

1.down:

是在upstream负载均衡服务器定义中,对其中的服务器做下线标记,不过不怎么用,一般想要下线服务器直接注释掉就行。

	#upstream负载均衡服务器定义,weight权重分配upstream  asd{server 192.168.222.131 weight=8 down;server 192.168.222.132 weight=2;}

2.backup:

是在upstream负载均衡服务器定义中,定义这个服务器是待机服务器,只有其他服务器全宕了,才会用到待机服务器。

	#upstream负载均衡服务器定义,weight权重分配upstream  asd{server 192.168.222.131 weight=8;server 192.168.222.132 weight=2;server 192.168.222.132 weight=2 backup;}

5)不常用(ip_hash、least_conn、url_hash、fair)

1.ip_hash

根据客户端的ip地址转发同一台服务器,可以保持会话。前提是用户ip没有发生更改。
如果需要临时删除其中一台服务器,则应用为了保留客户端 IP 地址,只能标记 down 。
	#upstream负载均衡服务器定义,weight权重分配upstream  asd{#保持同一个地址访问同一个服务器ip_hash;server 192.168.222.131 weight=8;server 192.168.222.132 weight=2;server 192.168.222.132 weight=2 down;}

 

2.least_conn

指定组应使用负载平衡方法,其中请求传递到活动连接数最少的服务器, 考虑到服务器的权重。 如果有多个这样的服务器,则使用加权循环平衡法。

 

选择活跃连接数与权重weight的比值最小者为下一个处理请求的server。上次已选的server和已达到最大连接数的server的不在选择范围。

加权循环平衡法

如一个upstream有三台server:

#upstream负载均衡服务器定义,weight权重分配
upstream aaa {#选取活跃连接数与权重weight的比值最小者为下一个处理请求的serverleast_conn;server 192.168.222.131 weight=8;server 192.168.222.132 weight=2;server 192.168.222.132 weight=2;
}

如上一个请求选择了第二台192.168.222.132,下一个请求到来,通过比较剩下可用的server的conns(连接数)/weight的值,决定哪一台。

如果192.168.222.131连接数为40,192.168.222.133连接数为8,权重分别是8和2,计算结果
192.168.222.131:40/8=5

192.168.222.132:8/2=4

因为 5 > 4,因为192.168.222.132的最小且链接数未满,所以选择192.168.222.132而不选192.168.222.131。尽管连接数192.168.222.131要大于192.168.222.132。

3.url_hash

定向流量转发,根据用户访问的url定向转发请求,主要用于访问固定位置的资源,如下载文件
#upstream负载均衡服务器定义,weight权重分配
upstream aaa {#主要用于访问固定位置的资源,如下载文件hash $request_uri;server 192.168.222.131 weight=8;server 192.168.222.132 weight=2;server 192.168.222.132 weight=2;
}

4.fair

根据后端服务器响应时间转发请求,基于每个后端服务器的响应时间和连接数来动态调整权重
#upstream负载均衡服务器定义,weight权重分配
upstream aaa {fair;server 192.168.222.131 weight=8;server 192.168.222.132 weight=2;server 192.168.222.132 weight=2;
}

 

九、动静分离

将 css、img、js等这些配置文件,放到nginx服务器上,不用放在后面的服务器上。

1、普通配置

 

d39084fbb3bd4293a2a0097dc11a11c6.png


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#负载均衡服务器定义upstream  asd{server 192.168.222.131;server 192.168.222.132;}#vhost虚拟主机-1server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  www.lingran.website;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#proxy_pass代理其它域名网址,proxy_pass和root只能二选一。proxy_pass http://asd;#文件根目录,相对于nginx安装根目录路径#root   C:/Users/Administrator/Desktop/www;#默认页名称,访问先到访页面#index  index.html index.htm;}#配置css,到root后面的路径,匹配csslocation /css {#文件根目录,相对于nginx安装根目录路径root   C:/Users/Administrator/Desktop/www;index  index.html index.htm;}#配置js,到root后面的路径,匹配jslocation /js {#文件根目录,相对于nginx安装根目录路径root   C:/Users/Administrator/Desktop/www;index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

2、正则配置

正则基本用法要有一些了解

8f0975b4882a48fdba77457782237395.png


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#负载均衡服务器定义upstream  asd{server 192.168.222.131;server 192.168.222.132;}#vhost虚拟主机-1server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  www.lingran.website;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#proxy_pass代理其它域名网址,proxy_pass和root只能二选一。proxy_pass http://asd;#文件根目录,相对于nginx安装根目录路径#root   C:/Users/Administrator/Desktop/www;#默认页名称,访问先到访页面#index  index.html index.htm;}#~表示要使用正则了,*表示不区分大小写,|隔开今写多个location ~*/(css|js|img) {#这三个静态文件夹css、js、img,要在下面的路径里root   C:/Users/Administrator/Desktop/www;index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

 

十、UrlRewrite

1、参数详情

地址重写,用户得到的都是经过处理后的URL地址。

#样例
rewrite ^/([0-9]+).html$ /index.jsp?pageNum=$1 break;

2649c29ee4974004b84b38e439c15646.png

rewrite     <regex>     <replacement>     [flag];
关键字         正则         替代内容         flag标记


关键字:关键字rewrite不能改变
正则:正则表达式语句进行规则匹配
替代内容:将正则匹配的内容替换成replacement


flag标记说明:

1、last
本条规则匹配完成后,继续向下匹配新的location URI规则
2、break
本条规则匹配完成即终止,不再匹配后面的任何规则

3、redirect
返回302临时重定向,浏览器地址会显示跳转后的URL地址

4、permanent
返回301永久重定向,浏览器地址栏会显示跳转后的URL地址

 

2、nginx.conf配置

 

5193c61d56504f06a3c992b8fd29320c.png


#默认为1,表示开启一个业务进程。根据服务器核数来配置,一般1个核对应1个进程
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;events {#单个业务进程可接受连接数worker_connections  1024;
}http {#引入http mime类型,引入在conf文件下的mime.types文件,让浏览器知道识别文件后缀名后该如何展示include       mime.types;#如果mime类型没匹配上,默认使用二进制流的方式传输。default_type  application/octet-stream;#使用高效网络传输,也就是数据0拷贝,直接传输数据。未开启sendfilesendfile        on;#保持链接时间keepalive_timeout  65;#负载均衡服务器定义upstream  asd{server 192.168.222.131;server 192.168.222.132;}#vhost虚拟主机-1server {#监听端口号listen       80;#主机名\域名,空格后面可以再接一个域名,支持正则,不同域名后缀也可以。server_name  www.lingran.website;#匹配路径url,样例:http://nginx.org/en/download.htmllocation / {#样例rewrite ^/([0-9]+).html$ /index.jsp?pageNum=$1 break;proxy_pass http://asd;}#~表示要使用正则了,*表示不区分大小写,|隔开今写多个location ~*/(css|js|img) {#这三个静态文件夹css、js、img,要在下面的路径里root   C:/Users/Administrator/Desktop/www;index  index.html index.htm;}#服务端报错后报错编码对应页面。样例:http://nginx.org/50x.htmlerror_page   500 502 503 504  /50x.html;#报错后识别到域名后面跟了/50x.html,则匹配到根目录root下的html文件夹location = /50x.html {root   html;}}}

3、效果

eb70ff311e7d4025b6864bd3c2e02cef.png

12a636d388dc445090be9e5f5d1c0fde.png

 

十一、报错

1、[error] OpenEvent("Global\ngx_reload_3220")

6da2bd70946e4a12b06d427e46e3f23b.png

nginx: [error] OpenEvent("Global\ngx_reload_3220") failed (2: The system cannot find the file specified)

命令窗口权限不足,以管理员权限打开命令窗口执行即可

 

目前这到这了

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/346461.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vue29:普通组件的注册使用

<template><div class"App"><!-- 头部组件 --><HmHeader></HmHeader><!-- 主体组件 --><HmMain></HmMain><!-- 底部组件 --><HmFooter></HmFooter><!-- 如果 HmFooter tab 出不来 → 需要配置…

通过技术优化财务规划报告,重塑企业体验

财务报告使企业的管理层能够及时、准确、清晰且一致地了解整个企业的财务业绩和风险机遇。它促进了企业内部利益相关者之间的沟通&#xff0c;从而支持基于数据驱动的洞察力提升和战略决策。但财务报告往往需要占用大量的时间来运行和准备&#xff0c;且可能使最终结论偏离核心…

腾讯云大数据ES Serverless

Elasticsearch&#xff1a;日志和搜索场景首选解决方案。 技术特点&#xff1a;分布式、全文搜索和数据分析引擎&#xff0c;可以对海量数据进行准实时地存储、搜索和统计分析。 ES的技术栈一共包含四个组件&#xff1a; 其中最核心的是Elasticsearch&#xff0c;可用于数据…

LVGL移植和图片显示

最近闲来无事&#xff0c;偶尔刷到了移植LVGL的教程&#xff0c;今天肝完了机械原理又移植完LVGL库&#xff0c;真是收获满满的一天&#xff0c;先接一杯水去。 回来了&#xff0c;发个朋友圈高级一下&#xff0c;好困。 lvgl v8.3移植及组件使用_lvgl界面编辑器-CSDN博客htt…

RAG:如何从0到1搭建一个RAG应用

通过本文你可以了解到&#xff1a; 什么是RAG&#xff1f;如何搭建一个RAG应用&#xff1f;目前开源的RAG应用有哪些&#xff1f; 大模型学习参考&#xff1a; 1.大模型学习资料整理&#xff1a;大模型学习资料整理&#xff1a;如何从0到1学习大模型&#xff0c;搭建个人或企业…

手机连接ESP8266的WIFI,进入内置网页,输入要显示的内容,在OLED显示屏上显示文本

在这篇技术博客中&#xff0c;我们将探讨如何使用ESP8266 Wi-Fi 模块和SSD1306 OLED显示屏&#xff0c;构建一个简易的信息显示和交互系统。此系统能够让用户通过一个简单的Web界面输入信息&#xff0c;并将其显示在OLED屏幕上。这种设备的应用非常广泛&#xff0c;可以用于智能…

vue实现pdf下载——html2canvas

html2canvas 官方文档https://html2canvas.hertzen.com/getting-started html2canvas 的原理是通过遍历DOM树,将每一个HTML元素转化为Canvas对象,并叠加到一起形成一张完整的图片或者PDF文件。 1. 安装插件 npm install html2canvas jspdf --save 2.使用&#xff08;页面已经…

Leetcode刷题笔记9

1. 两数之和 1. 两数之和 - 力扣&#xff08;LeetCode&#xff09; 解法一&#xff1a;暴力枚举 没什么好说的&#xff0c;直接使用两个for循环&#xff0c;i从第一个元素开始&#xff0c;j从第二个元素开始遍历并寻找 时间复杂度&#xff1a;O(N^2) 空间复杂度&#xff1a…

4_机械臂位姿求逆理论及代码计算

1、aubo arcs sdk poseInverse 使用例子 auto cur_pose rpc_cli->getRobotInterface(robot_name)->getRobotState()->getTcpPose();// 2.288083 0.035207 1.550335auto pose_inv rpc_cli->getMath()->poseInverse(cur_pose);//结果&#xff1a;0.118611 -0.57…

blender

通用设置&#xff1a; 仅显示/取消隐藏&#xff1a;数字键盘/ 移动视角&#xff1a;shift鼠标中键 Blender如何给场景添加参考图片-百度经验 (baidu.com) 进入编辑模式&#xff1a;Tab 编辑模式&#xff1a;点-线-面 两个视图 法向显示&#xff1a;就能变成恶心的蓝红色 显…

自动驾驶---Perception之视觉点云雷达点云

1 前言 在自动驾驶领域&#xff0c;点云技术的发展历程可以追溯到自动驾驶技术的早期阶段&#xff0c;特别是在环境感知和地图构建方面。 在自动驾驶技术的早期技术研究中&#xff0c;视觉点云和和雷达点云都有出现。20世纪60年代&#xff0c;美国MIT的Roberts从2D图像中提取3D…

解锁ChatGPT:从GPT-2实践入手解密ChatGPT

⭐️我叫忆_恒心&#xff0c;一名喜欢书写博客的研究生&#x1f468;‍&#x1f393;。 如果觉得本文能帮到您&#xff0c;麻烦点个赞&#x1f44d;呗&#xff01; 近期会不断在专栏里进行更新讲解博客~~~ 有什么问题的小伙伴 欢迎留言提问欧&#xff0c;喜欢的小伙伴给个三连支…

LabVIEW开发实验室超导体电流特性测试系统

本系统旨在为学校实验室提供一个基于LabVIEW的超导体电流特性测试平台&#xff0c;通过精确测量超导体在不同温度和电流条件下的电学特性&#xff0c;帮助学生和研究人员深入理解超导体的物理性质。本文将从背景、目标、工作原理、使用方法、操作流程和注意事项等方面详细介绍该…

现代x86汇编-环境安装

今天端午节&#xff0c;独自在家&#xff0c;翻阅了张银奎老师编写的《现代x86汇编语言程序设计》一书&#xff0c;前言部分说明书中示例代码都是用微软visual C工具编写并使用微软宏汇编&#xff08;著名的MASM&#xff09;编译的&#xff0c;好久没有用微软vc了&#xff0c;假…

【UML用户指南】-13-对高级结构建模-包

目录 1、名称 2、元素 3、可见性 4、引入与引出 用包把建模元素安排成可作为一个组来处理的较大组块。可以控制这些元素的可见性&#xff0c;使一些元素在包外是可见的&#xff0c;而另一些元素要隐藏在包内。也可以用包表示系统体系结构的不同视图。 狗窝并不复杂&#x…

排序题+贪心

排序力扣题 一&#xff1a;合并区间 56. 合并区间 方法一&#xff1a;先排序再合并 如图&#xff0c;把区间按照起点从小到达排序&#xff0c;如果起点相同那么按照终点小的优先排序 然后每次记录一个区间&#xff0c;访问下一个区间&#xff1a; 如果下一个区间的起点<前…

Hexo+Github搭建个人博客教程

hexo官网&#xff1a;https://hexo.io/zh-cn/ butterfly 主题设置&#xff1a;https://butterfly.js.org/ GitHub地址&#xff1a;https://github.com/jerryc127/hexo-theme-butterfly 基础命令 初始化博客命令&#xff1a;hexo init “文件名” 开启本地服务&#xff08;本…

支付交易——在线支付系统基本概念

摘要 本文聚集于实战&#xff0c;只讲解最实用的知识点&#xff0c;至于支付起源、在线支付发展历程等科普知识&#xff0c;感兴趣的读者可参考其它优秀的支付类书籍或网络上其它优秀的文章。本章内容对大部分专业概念进行了极致简化&#xff0c;以便更好地帮助读者入门。实际…

XSS(跨站脚本攻击)

1.什么是xss XSS全称&#xff08;Cross Site Scripting&#xff09;跨站脚本攻击&#xff0c;为了避免和CSS层叠样式表名称冲突&#xff0c;所以改为了 XSS&#xff0c;是最常见的Web应用程序安全漏洞之一,XSS是指攻击者在网页中嵌入客户端脚本&#xff0c;通常是JavaScript编写…

Word中插入Mathtype右编号,调整公式与编号的位置

当你已经将mathtype内置于word后&#xff0c;可以使用右编号快速插入公式 但是往往会出现公式和编号出现的位置或之间的距离不合适 比如我在双栏下插入公式&#xff0c;会发现插入的公式与编号是适用于单栏的 解决办法&#xff1a; 开始->样式->MTDisplayLquation -&g…