1、前言

因为工作的关系,最近很少更新surging,因为surging 一直处在不温不火的状态,而自己每天利用业余时间进行完善,每天都是疲惫的状态,还要应付新手的提问,曾经一度想放弃,但是有些人劝说,surging 已经有一定的忠粉,放弃难免可惜,你可以发展收费版本,这样你也有动力进行更新,用户也有需求,付费也是情理之中,你也能更好的发展下去。就在上个月我剥离了企业版、预定版、社区版。

社区版:阉割版本,不带配置中心,文档,服务编排流程引擎,管理中心等功能,而且没有咨询服务

预定版:部分企业版本功能,有配置中心,文档,部分中间件,带咨询服务,

企业版:2天一对一培训课程,咨询服务,有配置中心,文档,服务编排流程引擎,管理中心,所有中间件,

社区版地址:https://github.com/dotnetcore/surging

2、什么是微服务

这几年微服务这个话题很火,可谓是你方唱罢我登场,什么框架都要和微服务牵扯点关系,和微服务没关系就会显得很low,对于微服务设计,没有明确的定义,所以市面大多都有自己的理解和定义,而我个人认为大部分开源都是老汤换新药,都是一个疗效没有本质的区别,最主要是骗骗领导,对外宣传公司的技术实力,而对于现实来讲,基本上真正的微服务都在一二线互联网公司,而且你会发现总公司,分公司,附属公司都要自己开发一套微服务,而这是为什么呢?因为有弊端,要开发属于自己的微服务,来满足业务的需求。那么我是怎么理解这个微服务呢?

微服务是针对业务的松耦合,是对于业务的解耦,也是粒度最小的功能业务模块,对于协议高度集成化,对于本地和远程调用的抽象化和服务治理保证了可靠性通信,技术人员只关注业务实现和拆分,而无需关注底层的业务实现。

而以上只是谈了微服务的思想,那么对于微服务就需要通过引擎扫描或者引用加载业务服务模块驱动生成服务提供者,而针对于行业解决方案,我们可以加载需要协议服务主机。那么我们下面来谈谈如何扩展协议服务主机

3、协议主机集成-behavior特性

针对于协议服务主机,我们有必要认识下behaviors,那么什么是behaviors呢?

behaviors是协议服务主机引擎特性, 每个扩展的主机都包含一个 behavior, 可以包含属性、数据、标识和方法,组件引用它时,它的属性、数据和方法会被合并到组件中,对于各自的behavior会在启动的时候进行初始化生成ServiceEntries。里面包含了类型,routepath, behaviors. 以下各个协议服务主机的behavior

BackgroundServiceBehavior:继承IServiceBehavior, 后台托管服务,可以构建后台定时任务

UdpBehavior:继承IServiceBehavior,可以集成UDP协议

WSBehavior:继承于IServiceBehavior,可以集成ws协议

GreeterBehavior: 继承于IServiceBehavior和Protos生成的GreeterBase,可以集成Grpc

MqttBehavior:继承于ServiceBase,可以集成MQTT协议

DnsBehavior:继承于IServiceBehavior,可以集成DNS

以上所有的Behavior,IServiceBehavior和ServiceBase都支持rest,rpc可靠性远程调用。

4、协议主机-Grpc

对于刚刚更新Grpc 服务主机,有些人还不会用,这里我们谈谈如何构建Grpc

业务接口

首先建立业务接口,代码如下

  [ServiceBundle("api/{Service}/{Method}")]
public interface IGreeterService : IServiceKey
{
}

proto文件

在创建proto 文件前,需要nuget安装Google.Protobuf,Grpc.Core,Grpc.Tools。

然后在业务接口模块创建的Protos/greet.proto 文件内容如下:

syntax = "proto3";

package Greet;

// The greeting service definition.
service Greeter {
// Sends a greeting
rpc SayHello (HelloRequest) returns (HelloReply) {}
} // The request message containing the user's name.
message HelloRequest {
string name = ;
} // The response message containing the greetings.
message HelloReply {
string message = ;
}

因为是利用Grpc.Tools工具 通过.proto文件生成C#资源文件。所以还需要编辑.csproject文件,需要把以下代码添加到.csproject文件中。

  <ItemGroup>
<Protobuf Include="Protos\greet.proto" GrpcServices="Server" />
</ItemGroup>

