jimu是一个基于.Net6.0 简单易用的微服务框架,参考了很多开源库以及想法,使用了大量的开源库(如 DotNetty, consul.net, Flurl.Http, Json.net, Log4net, Quartz.net ... ), 支持分布式、高并发和负载均衡, 实现了服务治理(如服务注册、发现、健康检测 ...)和 RPC 调用。

jimu(积木),正如其中文名,希望用她来开发项目像搭积木一样简单快速可控,使项目安全可靠稳定,整体架构可拓展、高并发、分布式。

特点

  1. 使用 Apache License 2.0 开源协议
  2. jimu 最核心的思想是 IOC 和 DI, 通过配置文件使用了 autofac 将组件注入到框架中,用组件来驱动框架,使框架更具弹性。
  3. 服务注册与发现: consul
  4. 动态网关
  5. 基于 DotNetty 的 RPC
  6. JWT 鉴权
  7. 负载均衡:轮询
  8. 容错策略: 重试
  9. 容器发布 docker
  10. 路由配置: Attribute 注解
  11. 日志记录: log4net, nlog
  12. Api 文档: swagger
  13. 链路跟踪: skywalking
  14. RESTful: Attribute 注解
  15. 健康监测
  16. 文件上存下载:多文件和单文件
  17. uri跳转: 服务端跳转指定的 url
  18. ORM: Dapper
  19. DDD: MiniDDD
  20. 缓存: Memcached
  21. 消息队列:RabbitMq

Install

  1. 启动 consul;
  2. 设置 Samples/ApiGateway, Samples/Server.Auth, Samples/Server.Order, Samples/Server.User 为启动项;
  3. 打开 http://localhost:54762/swagger/index.html

配置

服务端

日志

  1. JimuLog4netOptions: Log4net 日志组件

    {
    "JimuLog4netOptions":{
    "EnableConsoleLog":true,
    "EnableFileLog":true,
    "FileLogPath":"log",
    "FileLogLevel":"Debug,Info,Warn,Error",
    "ConsoleLogLevel":"Debug,Info,Warn,Error",
    "UseInService": true // ILogger 是否注入到 service
    }
    }
  2. JimuNLogOptions: NLog 组件

授权

  1. JwtAuthorizationOptions: Jwt 授权

    {
    "JwtAuthorizationOptions":{
    "ServiceInvokeIp": "${SERVICE_INVOKE_IP}", //服务宿主的地址
    "ServiceInvokePort": "${SERVICE_INVOKE_PORT}",
    "Protocol": "Netty", //传输协议:Http,Netty
    "SecretKey": "123456", //生成token 的钥匙
    "ValidateLifetime": true,
    "ExpireTimeSpan": "0.16:0:0", //token 有效时长: day.hour:minute:second
    "ValidateIssuer": false, //
    "ValidIssuer": "",
    "ValidateAudience": false,
    "ValidAudience": "",
    "TokenEndpointPath": "/v2/token", //获取 token 的路径
    "CheckCredentialServiceId": "Auth.IServices.IAuthService.Check(context)" //验证用户名密码是否正确的 service id, context 是 JwtAuthorizationContext,包含 UserName,Password等调用上下文信息
    }
    }

服务发现

  1. ConsulOptions: 使用 Consul 作为服务发现组件
{
"ConsulOptions":{
"Ip": "127.0.0.1", //consul ip
"Port": "8500", // consul port
"ServiceGroups": "ctauto.test.store", //服务注册所属的组别
"ServiceInvokeIp": "127.0.0.1", //服务宿主的地址
"ServiceInvokePort": "8004 //服务宿主的端口
}
}

