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

  • 概述

本文目的是搭建三台asp.net core 集群, 并配上 nginx做负载均衡

  • 首先准备要运行的源码

http://pan.baidu.com/s/1qYNBvEs

准备三台服务器(或则虚拟机)  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.

curl -o  nginx.rpm http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

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

时间: 2024-10-14 19:19:38

asp.net core 负载均衡集群搭建(centos7+nginx+supervisor+kestrel)的相关文章

LVS负载均衡集群搭建

环境:RHEL6-x86-64 主要软件 MySQL-5.6.14 httpd-2.4 php-5.4.13 如下图:外网用户请求到达负载调度器,根据调度算法挑选一个Real Server(后简称RS)响应,并且使用PPC(持久端口连接),将同一客户端对同一集群服务的请求始终定向至此前选定的RS. 定向到同一个RS有什么用呢?例如:访问一个电商网站,RS1响应.刷新一下网页页面,可能被定向到RS2,这样就会要求用户重新登陆,很麻烦,通过持久连接就可以解决这种问题. 还有一个问题,如何保证无论通过

Apache+Tomcat负载均衡集群搭建

1.所需软件 apache_2.2.4-win32-x86-no_ssl,apache服务器 mod_jk-apache-2.2.4连接器,连接apache和tomcat apache-tomcat-6.0.33tomcat服务器 2.软件安装 2.1apache 安装 一直下一步,到此界面: 填写域名或localhost都可: 安装完成后,启动访问localhost,界面如下则安装成功: 2.2tomcat安装 省略,网上资料大把大把. 3.集群配置 3.1apache与mod_jk.so整合

Nginx+Tomcat高性能负载均衡集群搭建

转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/8745794.html Nginx是一个高性能的HTTP服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器.其占有内存少,并发能力强,在同类型的网页服务器中表现较好.Nginx可以在大多数Unix Linux OS上编译运行,并有Windows移植版.一般情况下,对于新建站点,建议使用最新稳定版作为生产版本. 单个Tomcat最大支持在线访问是500左右,要通知支持更多的访问量一个Tomcat

ASP.NET Core使用Docker-Swarm集群部署实现负载均衡实战演练

一.需求背景 人生苦短,我用.NET Core!阿笨对Docker是这样评价的:Docker在手,环境我有!Docker出手,集群我有!前面的Doc基础课程我们学习了如何使用Docker来部署搭建单机容器应用.当一台服务器的处理能力.存储空间不足时,不要企图去换更强大的服务器,对大型网站而言,不管多么强大的服务器,都满足不了网站持续增长的业务需求.实践中会发现,生产环境中使用单个 Docker 节点是远远不够的,搭建 Docker 集群势在必行.然而,面对 Kubernetes, Mesos等众

Nginx+Tomcat负载均衡集群

第3章:部署Tomcat及其负载均衡(案例) 防伪码:成功之前必须与孤独为伍! Tomcat应用场景:  Tomcat服务器是一个免费的开放源代码的web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的的场合下被普遍应用,是开始和调试JSP程序的首选.但是由于其处理静态HTML的能力远不及Apache或者Nginx,所以Tomcat通常是作为一个Servlet和JSP容器,单独运行在后端.如图所示 一.部署tomcat 1.安装JDK,配置Java环境 1)安装jdk,建立

Nginx+Tomcat7+Memcached负载均衡集群+session共享

Nginx+Tomcat7+Memcached负载均衡集群服务搭建 操作系统:CentOS6.5     本文档主要讲解,如何在CentOS6.5下搭建Nginx+Tomcat7+Memcached负载均衡集群服务器,Nginx负责负载均衡,Tomcat7负责实际服务,Memcached负责同步Tomcat7的Session,达到Session共享的目的.1.安装NginxNginx官网:http://nginx.org/下载最新稳定版本.在安装Nginx之前,需要先安装gcc. openssl

Nginx+Tomcat7+Mencached负载均衡集群部署笔记

Nginx+Tomcat+Memcached负载均衡集群服务搭建 操作系统:CentOS6.5 本文档主要讲解,如何在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群服务器,Nginx负责负载均衡,Tomcat负责实际服务,Memcached负责同步Tomcat的Session,达到Session共享的目的. 本文文档下载地址:http://download.csdn.net/detail/zht666/7744157 1.安装Nginx Nginx官网:http

使用Nginx1.9.9+Keepalived1.2.x搭建高可用负载均衡集群

一 简介以及原理介绍 (1)Nginx概念介绍: Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行.由俄罗斯的程序设计师Igor Sysoev所开发.其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度.京东.新浪.网易.腾讯.淘宝等 (2)Keepalived概念介绍: Keepalived的作用是检测服务器的状态,如果有一台we

keepalived+nginx搭建高可用and负载均衡集群

keepalived+nginx搭建高可用and负载均衡集群 前言 因生产环境需要,现需要搭建一个前端为nginx的HA双向互备.后端为nginx代理的loadbalance负载均衡集群.nginx进程基于于Master+Slave(worker)多进程模型,自身具有非常稳定的子进程管理功能.在Master进程分配模式下,Master进程永远不进行业务处理,只是进行任务分发,从而达到Master进程的存活高可靠性,Slave(worker)进程所有的业务信号都由主进程发出,Slave(worke