Behavior特性

针对于grpc需要再创建Behavior,并且继承通过Grpc.Tools生成的Greeter.GreeterBase和IServiceBehavior,代码如下

 public  partial class GreeterBehavior : Greeter.GreeterBase,IServiceBehavior
{ }

业务模块

针对于业务模块,需要继承Behavior和业务接口,代码如下

    public class GreeterService: GreeterBehavior, IGreeterService
{
public override Task<HelloReply> SayHello(HelloRequest request, ServerCallContext context)
{
return Task.FromResult(new HelloReply
{
Message = "Hello " + request.Name
});
}
}

配置

添加Surging.Core.Grpc引擎组件,配置GrpcPort,启用GrpcModule,配置surgingSettings.json如下

    "Ports": {
"HttpPort": "${HttpPort}|280",
"WSPort": "${WSPort}|96",
"MQTTPort": "${MQTTPort}|97",
"GrpcPort": "${GrpcPort}|95"
}
    "Packages": [
{
"TypeName": "EnginePartModule",
"Using": "${UseEngineParts}|ServiceProxyModule;DotNettyModule;NLogModule;MessagePackModule;ConsulModule;WSProtocolModule;MqttProtocolModule;EventBusRabbitMQModule;CachingModule;KestrelHttpModule;DnsProtocolModule;SwaggerModule;ApiGeteWayModule;SkywalkingModule;KestrelNLogModule;ServiceHostModule;GrpcModule"
}
]

通过以上服务端配置,那么再通过创建client 进行测试

客户端

而针对于客户端,也需要nuget 安装需要Google.Protobuf,Grpc.Core,Grpc.Tools。同时创建greet.proto 文件,然后我们需要编辑.csproject文件,需要把以下代码添加到.csproject文件中。

  <ItemGroup>
<Protobuf Include="Protos\greet.proto" GrpcServices="Client" />
</ItemGroup>

然后封装ServiceClient调用,代码如下

using Greet;
using Grpc.Core; namespace GrpcService1
{
public class ServiceClient
{
private static ChannelBase _channel;
private static Greeter.GreeterClient _client; static ServiceClient()
{
_channel = new Channel("127.0.0.1", , ChannelCredentials.Insecure);
_client = new Greeter.GreeterClient(_channel);
} public static HelloReply SayHello(string name)
{
return _client.SayHello(new HelloRequest
{
Name = name
});
}
}
}

再在Main函数中调用封装好的ServiceClient,代码如下

using System;

namespace GrpcService1
{
public class Program
{
public static void Main(string[] args)
{
var result = ServiceClient.SayHello("fanly"); Console.WriteLine("grpc Client Call SayHello():" + result);
Console.WriteLine("任意键退出...");
Console.ReadKey();
} }
}

运行结果如下图所示

