- 概述
本文目的是搭建三台asp.net core 集群, 并配上 nginx做负载均衡
- 首先准备要运行的源码
http://pan.baidu.com/s/1c20x0bA准备三台服务器(或则虚拟机) 192.168.182.129 , 192.168.182.130 , 192.168.182.131并将源码发布至三台服务器的 /root/aspnetcore/anuoapc 目录
- 在三台机器上分别搭建如下环境
第一步:NET Core 安装 (centos 7)
1.sudo yum install libunwind libicucurl -sSL -o dotnet.tar.gz https://go.microsoft.com/fwlink/?LinkID=809131sudo mkdir -p /opt/dotnet && sudo tar zxf dotnet.tar.gz -C /opt/dotnetsudo ln -s /opt/dotnet/dotnet /usr/local/bin2.mkdir hwappcd hwappdotnet new3.dotnet restoredotnet run 看到 hello world 就安装成功了 ! 第二步:Nginx 安装1.curl -o nginx.rpm http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm2.rpm -ivh nginx.rpmyum install nginx3.systemctl start nginx 来启动nginx。systemctl enable nginx 来设置nginx的开机启动4. 关闭防火墙 centos 7systemctl stop firewalld.service #停止firewallsystemctl disable firewalld.service #禁止firewall开机启动5.修改 /etc/nginx/conf.d/default.conf 文件。将文件内容替换为:
upstream myserver {
server 192.168.182.129:9090;
server 192.168.182.130:9090;
server 192.168.182.131:9090;
}
server {
listen 80;
location / {
proxy_pass http://myserver;
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;
}
}
最后:nginx –s reload 使其即时生效 6.关闭 SELinuxcd /etc/selinux/打开 config 文件, 将里面的 SELINUX 值设置为 disabled 重启centos 使其生效 第三步 . 配置守护进程supervisor 1.安装 supervisoryum install python-setuptoolseasy_install supervisor2.配置mkdir /etc/supervisorecho_supervisord_conf > /etc/supervisor/supervisord.conf 3.修改supervisord.conf文件将文件尾部的配置,修改为:[include]files = conf.d/*.conf4.启动supervisord -c /etc/supervisor/supervisord.conf 5.创建一个AnuoApc.conf 文件, 内容如下[program:AnuoApc]command=dotnet AnuoApc.Web.dll ; 运行程序的命令directory=/root/aspnetcore/anuoapc/ ; 命令执行的目录autorestart=true ; 程序意外退出是否自动重启stderr_logfile=/var/log/AnuoApc.err.log ; 错误日志文件stdout_logfile=/var/log/AnuoApc.out.log ; 输出日志文件environment=ASPNETCORE_ENVIRONMENT=Production ; 进程环境变量user=root ; 进程执行的用户身份stopsignal=INT6.将文件拷贝至:“/etc/supervisor/conf.d/”下supervisord reload 使其生效.ps -ef | grep AnuoApc如果看到 dotnet AnuoApc.Web.dll 进程则代表运行成功 第四步 修改源码, 并分别发布到三台 将源码中的 I am Node3 改成 Node2 发布至 三台中的某一台并用以下命令让 , 发布生效:
supervisorctl restart AnuoApc
以此类推, 三台 分别发布不同的 hello world ! I am node1; hello world ! I am node2; hello world ! I am node3; 这样后面调用接口时可以看到负载到了那台机器 第五步 用PostMan 调用接口连续点击三次奇迹发生了, 分别负载到了三台. 至此 大功告成 ! ! ! 推荐参考文章: http://www.cnblogs.com/ants/p/5732337.html