首页 > 编程知识 正文

net微服务架构有哪些,netcore分布式服务框架

时间:2023-05-06 15:14:49 阅读:42625 作者:1099

. Net Core分布式微服务框架介绍- Jimu系列文章

[原文]

. Net Core分布式微服务框架介绍- Jimu [原文] .Net Core分布式微服务框架- Jimu附加Swagger支持[原文][正文]

. Net Core分布式微服务框架介绍- Jimu一,前言参加了aelf于2019年举办的. Net论坛,从各路大神推荐使用. Net Core开始,随着项目的开发,所有工作都将. netCore跨平台的特点,再加上近几年微服务热度不断增加,我们非常希望能够使用一个比较完善的微服务框架。 经过反复搜索和检索,大神grissom007博客地址开发的微服务框架Jimu无可奈何地发现大神很忙,很多资料都没有。 所以我打算转载大神的使用教程,增加个人的一点见解文艺发夹。 我在写博客和框架方面很弱,所以在写的时候可能会有一些错误。 请向各路大人物指出批评。

grissom007大神这几年一直在. Net平台上开发企业APP应用程序。 使用过的. Net框架不多。 (具体数量不详,令人印象深刻的是Asp.Net MVC,WPF。 其他很多都是根据微软开发的框架打包形成新的框架,大多数没有命名就在历史中消失了)。 另一方面,用grissom007开发的框架也不少。 5 - 8套吧。 改变框架与改变公司成正比。 (每次换公司,至少换一套框架) )不能见人)当时觉得贵,后来觉得很low。 随波逐流,从winform时代到现在提供火热的微服务。 在网上阅读各种博客、新闻、评论、代码,了解微服务概念,结合网上开源代码和思想,grissom007是一个全面的微服务框架- Jimu

Jimu是一个易于使用的微服务框架,升级到. Net Core 2.0 (当前为. Net Core 3.1 ),使用多个开放源代码库支持分布式、高并发和负载平衡,包括服务治理和rru Jimu继续反复开发。 名称-希望像积木一样,用她开发项目可以像积木一样轻松快捷地控制,确保项目的安全性和稳定性,扩展整体结构,实现高并发性和分散性。

二、功能技术服务注册:指定服务器地址,或通过扩展支持其他APP应用(如consul -已支持、redis、 zookeeper )服务提供服务器地址或通过扩展支持其他APP应用(例如consul -已支持、redis, zookeeper )服务调用:使用DotNetty或Flurl.Http实现RPC呼叫服务代理: Microsoft.CodeAnalysis解析服务接口生成动态代理归属监视心跳负载均衡:轮询算法(未实现的是加权最小连接数法、随机法、加权随机法、源地址xjzs )许可认证: jose-JWT对jwt许可的串行化: JSON.

如图所示,这里有四个作用。

客户端:各种客户端,这是一种抽象的说法,只要访问API网关,都可以访问客户端(手机、电脑……、 API网关(如果Service Server1和Service Server2访问API网关,则属于客户端)服务网关(如果要从外部访问,则必须通过该网关)具有非常重要的作用他相当于外部服务和内部服务之间的中介,负责接受和响应外部请求、调用内部服务以及服务管理等功能。 服务发现服务器:负责保存注册的服务,相当于服务名册。 Service Server注册服务是在名册上记录自己的名字。 API网关发现服务是指去查找在名册上注册的服务服务。 这就是微服务,所有业务需求都在这里四个,实现了服务的注册和发现方法,已经实现了两种方法。

独立于第三方APP应用程序,直接注册本地服务。 请参见github上的快速启动依赖于consul。 必须首先启动consul,然后服务才能在consul中注册。 API网关演示如何访问consul,在服务下使用consul作为服务容器,并在Jimu中实现分布式微服务

启动consul下载并安装consul https://www.consul.io/downloads.html

启动!

consul agent -dev 2.微服务项目创建基于. Net Core 3.1的类库项目,并添加jimu依赖关系

Install-Package Jimu附加服务,浏览空间: using Jimu;

[jimu(API/{service} ) ] publicclassuserservice 3360 ijimuservice ([ jimu service ] createdby=' grissom ' ) ]/指定id=pup

d) { return $"user id {id}, name enjoy!"; } }

这样我们就有了一个积木的接口加实现,下一步我们要把接口和实现制作成微服务的服务端

3. 微服务服务端项目

创建一个基于 .Net Core 3.1 的控制台项目, 并添加 Jimu.Server 和 Jimu.Server.Discovery.Consul 依赖

Install-Package Jimu.ServerInstall-Package Jimu.Server.Discovery.Consul

在 Main 函数中添加服务器启动代码,引用空间: using Jimu.Server;

