net6 core 接入nacos 实现服务注册入门使用,心跳检测和负载均衡

本文主要是介绍net6 core 接入nacos 实现服务注册入门使用,心跳检测和负载均衡,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

net6 core 接入nacos 实现服务注册入门使用,心跳检测和负载均衡

配置中心比较Apollo与Nacos_appollo 和 nacos-CSDN博客

一:安装nacos 

Release 2.2.3 (May 25th, 2023) · alibaba/nacos · GitHub

二、配置Nacos

注*Nacos 是使用的mysql 数据库,需要先自行安装好数据库

1.在mysql中创建数据库:库名一定要是:nacos_config  字符集跟排序规则默认为空,没有特殊要求

2.解压出上面下载的压缩包,nacos下conf文件夹,在nacos_config数据库中执行数据库脚本:derby-schema.sql 
mysql-schema.sql

数据库脚本执行完成刷新表,看到如下时,就成功啦!

三.配置连接

打开conf文件夹下的 application.properties 文件  修改如下配置,其余的不要动,修改完成保存。

回到上一级,进入bin目录,在bin目录下cmd 执行 startup -m standalone  命令即可启动nacos。

如果提示没有安装java包,请自行按下面的java安装。

如上图,启动成功,默认端口是8848  我们打开浏览器访问: http://192.168.56.1:8848/nacos/index.html

四:安装java 环境

windows 安装jdk 相关坑 java jdk1.8.0_221 安装步骤_this version of the jdk-CSDN博客

五、NETCORE对接nacos 实现服务注册与发现以及负载均衡

1、配置Nacos

       服务对接之前,先在nacos上添加配置文件   打开nacos的web网页

1.1 配置命名空间

1.2 对命名空间配置参数

    选择 配置列表  选中刚才添加的命名空间   点击最左侧  +  号

填入参数  点击发布,json串可以直接填入   注意填入的时候把注释去掉

把localhost 改成实际你的nacos页面访问的ip地址

Namespace:命名空间ID  可以从左侧 命名空间菜单查看

ServiceName:服务名,自己定义  不要重复哦

Namespace

{

"nacos": {

"ServerAddresses": [ "http://192.168.56.1:8848/" ],

"DefaultTimeOut": 15000,

"Namespace": "23b63b57-c762-4778-b141-4d16db969984",

"ListenInterval": 1000,

"ServiceName": "UserService",

"GroupName": "DEFAULT_GROUP",

"ClusterName": "DEFAULT",

"RegisterEnabled": true,

"InstanceEnabled": true,

"Ephemeral": true,

"ConfigUseRpc": true,

"NamingUseRpc": true,

"LBStrategy": "WeightRoundRobin"

}
}

六:code net6 代码

6.netcore  接入nacos  实现服务注册与心跳检测

6.1 创建一个netcore webapi项目

引入两个nuget  nacos-sdk-csharp.Extensions.Configuration   nacos-sdk-csharp.AspNetCore

注册 nacos :

  // 注册服务到Nacos
  builder.Services.AddNacosAspNet(builder.Configuration); //默认节点Nacos
                                                          // 添加配置中心
  builder.Host.ConfigureAppConfiguration((context, builder) =>
  {
      var config = builder.Build();
      builder.AddNacosV2Configuration(config.GetSection("NacosConfig"));
  });

配置配置文件:

在appsettings.json 文件中贴入下面配置
 

  "NacosConfig": {"Listeners": [{"Optional": false,"DataId": "test01serviceconfig", //Data Id 配置列表查看 命名空间ID"Group": "DEFAULT_GROUP"}],"Optional": false,"Namespace": "23b63b57-c762-4778-b141-4d16db969984", //命名空间查看"ServerAddresses": [ "http://192.168.56.1:8848/" ] //你的nacos 实际访问地址}, 

将下图端口设置注释  因为该配置文件优于命令行参数

完事。。。。。。

2.2  启动多个项目

右键项目  在文件资源管理器中打开文件夹   在当前文件下打开cmd窗口   你要开几个服务 就打开几个窗口  在窗口中执行  dotnet run --urls=http://*:8003 --port=8003    端口你自己定义

如下图 我开启了三个窗口 分别开启了三个服务  端口分别是  8001   8002  8003

//dotnet run --urls=http://*:8001 --port=8001
//dotnet run --urls=http://*:8002 --port=8002
//dotnet run --urls=http://*:8003 --port=8003
//http://localhost:8001/WeatherForecast
 

此时 我们从nacos 查看  我们启动的三个服务已经显示了   你关掉对应的服务 这里也会减少或者增加  至此 服务注册与发现 心跳检测配置完成。

六:nacos net6 实现负载均衡

{"nacos": {"ServerAddresses": ["http://192.168.56.1:8848"],"DefaultTimeOut": 15000,"Namespace": "23b63b57-c762-4778-b141-4d16db969984","ListenInterval": 1000,"ServiceName": "LoadBalanceConfig","GroupName": "DEFAULT_GROUP","ClusterName": "DEFAULT","RegisterEnabled": true,"InstanceEnabled": true,"Ephemeral": true,"ConfigUseRpc": true,"NamingUseRpc": true,"LBStrategy": "WeightRoundRobin"}} 

修改项目appsettings.json文件

{
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft.AspNetCore": "Warning"
    }
  },
  "NacosConfig": {
    "Listeners": [
      {
        "Optional": false,
        "DataId": "LoadBalanceConfig", //Data Id 配置列表查看 命名空间ID
        "Group": "DEFAULT_GROUP"
      }
    ],
    "Optional": false,
    "Namespace": "23b63b57-c762-4778-b141-4d16db969984", //命名空间查看
    "ServerAddresses": [ "http://192.168.56.1:8848/" ] //你的nacos 实际访问地址
  },
  "AllowedHosts": "*"
}


 修改 默认控制器为  

 //private static readonly string[] Summaries = new[]//{//    "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"//};private readonly ILogger<WeatherForecastController> _logger;private readonly INacosNamingService _nacosNaming;public WeatherForecastController(ILogger<WeatherForecastController> logger, Nacos.V2.INacosNamingService nacosNaming)  {_logger = logger;_nacosNaming = nacosNaming;}[HttpGet]public string Get(){ var nacosConfig=_nacosNaming.SelectOneHealthyInstance("UserService", "DEFAULT_GROUP").GetAwaiter().GetResult();return nacosConfig.Ip+":"+nacosConfig.Port;}

总体来说  第一步 我们写了一个服务项目 启动了三个接口 分别为8001  8002  8003  注册到了nacos 

现在我们又创建了一个新的i项目 用来请求之前的服务  如果服务能自动切换端口则 负责均衡成功。

启动当前服务   快速发起请求   实现负载均衡

配置中心比较Apollo与Nacos_appollo 和 nacos-CSDN博客

这篇关于net6 core 接入nacos 实现服务注册入门使用,心跳检测和负载均衡的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1122557

相关文章

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3