net core 微服务 快速开发框架
dymDemo
github 地址:https://github.com/duyanming/dymDemo
dym 分布式开发框架 Demo 熔断 限流 事件总线(包括基于内存的、rabbitmq的) CQRS DDD 实例 随后更新
dym 分布式开发框架
dym 是一个分布式开发框架,同时支持 .net core2.2 、.net frameworker4.6.1。
1、运行Demo
第一步:启动注册中心
进入项目文件夹 dymDemo\YY.AppCenter\bin\Debug\netcoreapp2.2 ,运行命令 dotnet AppCenter.dll
看到下图 说明运行成功
代码:默认监听6660端口
using dym.Rpc.Center;
static class Program
{
static void Main(string[] args)
{
Console.Title = "YY.AppCenter";
Bootstrap.StartUp(args);
} }
配置文件:dym.config
服务启动后会注册到<Servers>节点内
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<!--#lbs 配置-->
<Port>6660</Port>
<TimeOut>120000</TimeOut>
<Servers> </Servers>
</configuration>

第二步:启动服务Server
Server可以和 AppCenter 不在同一台电脑,也可以运行多个server 也可以负载均衡,高级用法随后介绍
进入项目文件夹 dymDemo\YY.Server\bin\Debug\netcoreapp2.2 ,运行命令 dotnet YY.Server.dll
看到下图 说明 Server 成功运行 并且已经注册到 注册中心(APPCenter)运行成功
代码:默认监听6659端口
using dym.Rpc.Server;
static class Program
{
static void Main(string[] args)
{
Bootstrap.StartUp(args);
} }
配置文件:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<!--0,0 第一位是 工作站,第二位数据中心
(所有的 APPservice 的 两位数不能重复例如不能存在【1,2】【1,2】)
可以存在【1,2】【2,1】
-->
<IdWorker>0,0</IdWorker>
<!--App名称-->
<AppName>App001</AppName>
<!--监听端口-->
<Port>6659</Port>
<!--权重-->
<Weight>1</Weight>
<!--功能 非dym.Plugs 加入方式-->
<FuncName></FuncName>
<!--忽略的功能 Trace,Logic-->
<IgnoreFuncName></IgnoreFuncName>
<!--超时时间毫秒-->
<TimeOut>20000</TimeOut>
<!--注册到的目标-->
<Ts Ip="10.112.93.122" Port="6660"/>
<IocDll>
<!-- IOC 仓储--><!--
<Assembly>dym.Repository</Assembly>
--><!-- 领域--><!--
<Assembly>dym.Domain</Assembly>
--><!-- 查询服务--><!--
<Assembly>dym.QueryServices</Assembly>
--><!--事件Handler--><!--
<Assembly>dym.Command.Handler</Assembly>-->
</IocDll> </configuration>
业务代码示例:dym.Plugs.YYTestService
服务启动 配置
using System;
using dym.EngineData; namespace dym.Plugs.YYTestService
{
//服务启动 配置
public class YYTestBootstrap : IPlugsConfigurationBootstrap
{
public void ConfigurationBootstrap()
{
/*
* 服务启动的时候会执行此方法
* 也可以用来加载插件的配置
*/ } public void PreConfigurationBootstrap()
{
//Ioc 注入之前
}
}
}
业务编写:
using dym.EngineData;
using System;
using System.Collections.Generic;
using System.Text; namespace dym.Plugs.YYTestService
{
public class MyFirstModule: BaseModule
{
public MyFirstModule() {
} public ActionResult MyT() {
var xx = RequestString("XX");
Console.WriteLine($"来自客户端的消息:{xx}");
return new ActionResult(true,new { Msg= " I from dym.Plugs.YYTestService MyFirstModule!" },null, xx);
}
}
}

第三步:启动Client测试分布式框架是否可以正常运行
启动Client 测试 Client调用 Server是否成功
进入项目文件夹 dymDemo\YY.Client\bin\Debug\netcoreapp2.2 ,运行命令 dotnet YY.Client.dll
看到下图 说明 Client 成功运行
客户端代码:
using System; using dym.Rpc.Client; namespace YY.Client
{
class Program
{
static void Main(string[] args)
{
/*
* 1、AppName
* 2、注册中心
* 3、注册中心端口
* 4、关闭调用链追踪
*/
DefaultConfigManager.SetDefaultConfiguration("YY.Client", "127.0.0.1", 6660,false);
Restart:
Console.WriteLine("请输入一个消息然后回车发送到服务器:");
var inputMsg = Console.ReadLine();
var input = new InputTest()
{
channel = "dym.Plugs.YYTest",
router = "MyFirst",
method = "MyT",
XX = $"{inputMsg}参数1"
}; var rltStr = Connector.BrokerDns(input);
//var outPut = Newtonsoft.Json.JsonConvert.DeserializeObject<dynamic>(rltStr);
Console.WriteLine(rltStr); Console.WriteLine("-----------------------------------------------------------------------------"); var inputYYTest = new InputTest()
{
channel = "dym.Plugs.YYTest",
router = "MySecond",
method = "MyT",
XX = $"{inputMsg}参数2"
};
var rltStrYY = Connector.BrokerDns(inputYYTest);
//var outPutYY = Newtonsoft.Json.JsonConvert.DeserializeObject<dynamic>(rltStr);
Console.WriteLine(rltStrYY);
goto Restart;
}
} public class InputTest : InputDtoBase
{
public string XX { get; set; }
}
}