static void Main(string[] args){ ApplicationHostServer.Instance.Run();}

创建配置文件JimuAppServerSettings.json到控制台项目下,文件属性写"如果较新则复制"

{//Nlog配置 "JimuNLogOptions": { "UseInService": true, "EnableConsoleLog": true, "EnableFileLog": true, "FileLogPath": "log", "FileLogLevelMax": "Error", "FileLogLevelMin": "Debug", "ConsoleLogLevelMax": "Error", "ConsoleLogLevelMin": "Debug" //"Configuration": "nlog.config" },//Consul配置 "ConsulOptions": { "Ip": "127.0.0.1", //consul ip 启动consul的那台主机的ip "Port": "8500", // consul port consul默认端口 "ServiceGroups": "jimu.sample", //服务注册所属的组别 "ServiceInvokeIp": "127.0.0.1", //这个微服务的地址 "ServiceInvokePort": "8001" //这个微服务监听的端口 },//这个微服务的配置 "TransportOptions": { "Ip": "127.0.0.1", //当前服务宿主ip "Port": 8001, //当前服务宿主端口 "Protocol": "Netty", //传输协议: Netty, Http "ServiceInvokeIp": "127.0.0.1", //当前服务宿主的地址 "ServiceInvokePort": "8001" },//微服务启动时加载的组件配置 "ServiceOptions": { "Path": "", //服务dll所在路径,默认当前目录 "LoadFilePattern": "JiMuStartService.dll" //需要加载的服务dll,支持统配符:*.dll,*.txt 写我们刚才创建的类库的生成dll的名称 }}

接下来在我们这个项目中把刚才创建的类库项目添加到项目引用,为的是能够在项目启动的时候,把类库项目最新的dll复制到运行目录中

至此我们的微服务创建完毕

4. 微服务客户端(ApiGateway)项目

创建一个基于 .Net Core 3.1 的 Asp.Net Core Web 应用程序(可选择 API 项目模版),并添加 Jimu.Client 和Jimu.Common.Discovery.ConsulIntegration 依赖

Install-Package Jimu.ClientInstall-Package Jimu.Client.Discovery.ConsulInstall-Package Jimu.Client.ApiGateway.Swagger

修改 Program.cs 类的代码, 以便添加对 jimu 的支持 删除Startup.cs文件

public class Program { public static void Main(string[] args) { Jimu.Client.ApplicationWebClient.Instance.Run(null, (env, app) => //ASP.NET Core 使用app.UseStaticFiles配置静态文件中间件,达到类似IIS中虚拟目录的效果,可访问位于 Web 根目录之外的文件 app.UseStaticFiles()); } }

在apiGateWay项目中新增JimuAppClientSettings.json文件

{ "SwaggerOptions": { "Title": "FirstJiMuService", "Version": "v0.1" ] }, //log4net配置 "JimuLog4netOptions": { "EnableConsoleLog": true, //是否打开Console输出 "EnableFileLog": true, //是否输出到文件 "FileLogPath": "log", //文件地址 "FileLogLevelMax": "Error", // "FileLogLevelMin": "Debug", "ConsoleLogLevelMax": "Error", "ConsoleLogLevelMin": "Debug" }, //Consul配置 "ConsulOptions": { "Ip": "127.0.0.1", //consul ip "Port": 8500, // consul port "ServiceGroups": "jimu.sample" //服务注册所属的组别 }, "DiscoveryOptions": { "UpdateJobIntervalMinute": 1 //单位分钟,1分钟刷新一次 }, "FaultTolerantOptions": { "RetryTimes": 0 //服务调用失败重试次数 }, "HealthCheckOptions": { "IntervalMinute": 1 //心跳监测时间间隔,单位分钟 }, "LoadBalanceOptions": { "LoadBalance": "Polling" //负载均衡算法: Polling - 轮询 }, "TransportOptions": { "Protocol": "Netty" //传输协议: Netty } } 5. 同时启动 服务端 和 客户端

然后在浏览器访问: https://localhost:44367/swagger/index.html  注意端口号

至此您使用jimu框架搭建的第一款微服务应用完成

6.  demo

grissom007Demo更多强悍的功能使用,请自己看 demo 领悟,由于时间有限,这里就不一一详解了,如果大家有兴趣,日后或者会有多篇幅和文档来介绍。
请下载 Jimu 源码, 或者下载项目 jimu.demo

 

本文Demo

CSDN:https://download.csdn.net/download/zhengjian1996/14933919

GitHub: https://github.com/ZhengJian1996/JiMuFristDemo

五、源码

请到 github pull 源码,包含有“巨量” demo

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。