.Net Core服务治理Consul使用服务发现
作者:老马-Max 发布时间:2023-06-25 07:49:19
先思考一些问题:它是做什么的、以及怎么使用它。带着这些问题往下走。
consul是做什么的
consul用于微服务下的服务治理。服务治理是什么?它包含但不限于:服务发现、服务配置、健康检查、键值存储、安全服务通信、多数据中心等。
为什么需要服务治理?举个例子:最开始的服务比较简单,各服务之间通过API就能访问。后面业务复杂了,服务也跟着复杂了,搞分布式了,而分布式又必然是多服务器部署,这就有一个问题:如果服务之间还是用API访问,那某个服务所在的服务器挂掉以后这个服务就不能用了,也不能自动转移,那么只能人肉运维了。这时候大家在想:如果下游调用上游,只需要一个统一的地址,不用关注负载均衡、节点失效之类的问题,也不用关注可用性,这些都有一个中间件来完成,那该有多好。这个中间件要做的事情,就是服务治理,也就是本文的consul,它就是解决这个事的。但其实也不是只有它能做这个事,zooKeeper、etcd也能做这个事,也没有什么高下之分,用什么主要看自己,看公司。对自己来说,哪个摸得透、玩的熟就用哪个。对公司来说,哪个市场认可度高就用哪个,说白了就是哪个用的人多。用的人多会的人就多,招人换人速度就快了,互联网企业追求的不就是速度么?“时间就是金钱,效率就是生命”,这句话早期在深圳随处可见,至今仍然适用。
题外话有点多,接着往下走。
怎么使用consul
这里只讲docker内的consul。首先下载一个镜像:
dokcer pull consul
然后运行起来:
docker run -itd -p 8700:8500 --name myconsuldemo consul
成功运行后能看到如下页面:
tips:consul的默认端口是8500,docker启动可以映射到任意端口。
服务注册
服务发现的概念,简单来说就是所有节点程序启动时都去consul注册一下,注册后的信息统一保存在consul中以供调用。是不是很简单?
现在net core 3.1下完成consul服务注册。
首先需要添加nuget包:
然后自行封装一个注册服务,节省时间先上源码:
public static void Reg(IConfiguration configuration)
{
string ip = configuration.GetSection("ip").Value.ToString();
string port = configuration.GetSection("port").Value.ToString();
string weight = configuration.GetSection("weight").Value.ToString();
string address = configuration.GetSection("address").Value.ToString();//consul的启动地址
string center = configuration.GetSection("center").Value.ToString();//数据中心名称
ConsulClient client = new ConsulClient(x =>
{
x.Address = new Uri(address);
x.Datacenter = center;
});
client.Agent.ServiceRegister(new AgentServiceRegistration()
{
ID = $"server {ip}:{port}",
Name = "shenzhen-ma",//分组名称
Address = ip,
Port = int.Parse(port)
});
}
配置文件:
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft": "Warning",
"Microsoft.Hosting.Lifetime": "Information"
}
},
"AllowedHosts": "*",
"ip": "127.0.0.1",
"port": 5100,
"weight": 1,//权重,负载均衡的重要参数
"address": "http://127.0.0.1:8700",//consul地址
"center": "dc1"//数据中心
}
最后,这个服务需要在程序启动的时候调用,只一次就好。直接把调用放在startup里就好,这样程序启动的时候就会自动注册一个服务。
为了能够动态修改配置文件,接下来通过控制台启动程序:
dotnet run --urls="http://*:5000" --ip="127.0.0.1" --port=5000
启动成功以后,转到consul的ui看一下:
能看到多了一个分组【shenzhen-ma】,点进去看下我们的服务:
127.0.0.1:5000,没毛病。这时候模拟一下多节点,再多启动两个程序试试看:
5001,5002也自动注册进入了这个分组。
因为时间关系,今天只能写到这里了,还有很多东西没有写,服务调用、健康检查什么的,我会尽快再发文的。
来源:https://www.cnblogs.com/muchengqingxin/p/15007491.html


猜你喜欢
- F()函数F()函数的导入from django.db.models import F为什么要使用F()函数?一个 F()对象代表了一个mo
- 在日常的编程中,我经常需要标识存在于文本文档中的部件和结构,这些文档包括:日志文件、配置文件、定界的数据以及格式更自由的(但还是
- MySql总是定时弹出一个MySQLInstallerConsole.exe的窗口,如何解决呐?这貌似是一条安装命令,Installing
- 你可以输入'脚本'查查看 查找页面中的字符 <script language="JavaScript&quo
- 下面开始优化下my.conf文件(这里的优化只是在mysql本身的优化,之前安装的时候也要有优化)cat /etc/my.cnf# For
- 出现这个问题解决方法:点击File > Settings > Tools > Server Certificates &g
- 概要本文分步介绍了如何在运行 SQL Server 的计算机之间移动 Microsoft SQL Server 用户数据库和大多数常见的 S
- 目标站点分析本次要抓取的目标站点为:中介网,这个网站提供了网站排行榜、互联网网站排行榜、中文网站排行榜等数据。网站展示的样本数据量是 :58
- 前言:Go 语言追求简洁优雅,所以,Go 语言不支持传统的 try…catch…finally
- Q:在给Dataloader设置worker数量(num_worker)时,到底设置多少合适?这个worker到底怎么工作的?
- 一、前言大家好,今天我来介绍我接一个Python单子。我完成这个单子前后不到2小时。首先我接到这个单子的想法是处理Excel表,在两个表之间
- python3.7简单的爬虫,具体代码如下所示:#https://www.runoob.com/w3cnote/python-spider-
- 在生活之中,我们想要去一个很远的地方,可能先走到坐车的地方,再从乘车去目的地。那么,我们是不是可以理解成函数嵌套也是这样,需要不同函数的组合
- 依赖条件:需要有Hadoop,hive,zookeeper,hbase环境映射:每一个在 Hive 表中的域都存在于 HBase 中,而在
- 1.1MyBatis简介 MyBatis 是一个可以自定义SQL、存储过程和高级
- 1.消息丢失1.生产者发送失败所有消息队列都可能发生的问题生产者发送消息后,队列未成功接收(网络原因或其他)而生产者不知情,消息丢失生产者发
- 插入或更新null空值一、在SQL语句中直接插入null或空字符串“”int? item = nul
- 很多时候我们都会有一个麻烦事,就是打开pycharm或者VScode等的时候,都有可能因为自己电脑上面安装的第三方模块过多,导致电脑很卡,风
- 本文实例讲述了Python自动发送邮件的方法。分享给大家供大家参考,具体如下:python发邮件需要掌握两个模块的用法,smtplib和em
- 因为python打包的时候需要用到ico图片格式,网上看好的图片又没有ico,于是自己寻找了一下python转换图片格式的方法,彻底解决这个