系列文章
[原文]
[本文]
从2019年参加aelf举办的.Net论坛,各路大神推荐使用.netCore开始,伴随着项目的开发,所有工作已经迁移到.netCore平台上。.netCore 跨平台的特点加之近几年微服务热度增加,非常的希望有比较完善的微服务框架能够使用。经过反复的搜寻和查找,找到了大神grissom007 博客地址 开发的微服务框架Jimu 奈何大神太忙,很多资料没有跟上。所以我打算转载大神的使用教程,并添加个人一点微薄的见解在里面。本人在写博客和框架方面比较弱,编写过程中可能出现多多少少的失误,请各路大侠指正批评。
grissom007大神在近些年一直在 .Net 平台做企业应用开发,用过的 .Net 框架不多(具体数量不清,印象深刻的有 Asp.Net MVC,WPF,其他很多都是基于微软开发的框架做些封装而形成新的框架,大都是还没起好名就湮灭在历史长河中),而grissom007开发的框架倒是不少(5 - 8 套吧), 换框架与换公司成正比(每换一家公司,至少换一套框架),很多都见不得人(当时觉得高大上,后来觉得很low)。 随波逐流从 winform 年代到现在热火朝天的微服务,网上阅读各式各样的博客、新闻、评论、代码,懂了点微服务的概念,结合网上开源代码和思想,grissom007开发出一个全面的微服务框架 - Jimu (中文名:积木)。
Jimu 是一个基于.Net Core 2.0 (现已升级.Net Core 3.1)简单易用的微服务框架,使用了大量的开源库, 支持分布式、高并发和负载均衡, 实现了服务治理和 RPC 调用。Jimu 在持续迭代开发中。正如其中文名 - 积木,希望用她来开发项目像搭积木一样简单快速可控,使项目安全可靠稳定,整体架构可拓展、高并发、分布式。
如图所示,这里有四种角色:
服务注册与发现, 已经实现了两种方式:
下面用 consul 作为服务容器,演示怎么用 Jimu 实现一个分布式的微服务
下载安装 consul https://www.consul.io/downloads.html
启动
consul agent -dev
创建一个基于 .Net Core 3.1 的类库项目,并添加 jimu 依赖
Install-Package Jimu
添加服务,引用空间: using Jimu;
[Jimu("api/{Service}")]
public class UserService : IJimuService
{
[JimuService(CreatedBy = "grissom")] // 指定服务的元数据, 该服务调用路径为 api/user/getname?id=
public string GetName(string id)
{
return $"user id {id}, name enjoy!";
}
}
这样我们就有了一个积木的接口加实现,下一步我们要把接口和实现制作成微服务的服务端
创建一个基于 .Net Core 3.1 的控制台项目, 并添加 Jimu.Server 和 Jimu.Server.Discovery.Consul 依赖
Install-Package Jimu.Server
Install-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复制到运行目录中
至此我们的微服务创建完毕
创建一个基于 .Net Core 3.1 的 Asp.Net Core Web 应用程序(可选择 API 项目模版),并添加 Jimu.Client 和Jimu.Common.Discovery.ConsulIntegration 依赖
Install-Package Jimu.Client
Install-Package Jimu.Client.Discovery.Consul
Install-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
}
}
然后在浏览器访问: https://localhost:44367/swagger/index.html 注意端口号
至此您使用jimu框架搭建的第一款微服务应用完成
grissom007Demo更多强悍的功能使用,请自己看 demo 领悟,由于时间有限,这里就不一一详解了,如果大家有兴趣,日后或者会有多篇幅和文档来介绍。
请下载 Jimu 源码, 或者下载项目 jimu.demo
本文Demo
CSDN:https://download.csdn.net/download/zhengjian1996/14933919
GitHub: https://github.com/ZhengJian1996/JiMuFristDemo
请到 github pull 源码,包含有“巨量” demo