- 下载nginx
官方下载 http://nginx.org/en/download.html
- 下载到本地解压打开
- cmd命令进入解压文件的根目录
- 不着急启动,我们要实现负载均衡,先修改一波配置文件
upstream mservers{
server 127.0.0.1:8080 weight=1;
server 127.0.0.1:8090 weight=1;
}
server {
listen 80; # 这里推荐修改为本地没有占用的端口
server_name localhost;
location /test {
proxy_pass http://mservers;
proxy_set_header Host $host;
index index.html index.htm;
}
}
upstream 中配置
参数:weight、max_conns、slow_start、down、backup、max_fails、fail_timeout
max_conns:设置server的最大连接数。默认为0,没有限制。使用时保证worker_processes为1
slow_start:服务器在指定时间内启动。(该参数商业版nginx有效)
down:nginx集群中的这台已不可用
backup:备份server服务器。
max_fails、fail_timeout:两个参数需要一起使用。 最大失败次数和失败时间段。默认为1和10s。
# 10s内访问该服务器两次,若都失败,则认为该服务器不可用。
server 127.0.0.1:8080 max_fails=2 fail_timeout=10s;
- 启动nginx,本次在windows上操作
start nginx.exe
# 启动之后可以使用命令查看nginx是否已经启动
tasklist fi "imagename eq nginx.exe"
# 停止服务 需要有记录pid文件
nginx -s stop
# 重新加载配置文件 windows重新加载有问题看文末
nginx -s reload
- 访问localhost:80 80 为配置文件中默认监听的端口
出现如上页面正常访问
- 确保upstream下的服务器是可以访问的
是否开启端口开放
是否对外网开放
- 访问其余两台服务器下已部署服务的路径 查看是否正常, 这里只做本地服务的演示
该项目为学习分布式锁的demo 大家也可以尝试下
如上所示,启动两个服务接着在浏览器中访问localhost/test接口即可,代码中已写好/test接口
启用负载均衡后 两个服务中均有请求发进来,并且weight=1参数的效果还是比较均匀的
也可以测试下没有weight参数 我自己测会出现一边倒的效果
踩坑: 重新加载命令无用 | upstream设置无效 负载均衡无效
这里可能是由于先启动了nginx, 停止nginx服务实际上需要记录pid才能停止,有些小伙伴会发现使用命令既无法停止,重新修改了配置文件也不生效,就是这个原因。
- 直接任务管理器 进程界面杀掉nginx有关的进程
- 使用命令行杀掉进程,再修改配置文件后重新启动。
taskkill /f /t /im "nginx.exe"
# 或者
taskkill /f /t /pid "进程pid"