• asp.net core 负载均衡集群搭建(centos7+nginx+supervisor+kestrel)


    • 概述
    本文目的是搭建三台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 libicu
    curl -sSL -o dotnet.tar.gz https://go.microsoft.com/fwlink/?LinkID=809131
    sudo mkdir -p /opt/dotnet && sudo tar zxf dotnet.tar.gz -C /opt/dotnet
    sudo ln -s /opt/dotnet/dotnet /usr/local/bin
    2.
    mkdir hwapp
    cd hwapp
    dotnet new
    3.
    dotnet restore
    dotnet run
     
    看到 hello world 就安装成功了 !
     
    第二步:Nginx 安装
    1.
    2.
    rpm -ivh nginx.rpm
    yum install nginx
    3.
    systemctl start nginx 来启动nginx。
    systemctl enable nginx 来设置nginx的开机启动
    4. 关闭防火墙 centos 7
    systemctl stop firewalld.service #停止firewall
    systemctl 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.关闭 SELinux
    cd /etc/selinux/
    打开 config 文件, 将里面的 SELINUX 值设置为 disabled 
    重启centos  使其生效
     
     
    第三步 . 配置守护进程supervisor
     
    1.安装 supervisor
    yum install python-setuptools
    easy_install supervisor
    2.配置
    mkdir /etc/supervisor
    echo_supervisord_conf > /etc/supervisor/supervisord.conf
     
    3.修改supervisord.conf文件
    将文件尾部的配置,修改为:
    [include]
    files = conf.d/*.conf
    4.启动
    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=INT
    6.
    将文件拷贝至:“/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
  • 相关阅读:
    bzoj 2115: [Wc2011] Xor【线性基+dfs】
    bzoj 1027: [JSOI2007]合金【凸包+Floyd】
    bzoj 4824: [Cqoi2017]老C的键盘【树形dp】
    bzoj 2111: [ZJOI2010]Perm 排列计数【树形dp+lucas】
    bzoj 4822: [Cqoi2017]老C的任务【扫描线+树状数组+二维差分】
    bzoj 4823: [Cqoi2017]老C的方块【最大权闭合子图】
    bzoj 4826: [Hnoi2017]影魔【单调栈+树状数组+扫描线】
    洛谷 P3731 [HAOI2017]新型城市化【最大流(二分图匹配)+tarjan】
    洛谷 P3732 [HAOI2017]供给侧改革【trie树】
    poj 1474 Video Surveillance 【半平面交】
  • 原文地址:https://www.cnblogs.com/anuo/p/5793264.html
Copyright © 2020-2023  润新知