surging 微服务引擎 -协议主机的Behavior特性的更多相关文章

  1. surging 微服务引擎 2.0 会有多少惊喜?

    surging 微服务引擎从2017年6月至今已经有两年的时间,这两年时间有多家公司使用surging 服务引擎,并且有公司搭建了CI/CD,并且使用了k8s 集群,这里我可以说下几家公司的服务搭建情 ...

  2. 谈谈surging 微服务引擎 2.0的链路跟踪和其它新增功能

    一.前言 surging是基于.NET CORE 服务引擎.初始版本诞生于2017年6月份,经过NCC社区二年的孵化,2.0版本将在2019年08月28日进行发布,经历二年的发展,已经全部攘括了微服务 ...

  3. surging 微服务引擎 1.0 正式发布

    surging 是一个分布式微服务引擎,提供高性能RPC远程服务调用,服务引擎支持http.TCP.WS.Mqtt协议,采用Zookeeper.Consul作为surging服务的注册中心,集成了哈希 ...

  4. (三)surging 微服务框架使用系列之我的第一个服务(审计日志)

    前言:前面准备了那么久的准备工作,现在终于可以开始构建我们自己的服务了.这篇博客就让我们一起构建自己的第一个服务---审计日志. 首先我们先创建两个项目,一个控制台的服务启动项目,一个业务的实现项目. ...

  5. 一)surging 微服务框架使用系列之surging 的准备工作rabbitmq安装(转载 https://www.cnblogs.com/alangur/p/8339905.html)

    (一)surging 微服务框架使用系列之surging 的准备工作rabbitmq安装   (1)下载erlang: http://www.erlang.org/download/otp_win64 ...

  6. 转载 (三)surging 微服务框架使用系列之我的第一个服务(审计日志)

    (三)surging 微服务框架使用系列之我的第一个服务(审计日志)   前言:前面准备了那么久的准备工作,现在终于可以开始构建我们自己的服务了.这篇博客就让我们一起构建自己的第一个服务---审计日志 ...

  7. Surging 微服务框架使用入门

    原文:Surging 微服务框架使用入门 前言 本文非 Surging 官方教程,只是自己学习的总结.如有哪里不对,还望指正.  我对 surging 的看法 我目前所在的公司采用架构就是类似与Sur ...

  8. Anno微服务引擎与传统应用相融合

    1.Anno是什么? Anno是一个微服务引擎.在此之前我们通过 Viper项目对Anno有一个基本的认识,并且Viper也受到的很多朋友的喜欢,截止发稿前Viper在GitHub收获了300多个星. ...

  9. 云图说丨初识华为云微服务引擎CSE

    摘要:微服务引擎(Cloud Service Engine,CSE),是用于微服务应用的云中间件,为用户提供注册发现.服务治理.配置管理等高性能和高韧性的企业级云服务能力 本文分享自华为云社区< ...

随机推荐

  1. JavaScrpt 介绍

    什么是 JavaScript? JavaScript 是一种直译式脚本语言,一种轻量级的脚本语言 什么是脚本语言? Script language指的是它不具备开发操作系统的能力,而是只用来编写控制其 ...

  2. 重学js之JavaScript 面向对象的程序设计(创建对象)

    注意: 本文章为 <重学js之JavaScript高级程序设计>系列第五章[JavaScript引用类型]. 关于<重学js之JavaScript高级程序设计>是重新回顾js基 ...

  3. maven引入本地jar包的方法

    maven作为包管理工具,好处不必多说 但是有些情况,比如需要引入第三方包,如快递鸟,支付宝,微信等jar包(当然有可能直接提供maven依赖) 如果直接下载到本地之后,怎么整合到自己的maven工程 ...

  4. NPOI导出2007格式报错:文件损坏

    这个问题,归根结底还是代码问题,如下修改了代码就可以了.左侧是会出现问题的代码,右侧是正确的代码,自己感受,我也是一口老血:

  5. 混合事务分析处理“HTAP”的技术要点分析

    HTAP是近些年来比较火的一个概念,本文将聊聊HTAP的前世今生及技术特点. 一.数据应用类别 根据数据的使用特征,可简单做如下划分.在选择技术平台之前,我们需要做好这样的定位. 1.1 OLTP 联 ...

  6. 小程序开发初体验,从静态demo到接入Bmob数据库完全实现

    之前我胖汾公司年会.问我能不能帮忙搞个小程序方便他们进行游戏后的惩罚/抽奖使用.出了个简单的设计图.大概三天左右做了个简单的小程序.目前提交审核了.对于写过一小段时间vue来说小程序很容易上手.写法和 ...

  7. Jmete压力测试、并发测试的简单方法

    我们的需求场景如下: 服务器硬件:(只有一台) 系统:CentOS 7 WebServer:Tomcat 7.0 Jdk:1.8 CPU:8核 2.9GHz两个 内存:16g 报名应用系统:只需要向外 ...

  8. 链表-LinkList

    什么是链表 维基百科:链表(Linked list)是一种常见的基础数据结构,是一种线性表,但是并不会按线性的顺序存储数据,而是在每一个节点里存到下一个节点的指针(Pointer).由于不必须按顺序存 ...

  9. 《菜鸟程序员成长之路:从技术小白到阿里巴巴Java工程师》

    <菜鸟程序员成长之路:从技术小白到阿里巴巴Java工程师> 国庆节快乐!一年一度长度排第二的假期终于来了. 难得有十一长假,作者也想要休息几天啦. 不管你是选择出门玩,还是在公司加班,在学 ...

  10. 配置eclipse编写html/js/css/jsp/java时自动提示

    配置eclipse编写html/js/css/jsp/java时自动提示步骤: 1.打开eclipse→Windows→Preferences→Java→Editor→Content Assist 修 ...