服务调用协议

  1. TransportOptions: 服务调用的传输组件

    {
    "TransportOptions":{
    "Ip": "127.0.0.1", //服务宿主ip
    "Port": 8001, //服务宿主端口
    "Protocol": "Netty", //传输协议: Netty, Http
    "ServiceInvokeIp": "127.0.0.1", //服务宿主的地址
    "ServiceInvokePort": "8001"
    }

服务

  1. ServiceOptions: 服务配置
{
"ServiceOptions":{
"Path": "",//服务dll所在路径,默认当前目录
"LoadFilePattern": "IService.dll,Service.dll",//需要加载的服务dll,支持统配符:*.dll,*.txt
}
}
ORM

数据库接入

  1. Dapper

    {
    "DapperOptions": {
    "ConnectionString": "server=localhost;database=grissom_dev;user=root;pwd=root;",
    "DbType": "MySql" //数据库类型,支持: MySQL,SQLServer,Oracle,SQLite, PostgreSQL
    }
    }
MiniDDD Repository

MiniDDD 是一个轻量级的 DDD 框架, MiniDDD Repository 就是基于该框架的数据仓储,支持以下仓储

  1. Dapper

    {
    "MiniDDDDapperOptions": {
    "ConnectionString": "server=localhost;database=grissom_dev;user=root;pwd=root;",
    "DbType": "MySql" //数据库类型,支持: MySQL,SQLServer,Oracle,SQLite, PostgreSQL
    // 没有 sql 日志可输出
    }
    }
  2. EF

    {
    "MiniDDDEFOptions": {
    "ConnectionString": "server=localhost;database=grissom_dev;user=root;pwd=root;",
    "DbType": "MySql", //数据库类型,支持: MySQL,SQLServer,Oracle,SQLite, PostgreSQL
    "TableModelAssemblyName": "",//EF对应的表的实体类dll, Server 项目引用了则不需要设置
    "OpenLogTrace":false, //是否开启 sql 日志,一般 debug 时开启方面查看生成的 sql
    "LogLevel":"Debug" //日志级别: Debug,Information,Warning,Error
    }
    }
  3. SqlSugar

    {
    "MiniDDDSqlSugarOptions": {
    "ConnectionString": "server=localhost;database=grissom_dev;user=root;pwd=root;",
    "DbType": "MySql", //数据库类型,支持: MySQL,SQLServer,Oracle,SQLite, PostgreSQL
    "OpenLogTrace":false, //是否开启 sql 日志,一般 debug 时开启方面查看生成的 sql,没有日志级别可选
    }
    }

客户端

日志

  1. JimuLog4netOptions: Log4net 日志组件

    {
    "JimuLog4netOptions":{
    "EnableConsoleLog":true,
    "EnableFileLog":true,
    "FileLogPath":"log",
    "FileLogLevel":"Debug,Info,Warn,Error",
    "ConsoleLogLevel":"Debug,Info,Warn,Error"
    }
    }
  2. JimuNLogOptions: NLog 组件

授权

  1. JwtAuthorizationOptions: Jwt 授权,支持在客户端实现 jwt 授权,服务端不需要配置
{
"JwtAuthorizationOptions":{
"Protocol": "Http", //传输协议:Http,Netty
"SecretKey": "123456", //生成token 的钥匙
"ValidateLifetime": true,
"ExpireTimeSpan": "0.16:1:0", //token 有效时长: day.hour:minute:second
"ValidateIssuer": false, //
"ValidIssuer": "",
"ValidateAudience": false,
"ValidAudience": ""
}
}

服务发现

  1. ConsulOptions: 使用 Consul 作为服务发现组件
{
"ConsulOptions":{
"Ip": "127.0.0.1",//consul ip
"Port": 8500,// consul port
"ServiceGroups": "MyService",//服务注册所属的组别
}
}

服务发现刷新频率

  1. DiscoveryOptions:客户端会缓存已发现的服务,设定刷新频率

    {
    "DiscoveryOptions":{
    "UpdateJobIntervalMinute":1//单位分钟,1分钟刷新一次
    }
    }

容错机制

  1. FaultTolerantOptions:服务调用时的容错机制

    {
    "FaultTolerantOptions":{
    "RetryTimes":0 //服务调用失败重试次数
    }
    }

服务健康监测

  1. HealthCheckOptions: 根据已发现服务的ip,port 定时进行服务器心跳监测(客户端主动连接)

    {
    "HealthCheckOptions":{
    "IntervalMinute":1 //心跳监测时间间隔,单位分钟
    }
    }

负载均衡

  1. LoadBalanceOptions

    {
    "LoadBalanceOptions":{
    "LoadBalance":"Polling" //负载均衡算法: Polling - 轮询
    }
    }

远程代理

  1. ServiceProxyOptions

    {
    "ServiceProxyOptions":{
    "AssemblyNames":["IOrderServices.dll","IUserServices.dll"]//代理接口dll配置
    }
    }

客户端获取请求 token 的方式

  1. TokenGetterOptions

    {
    "TokenGetterOptions":{
    "GetFrom":"HttpHeader" //从http header 获取, Request.Headers["Authorization"]
    }
    }

服务调用

  1. TransportOptions: 服务调用的传输组件

    {
    "TransportOptions":{
    "Protocol":"Netty" //传输协议: Netty
    }
    }
 

dotnet core微服务框架Jimu介绍的更多相关文章

  1. 基于.NET CORE微服务框架 -surging的介绍和简单示例 (开源)

    一.前言 至今为止编程开发已经11个年头,从 VB6.0,ASP时代到ASP.NET再到MVC, 从中见证了.NET技术发展,从无畏无知的懵懂少年,到现在的中年大叔,从中的酸甜苦辣也只有本人自知.随着 ...

  2. hello world .net core 微服务框架 Viper

    1.Viper是什么? Viper 是.NET平台下的Anno微服务框架的一个示例项目.入门简单.安全.稳定.高可用.全平台可监控.底层通讯可以随意切换thrift grpc. 自带服务发现.调用链追 ...

  3. 基于.NET CORE微服务框架 -谈谈surging API网关

    1.前言 对于最近surging更新的API 网关大家也有所关注,也收到了不少反馈提出是否能介绍下Api网关,那么我们将在此篇文章中剥析下surging的Api 网关 开源地址:https://git ...

  4. 基于.NET CORE微服务框架 -浅析如何使用surging

    1.前言 surging受到大家这么强烈的关注,我感到非常意外,比如有同僚在公司的分享会上分享surging, 还有在博客拿其它的RPC框架,微服务做对比等等,这些举动都让我感觉压力很大,毕竟作为个人 ...

  5. 微服务框架Lagom介绍之一

    背景 Lagom是JAVA系下响应式 微服务框架,在阅读本文之前请先阅读微服务架构设计,Lagom与其他微服务框架相比,与众不同的特性包括: 目前,大多数已有的微服务框架关注于简化单个微服务的构建-- ...

  6. 微服务框架 ketchup 介绍

    1.背景 在ketchup诞生之前.期间也是用surging开发了两个项目.奈何surging没有文档,升级之后,只能从头在读一遍源码,了解新功能,会消耗大量的时间.商业化也使一些 想学习微服务的人望 ...

  7. net core 微服务框架 Viper 调用链路追踪

    1.Viper是什么? Viper 是.NET平台下的Anno微服务框架的一个示例项目.入门简单.安全.稳定.高可用.全平台可监控.底层通讯可以随意切换thrift grpc. 自带服务发现.调用链追 ...

  8. 基于.NET CORE微服务框架 -谈谈surging的服务容错降级

    一.前言 对于不久开源的surging受到不少.net同学的青睐,也受到.net core学习小组的关注,邀请加入.NET China Foundation以方便国内.net core开源项目的推广, ...

  9. dotnet core 微服务教程

    这个教程主要是对于第一次使用dotnet core开发的同学. 运行环境是在centos 7 , 使用了docker容器. 即这是一篇运行在linux的docker容器上的微服务的简单应用. 一. 安 ...

  10. 【Tars】腾讯微服务框架Tars介绍

    目录 1.介绍2.设计思路3.整体架构4.平台特性1. 介绍 Tars是[基于名字服务][使用Tars协议]的高性能[RPC]开发框架,同时配套一体化的[服务治理平台],帮助个人或者企业快速的以微服务 ...

随机推荐

  1. python语言:将多张图片压成一段视频——利用opencv-python库实现

    相关代码例子参见: All_finished_Demo.py ========================================= 这里将的功能就是用python语言实现将多张照片压成一 ...

  2. ubuntu环境下boost库的安装——Could NOT find Boost (missing: Boost_INCLUDE_DIR program_options) (Required is at least version "1.49.0")

    在Ubuntu环境下使用cmake编译软件,报错,提示信息: Could NOT find Boost (missing: Boost_INCLUDE_DIR program_options) (Re ...

  3. 关于腾讯会议pc端的使用教程

    一.首先先在官网下载pc端 下面是连接:腾讯会议_腾讯会议下载- 腾讯云 (tencent.com) 点击免费下载即可. 二.登录并创建会议 选择一种登录方式. 创建会议有快速会议和预定会议两种方式 ...

  4. 一分钟搭建Ghost个人网站博客系统

    什么是Ghost博客系统 Ghost 是一款设计简约.主题精致的个人博客系统,Ghost支持多用户创建和编辑,支持Markdown格式撰写文章,编辑的内容可即时预览. 创建轻量云主机 这里默认你已经有 ...

  5. python png 转 icon文件

    pip install pillow from PIL import Image def png_to_ico(png_path, ico_path): img = Image.open(png_pa ...

  6. 【YashanDB知识库】收集分区表统计信息采样率小于1导致SQL执行计划走偏

    [问题分类]性能优化,BUG [关键字]分区表,统计信息,采样率 [问题描述]收集表(分区表)级别的统计信息时,如果采样率小于1,dba_ind_statistics中partition_name i ...

  7. 傅里叶级数 傅里叶变换 FFT 时域 频域 功率谱 能量谱 功率谱密度PSD

    傅立叶级数是基于周期函数的,如果我们把周期推广到

  8. 所见即所得,赋能RAG:PDF解析里的段落识别

    前几天,有一位用户使用OCR产品识别多栏论文后向我们询问:要怎么解决不合适的断句.分段以及错误阅读顺序的问题? 我们用一个相似案例为大家直观展示这位用户遇到的情况. 如图中的多栏期刊,如果用OCR识别 ...

  9. ubuntu莫名的 系统出现文件系统只读

    运维记录 日期:2024年9月15日 问题描述: 在安装多个 LNMP 服务后,系统重启出现了问题.当尝试运行 apt update 命令时,系统出现了如下错误信息: 忽略:1 http://secu ...

  10. Flutter 2.8 正式发布

    文/ Tim Sneath,Flutter & Dart 产品经理 Flutter 已经更新到 2.8 正式版,发布了多项新特性和改进以不断改善移动和 Web 端的开发体验,同时也正在将桌面端 ...