一、nginx是什么?
nginx是一个高性能的HTTP和反向代理的web服务器,特点就是内存少,并发能力强。他和apache很像,是一个用于解析网页展示网页的web服务器,同时也能做负载均衡器和反向代理、缓存服务器;本身功能都是模块化,可控性较高,同时面对高并发时处理速度快,资源消耗低,但是适合处理静态网页请求
二、nginx有什么用?
1、作为Web服务器,Nginx处理静态文件、索引文件,自动索引的效率非常高
2、作为代理服务器,Nginx可以实现无缓存的反向代理加速,提高网站运行速度
3、作为负载均衡服务器,Nginx既可以在内部直接支持Rails和PHP,也可以支持HTTP代理服务器对外进行服务,同时还支持简单的容错和利用算法进行负载均衡
4、在性能方面,Nginx是专门为性能优化而开发的,实现上非常注重效率。它采用内核Poll模型,可以支持更多的并发连接,最大可以支持对5万个并发连接数的响应,而且只占用很低的内存资源
5、在稳定性方面,Nginx采取了分阶段资源分配技术,使得CPU与内存的占用率非常低。Nginx官方表示,Nginx保持1万个没有活动的连接,而这些连接只占用2.5MB内存,因此,类似DOS这样的攻击对Nginx来说基本上是没有任何作用的
6、在高可用性方面,Nginx支持热部署,启动速度特别迅速,因此可以在不间断服务的情况下,对软件版本或者配置进行升级,即使运行数月也无需重新启动,几乎可以做到7x24小时不间断地运行
7、nginx常用于静态的内容服务和代理服务器,例如部署前端,tomcat常用于应用容器,跑接口。
三、为何要用到nginx?
当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。
四、怎么用到nginx?
我们此处讲的是在windows上配置nginx,如果是在linux上配置,请至https://www.runoob.com/linux/nginx-install-setup.html
首先下载nginx,地址:http://nginx.org/download/
下载好后解压,显示的是这样的:
我们需要在上面配置我们的域名和端口号,进入:
根据你的需求配置如下信息:
#user nobody;
worker_processes 1;#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;#pid logs/nginx.pid;
#工作模式及连接数上限
events {
worker_connections 1024;
}#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
#设定mime类型,类型由mime.type文件定义
include mime.types;
default_type application/octet-stream;#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';#access_log logs/access.log main;
#sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
#必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
sendfile on;
#tcp_nopush on;#连接超时时间
#keepalive_timeout 0;
keepalive_timeout 18000;
client_max_body_size 2048m; #增加这个参数就可以指定最大上传文件大小为10m了;
proxy_connect_timeout 18000;
proxy_send_timeout 18000;
proxy_read_timeout 18000;
send_timeout 18000;
server {
listen 443;#默认端口是80,如果端口没被占用可以不用修改
server_name xxxxxx;ssl on;
ssl_certificate cert/3338972_xxxxxx.pem;
ssl_certificate_key cert/3338972_xxxxxx.cn.key;
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
#charset koi8-r;#access_log logs/host.access.log main;
root xxxxxx;#vue项目的打包后的distlocation / {
try_files $uri $uri/ @router;#需要指向下面的@router否则会出现vue的路由在nginx中刷新出现404
index index.html index.htm;
}
#对应上面的@router,主要原因是路由的路径资源并不是一个真实的路径,所以无法找到具体的文件
#因此需要rewrite到index.html中,然后交给路由在处理请求资源
location @router {
rewrite ^.*$ /index.html last;
}
#.......其他部分省略
location ^~ /xxxxxx/ {
proxy_pass http://127.0.0.1:8087/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection keep-alive;
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
}
location ^~ /xxxxxx/ {
proxy_pass http://127.0.0.1:8086/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
#add_header Content-Disposition: 'attachment;';
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
如果要配置成https就把证书放在\nginx-1.14.2\conf\cert,然后在端口下面配置信息即可,如上图所示,添加两处即可
最后双击启动nginx即可
查看配置是否正确,是否成功启动nginx,可在任务管理器中查看,如果没有启动成功,则不会显示