Nginx 是一个高性能的HTTP和反向代理web服务器,因它的稳定性、丰富的功能集、简单的配置文件和低系统资源的消耗而闻名,其特点是占有内存少,并发能力强,能够支持高达5w并发连接,实际生产环境中可以支撑2-4万并发连接数。
Nginx的所有配置基本都是在nginx.conf文件中进行配置。
1. 下载Nginx:
http://nginx.org/en/download.html
2. 解压nginx.rar压缩包,并进入nginx目录,双击nginx.exe启动。
3. 打开浏览器访问 http://127.0.0.1 如果出现以下画面则表示Nginx启动成功。
-- 验证Nginx是否启动成功
linux服务安装Nginx需要提前安装一些依赖,相比Windows安装有一些繁琐,所以给大家提供了一键安装Nginx的脚本
下载脚本链接:https://pan.baidu.com/s/1NP5AHq17Djce2_T7tnP4vw?pwd=nzz5
下载下来后将下图中的两个文件(Nginx安装包和sh脚本)上传到服务器,
然后执行./nginx-install.sh即可完成一键安装;Nginx将会安装到 /usr/local/nginx。
.sh脚本
如果./nginx-install.sh无法运行则需要设置文件权限,执行以下命令chmod 755 nginxinstall.sh,然后重新执行命令即可。
反向代理:指通过代理服务器(Nginx)来接受网络上的连接请求,然后将请求转发给内部网络上的其它服务器,并从服务器上得到的结果返回给网络上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。
反向代理案例
1、在nginx.conf中配置反向代理,可直接将以下代码替换到你本地nginx.conf中
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type Application/octet-stream;
keepalive_timeout 65;
server {
listen 80;
server_name localhost;
location /a/ {
proxy_pass http://127.0.0.1:8080/;
}
location /b/ {
proxy_pass http://127.0.0.1:8081/;
}
}
}
2、后台启动两个端口8080和8081;
3、 浏览器分别访问127.0.0.1/a/${接口路径} 127.0.0.1/b/${接口路径} 查看效果。
location中拦截参数结尾带/和不带/区别 ?
例如:location /a 和 /a/有什么区别 ?
- 当结尾加上了/,相当于是绝对根路径,则nginx不会把location中匹配的路径部分代理走;
- 如果没有/,则会把匹配的路径部分也给代理走。
负载均衡
按照一定的算法【权重、轮询、IP绑定】,将客户端请求转发到不同应用服务器上,减轻单个服务器压力,提高系统并发量。
故障转移
通过心跳检测的方式,判断应用服务器当前是否可以正常工作,如果服务器期宕掉,自动将请求发送到其他正常的应用服务器。
如果检查到发生故障的应用服务器恢复工作,则会重新加入负载均衡队列进行工作。
1. 轮询(默认)
将请求按顺序轮流均匀的分配到后端服务器上。
upstream testserver {
server 127.0.0.1:8080;
server 127.0.0.1:8180;
}
2. IP绑定
按照访问ip的hash结果进行取模运算,得到的结果便是客服端要访问服务器,可以解决session的问题。
upstream testserver {
ip_hash;
server 127.0.0.1:8080;
server 127.0.0.1:8180;
}
3. 指定权重
指定轮询几率,weight越大,负载的权重就越大,用于后端服务器性能不均的情况。
upstream testserver {
server 127.0.0.1:8080 weight=10;
server 127.0.0.1:8180 weight=10;
}
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
keepalive_timeout 65;
#轮训负载均衡
upstream testserver {
server 127.0.0.1:8080;
server 127.0.0.1:8180;
}
server {
listen 80;
server_name localhost;
location /a/ {
proxy_pass http://testserver/;
}
}
}
2.后台启动两个端口8080和8180;
3.浏览器多次访问127.0.0.1/a/${接口路径}查看轮训效果。