Nginx实现反向代理和负载均衡
概述
Nginx 是一款高性能的 http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师伊戈尔·西索夫(Igor Sysoev)所开发,官方测试 nginx 能够支支撑 5 万并发链接,并且 cpu、内存等资源消耗却非常低,运行非常稳定。
Nginx 应用场景:
1、http 服务器。Nginx 是一个 http 服务可以独立提供 http 服务。可以做网页静态服务器。
2、虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
3、反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用 nginx 做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。
安装
首先到官网下载
http://nginx.org/en/download.html
我就使用windows稳定版本的 nginx/Windows-1.14.0
下载解压后.我就放在D:\server
注意:使用管理员打开命令行
使用nginx
启动nginx
访问localhost:80
出现如下页面说明启动成功
想关闭 nginx有以下两个命令
nginx -s stop
nginx -s quit
修改nginx.conf文件后,重新加载,使用如下命令
nginx -s reload
端口映射部署静态文件
接下来使用nginx部署静态文件
在根目录下新建server1 和server2的文件夹,并添加index.html文件
修改D:\server\nginx-1.14.0\conf\nginx.conf
文件
添加如下内容,做端口映射静态资源文件
server {
listen 81;
server_name localhost;
location / {
root server1;
index index.html;
}
}
server {
listen 82;
server_name localhost;
location / {
root server2;
index index.html;
}
}
重新加载nginx
访问localhost:81 与localhost:81 即可访问静态文件
反向代理和负载均衡
在springcloud中我们使用Ribbon进行负载均衡,使用zuul进行网关代理
nginx也有反向代理和负载均衡的功能
为了测试方便,启动两个SpringBoot项目,端口分别为8001和8002
暴露RestAPI
@RestController
public class TestController {
@RequestMapping("/port")
public String hello(){
return "server port 8001";
}
}
@RestController
public class TestController {
@RequestMapping("/port")
public String hello(){
return "server port 8002";
}
}
接下来在D:\server\nginx-1.14.0\conf\nginx.conf
中配置ip:端口映射
并可以设置权重
upstream tomcat-portal {
server 127.0.0.1:8001;
server 127.0.0.1:8002 weight=2;
}
server {
listen 83;
server_name localhost;
location / {
proxy_pass http://tomcat-portal;
}
}
不断刷新访问localhost:83/port 可见实现了反向代理与负载均衡