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 微服务 快速开发框架的更多相关文章

  1. net core 微服务 快速开发框架 Viper 初体验2020-10-17

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

  2. 不死的小强 .net core 微服务 快速开发框架 Viper 限流

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

  3. 一个轻量级的.Net Core微服务快速开发的轮子

    前言     Adnc是一个轻量级的.Net Core微服务快速开发框架,同时也可以应用于单体架构系统的开发.框架基于JWT认证授权.集成了一系列微服务配套组件,代码简洁.易上手.学习成本低.开箱即用 ...

  4. .netcore 微服务快速开发框架 Anno&Viper 注册中心 (服务上线下线预警通知)

    1.微服务时代,服务上线先预警通知 在微服务大行其道的今天,相信很多人都用上了微服务或者是微服务的概念也已经有了一个深刻的了解.今天我们不在这里展开阐述,今天我们要说的是微服务伴侣预警通知. 2.注册 ...

  5. 基于SpringBoot-Dubbo的微服务快速开发框架

    简介: 基于Dubbo的分布式/微服务基础框架,为前端提供脚手架开发服务,结合前一篇--Web AP快速开发基础框架,可快速上手基于Dubbo的分布式服务开发,项目代码: https://github ...

  6. .netcore 微服务快速开发框架 Anno&Viper -分布式锁是个什么鬼

    1.什么是锁 锁是为了解决多线程或者多进程资源竞争的问题. 同一进程的多个线程资源竞争可以用lock解决. lock 关键字可确保当一个线程位于代码的临界区时,另一个线程不会进入该临界区. 如果其他线 ...

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

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

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

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

  9. Adnc如何本地调试 - 一个轻量级的.Net Core微服务开发框架

    前言     Adnc是一个轻量级的.Net Core微服务开发框架,同样适用于单体架构系统的开发.     如果只是想本地调试,只需要安装必备软件,必备软件除开发工具外,其它软件建议大家都使用`do ...

随机推荐

  1. AES字节数组加密解密流程

    AES类时微软MSDN中最常用的加密类,微软官网也有例子,参考链接:https://docs.microsoft.com/zh-cn/dotnet/api/system.security.crypto ...

  2. 浅谈Java 线程池原理及使用方式

    一.简介 什么是线程池? 池的概念大家也许都有所听闻,池就是相当于一个容器,里面有许许多多的东西你可以即拿即用.java中有线程池.连接池等等.线程池就是在系统启动或者实例化池时创建一些空闲的线程,等 ...

  3. jenkins 下载插件失败 有效的处理办法(亲测)

    jenkins 下载插件失败,提示: java.io.IOException: Downloaded file /app/jenkins_home/plugins/jacoco.jpi.tmp doe ...

  4. 什么是Lambda架构

    一.Lambda架构需求 Lambda架构背后的需求是由于MR架构的延迟问题.MR虽然实现了分布式.可扩展数据处理系统的目的,但是在处理数据时延迟比较严重.实际上如果内存和CPU足够强大,MR也可以实 ...

  5. MySQL/InnoDB中,乐观锁、悲观锁、共享锁、排它锁、行锁、表锁、死锁概念的理解

    文章出处:https://www.souyunku.com/2018/07/30/mysql/?utm_source=tuicool&utm_medium=referral MySQL/Inn ...

  6. Python3使用钉钉机器人推送消息(签名方式)

    import time import hmac import hashlib import base64 import urllib import json import requests impor ...

  7. Dockerfile构建镜像实战

    目录 一.常见Dockerfile指令 二.编写Centos Dockerfile 2.1.编写Dockerfile 2.2.构建 2.3.查看Docker镜像 2.4.运行镜像 三.CMD和ENTR ...

  8. Oracle学习(七)游标

    一.简介 定义 实质上是数据集,类似数组一样,把查询的数据集存储在内存当中. 使用时可以通过游标指向其中一条记录,也可以通过循环游标达到循环数据集的目的. 游标的种类 显式游标: 使用之前必须得先声明 ...

  9. python os模块方法详解

    os.access() 方法使用当前的uid/gid尝试访问路径.大部分操作使用有效的 uid/gid, 因此运行环境可以在 suid/sgid 环境尝试. 实例: os.chdir() 方法用于改变 ...

  10. 渗透测试方法论(qf总结)

    渗透测试(penetration testing , pentest)是实施安全评估(即审计)的具体手段.方法论是在指定.实施信息安全审计方案时,需要遵循的规则.惯例和过程.人们在评估网路.应用.系统 ...