net core 微服务 快速开发框架的更多相关文章
- net core 微服务 快速开发框架 Viper 初体验2020-10-17
1.Viper是什么? Viper 是.NET平台下的Anno微服务框架的一个示例项目.入门简单.安全.稳定.高可用.全平台可监控.底层通讯可以随意切换thrift grpc. 自带服务发现.调用链追 ...
- 不死的小强 .net core 微服务 快速开发框架 Viper 限流
1.Viper是什么? Viper 是.NET平台下的Anno微服务框架的一个示例项目.入门简单.安全.稳定.高可用.全平台可监控.底层通讯可以随意切换thrift grpc. 自带服务发现.调用链追 ...
- 一个轻量级的.Net Core微服务快速开发的轮子
前言 Adnc是一个轻量级的.Net Core微服务快速开发框架,同时也可以应用于单体架构系统的开发.框架基于JWT认证授权.集成了一系列微服务配套组件,代码简洁.易上手.学习成本低.开箱即用 ...
- .netcore 微服务快速开发框架 Anno&Viper 注册中心 (服务上线下线预警通知)
1.微服务时代,服务上线先预警通知 在微服务大行其道的今天,相信很多人都用上了微服务或者是微服务的概念也已经有了一个深刻的了解.今天我们不在这里展开阐述,今天我们要说的是微服务伴侣预警通知. 2.注册 ...
- 基于SpringBoot-Dubbo的微服务快速开发框架
简介: 基于Dubbo的分布式/微服务基础框架,为前端提供脚手架开发服务,结合前一篇--Web AP快速开发基础框架,可快速上手基于Dubbo的分布式服务开发,项目代码: https://github ...
- .netcore 微服务快速开发框架 Anno&Viper -分布式锁是个什么鬼
1.什么是锁 锁是为了解决多线程或者多进程资源竞争的问题. 同一进程的多个线程资源竞争可以用lock解决. lock 关键字可确保当一个线程位于代码的临界区时,另一个线程不会进入该临界区. 如果其他线 ...
- net core 微服务框架 Viper 调用链路追踪
1.Viper是什么? Viper 是.NET平台下的Anno微服务框架的一个示例项目.入门简单.安全.稳定.高可用.全平台可监控.底层通讯可以随意切换thrift grpc. 自带服务发现.调用链追 ...
- hello world .net core 微服务框架 Viper
1.Viper是什么? Viper 是.NET平台下的Anno微服务框架的一个示例项目.入门简单.安全.稳定.高可用.全平台可监控.底层通讯可以随意切换thrift grpc. 自带服务发现.调用链追 ...
- Adnc如何本地调试 - 一个轻量级的.Net Core微服务开发框架
前言 Adnc是一个轻量级的.Net Core微服务开发框架,同样适用于单体架构系统的开发. 如果只是想本地调试,只需要安装必备软件,必备软件除开发工具外,其它软件建议大家都使用`do ...
随机推荐
- meta生成器 —— 表单元素组件
手写代码? meta(json)需要手写吗?别闹,手写多麻烦呀,我这么懒怎么可能手写,这辈子都别想,所以要弄个工具出来,咱们说干就干. 这个工具,说白了本身就是一个表单,一个meta属性对应一个met ...
- 关于在异步操作中访问React事件对象的小问题
最近撸React的代码时踩了个关于事件处理的坑,场景如下:在监听某个元素上会频繁触发的事件时,我们往往会对该事件的回调函数进行防抖的处理:防抖的包装函数大致长这样: debounce = (fn, d ...
- flutter权限管理permission_handler
flutter权限管理permission_handler 添加依赖 #权限 permission_handler: ^3.0.0 使用 在android的mainfest中添加权限: <use ...
- python基础入门语法和变量类型(二)
列表 列表是 Python 中使用最频繁的数据类型,它可以完成大多数集合类的数据结构实现,可以包含不同类型的元素,包括数字.字符串,甚至列表(也就是所谓的嵌套). 和字符串一样,可以通过索引值或者切片 ...
- 2020 计蒜之道 预赛 第三场 石子游戏(简单)(暴力DP)
石子游戏(简单) 原题链接 思路: 通过形式容易看出是一道DP.其中异或和的情况只有64种,所以我们可以开一维来记录当前异或和的状态. 利用dp[当前位置][异或和][是否选择当前]来进行状态转移.时 ...
- Python爬虫之反爬虫---使用随机User-Agent
在编写爬虫时,大多数情况下,需要设置请求头.而在请求头中,随机更换User-Agent可以避免触发相应的反爬机制. 使用第三方库fake-useragent便可轻松生成随机User-Agent. 使用 ...
- Oracle复习(复习精简版v1.0)
自己没记不住的,超基础Oracle知识,新手可以看一下. 大多数例子是用scott用户中的emp表完成 排序:order by 列名 desc是降序,默认是升序: update 表名 set 列 ...
- Android Studio 自定义字体显示英文音标
android:fontFamily="serif" 网上查了很多自定义字体的方式,或多或少都有些麻烦,最后还是尝试着认为内置字体不应该实现不了英文音标问题,就一个一个字体试了一下 ...
- Kubernetes Pod水平自动伸缩(HPA)
HPA简介 HAP,全称 Horizontal Pod Autoscaler, 可以基于 CPU 利用率自动扩缩 ReplicationController.Deployment 和 ReplicaS ...
- Centos-强制将内存中数据写入磁盘-sync
sync 强制将内存中数据写入磁盘,以免数据丢失.在linux系统中,修改过的操作并不会立即写入磁盘,而是先写到内存中,通过buffer队列当达到指定时间或者指定大小再一次性写入磁盘,提高IO效率,正 ...