nginx大家如果没用过那或多或少都应该听过,vue的部署、反向代理、负载均衡nginx都能帮你做到。

今天主要说一下nginx负载均衡我们的项目,如下图所示,请求到达nginx,nginx再帮我们转发。

.Net Core + Nginx实现项目负载均衡的全步骤

首先使用Docker安装nginx.

docker pull nginx:latest

运行容器,将本地的8080端口映射到容器内部的 80 端口.

docker run --name nginx -p 8080:80 -d nginx

查看nginx容器,如果有错请看日志.

.Net Core + Nginx实现项目负载均衡的全步骤

浏览器中访问一下

.Net Core + Nginx实现项目负载均衡的全步骤

ok,到此我们的nginx就已安装完成。

我们准备好3个以上的webapi的项目并发布。

.Net Core + Nginx实现项目负载均衡的全步骤

进入nginx容器

Docker exec -it nginx bash

找到nginx.conf文件并作修改,nginx.conf分为http块、events块和server块,此次主要在server块中做更改.

.Net Core + Nginx实现项目负载均衡的全步骤

此时在nginx容器里面使用vi或者vim没有用,需要依次执行如下两条命令

apt-get update 
apt-get install vim

进入文件内,末尾处指向了另一个文件,没错这个文件里就是放server块配置内容

.Net Core + Nginx实现项目负载均衡的全步骤

进入etc/nginx/conf.d/default.conf文件中并做修改

.Net Core + Nginx实现项目负载均衡的全步骤

.Net Core + Nginx实现项目负载均衡的全步骤

upstream ServiceInstance{   #nginx默认轮询下面的服务实例
  server ***.**.***.***:9007; 
  server ***.**.***.***:9008; 
  server ***.**.***.***:9009;
} 
server { 
  listen    80; 
  server_name localhost; 
 
  #charset koi8-r; 
  #access_log /var/log/nginx/host.access.log main; 
 
  location / { 
    #root  /usr/share/nginx/html; 
    #index index.html index.htm;     #请求到达后会进行转发
    proxy_pass http://ServiceInstance; 
  } 
 
  #error_page 404       /404.html; 
 
  # redirect server error pages to the static page /50x.html 
  # 
  error_page  500 502 503 504 /50x.html; 
  location = /50x.html { 
    root  /usr/share/nginx/html; 
  } 
 
  # proxy the PHP scripts to Apache listening on 127.0.0.1:80 
  # 
  #location ~ \.php$ { 
  #  proxy_pass  http://127.0.0.1; 
  #} 
 
  # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 
  # 
  #location ~ \.php$ { 
  #  root      html; 
  #  fastcgi_pass  127.0.0.1:9000; 
  #  fastcgi_index index.php; 
  #  fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; 
  #  include    fastcgi_params; 
  #} 
 
  # deny access to .htaccess files, if Apache's document root 
  # concurs with nginx's one 
  # 
  #location ~ /\.ht { 
  #  deny all; 
  #} 
}

完成之后重启一下容器,如果有错误请查看日志.

docker restart nginx

浏览器中调用一个接口查看

.Net Core + Nginx实现项目负载均衡的全步骤

每一次都会轮询不同的服务实例,负载均衡的预期就实现了!

我们也可以设置权重比例,weight值越大,请求到达此实例的次数就越多!

upstream ServiceInstance{ 
  #nginx默认轮询下面的服务实例
  server ***.**.***.***:9007 weight=1; 
  server ***.**.***.***:9008 weight=2; 
  server ***.**.***.***:9009 weight=3;
}

各位同学也可慢慢研究,nginx很强大的!😎

总结

标签:
nginx负载均衡配置详解,nginx负载均衡原理,nginx负载均衡怎么配置

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。