网关部署

1、在网关服务器上,安装.net core 3.1运行环境;

2、到 https://www.cnblogs.com/IWings/p/13354541.html 下载Gateway.zip,解压到网关服务器

3、打开appsettings.json配置文件,修改里面的配置,我的配置如下所示:

{
"Port": ,
"UnLockKeyTimeout": , //当微服务掉线后,lockkey有效期(单位:毫秒)
"DataFolder": "./data", //数据存放目录
"AllowIps": [], //允许哪些ip成为微服务,为空表示允许所有ip //"SSL": { //SSL为可选项
// "Cert": "../../../../pfx/gateway_server.pfx",
// "Password": "123456",
// //配置client.pfx的哈希值,仅接受client.pfx证书请求
// "AcceptCertHash": [ "ACE9C81C11688415DBFA1B39702450A8590BDB0B" ] //被接受的对方证书的hash值,空数组表示信任所有证书
// }, //"Cluster": { //配置集群里的裁判地址,不做集群此项可移除
// "Referee": {
// "Address": "127.0.0.1",
// "Port": 8919
// }
//}, //"ShareFolder": "./shares",//共享文件目录 "ServiceProviderAllocator": {
"FullName": "JMS.ServiceProviderAllocator",
"Assembly": "JMS.Gateway"
},
"Logging": {
"LogLevel": {
"Default": "Debug",
"System": "Information",
"Microsoft": "Information"
}
}
}

然后运行命令 dotnet JMS.Gateway.dll ,启动网关程序。(建议用xshell启动,因为控制台能输出中文)

看到以下信息,表示启动成功

创建微服务项目

打开vs,新建一个.net core 3.1控制台项目,名称为:MyHelloworldService

引用下面的 nuget 包:

Microsoft.Extensions.Logging.Console

JMS.ServiceProvider

然后Program.cs代码如下:

using JMS;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using System; namespace MyHelloworldService
{
class Program
{
static void Main(string[] args)
{
var port = ; //提供微服务的端口 var gateways = new NetAddress[] {
new NetAddress("192.168.40.131" , ) //网关地址
}; ServiceCollection services = new ServiceCollection();
services.AddLogging(loggingBuilder =>
{
loggingBuilder.SetMinimumLevel(LogLevel.Debug);
loggingBuilder.AddConsole();
}); var msp = new MicroServiceHost(services);
msp.Build(port, gateways)
.Run();
}
}
}

运行控制台,如果成功连接网关,会如下显示:

编写提供的服务

在项目中,新建一个类,名称为:HelloworldController,继承 JMS.MicroServiceControllerBase

namespace MyHelloworldService
{
class HelloworldController : MicroServiceControllerBase
{
public string Hello()
{
return $"你好,现在时间是: {DateTime.Now.ToShortDateString()}";
}
}
}

然后回到Program.cs代码中,在 new MicroServiceHost(services) 的后面加入服务注册语句

            var msp = new MicroServiceHost(services);
msp.Register<HelloworldController>("Hello world");//服务名称为Hello world
msp.Build(port, gateways)
.Run();

到这里,一个最简单的微服务就写完了。

编写调用端

下面,我们再创建一个控制台项目,用来调用微服务,项目名称为:TestApplication

引用下面的 nuget 包:

Microsoft.Extensions.Logging.Console

JMS.Invoker

Program.cs代码如下:

using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using System;
using System.Threading; namespace TestApplication
{
class Program
{
static IServiceProvider ServiceProvider;
static JMSClient CreateMST()
{
var logger = ServiceProvider.GetService<ILogger<JMSClient>>();
return new JMSClient("192.168.40.131", , null, logger);
}
static void Main(string[] args)
{
Thread.Sleep();//等服务启动完毕 ServiceCollection services = new ServiceCollection();
services.AddLogging(loggingBuilder =>
{
loggingBuilder.SetMinimumLevel(LogLevel.Debug);
loggingBuilder.AddConsole();
});
ServiceProvider = services.BuildServiceProvider(); using ( var tran = CreateMST() )
{
var api = tran.GetMicroService("Hello world");
var ret = api.Invoke<string>("Hello");
Console.WriteLine(ret);
} }
}
}

鼠标右键解决方案-》设置启动项目...

F5启动调试,两个控制台输出如下:

大家回看调用端的代码,这个地方:

是用字符串的方式,指明了调用微服务的Hello方法,这种方式,调用者如果没有一个微服务的api列表(类似 swagger ),很难搞清楚服务端提供的方法有哪些,

下面,我们用另一种方式调用。

给服务端加注释

我把服务端HelloworldController代码,加上注释,并追加一个time参数

    class HelloworldController : MicroServiceControllerBase
{
/// <summary>
/// 哈喽方法
/// </summary>
/// <param name="time">我当前的时间</param>
/// <returns>中文问候语</returns>
public string Hello(DateTime time)
{
return $"你好,你给的时间是: {time.ToShortDateString()}";
}
}

并且指定项目编译时,需要生成xml文档

调用端代码改为:

            using ( var tran = CreateMST() )
{
var api = tran.GetMicroService("Hello world");
var code = api.GetServiceClassCode("TestApplication" , "HelloWorldApi");
File.WriteAllText("../../../HelloWorldApi.cs", code, Encoding.UTF8);
}

api.GetServiceClassCode生成客户端代码(服务端必须是debug模式),把代码写到HelloWorldApi.cs文件当中

打开生成的HelloWorldApi.cs文件,效果如下:

然后,调用端代码,就可以这么写了:

            using ( var tran = CreateMST() )
{
var api = tran.GetMicroService<HelloWorldApi>();
var ret = api.Hello(DateTime.Now);
Console.WriteLine(ret);
}

服务器的方法该怎么用,是一目了然了

上一篇 概述    下一篇 编写分布式事务

JMS微服务开发示例(一)Hello world的更多相关文章

  1. 微软微服务eShopOnContainers示例之EventBusRabbitMq解析与实践

    eShopOnContainers eShopOnContainers是微软官方的微服务架构示例,GitHub地址https://github.com/dotnet-architecture/eSho ...

  2. 【新书推荐】《ASP.NET Core微服务实战:在云环境中开发、测试和部署跨平台服务》 带你走近微服务开发

    <ASP.NET Core 微服务实战>译者序:https://blog.jijiechen.com/post/aspnetcore-microservices-preface-by-tr ...

  3. 【开源】.net微服务开发引擎Anno 让复杂的事简单点- 日志、链路追踪一目了然 (上)

    1.Anno简介? Anno是一个微服务框架引擎.入门简单.安全.稳定.高可用.全平台可视化监控.依赖第三方框架少.详情请查看<[开源].net微服务开发引擎Anno开源啦> 本章主题:. ...

  4. 构建微服务开发环境4————安装Docker及下载常用镜像

    [内容指引] 下载Docker: Mac下安装Docker: Windows下安装Docker; 下载常用docker镜像. 一.下载Docker 1.Mac适用Docker下载地址:https:// ...

  5. 构建微服务开发环境8————Hello 微服务

    [内容指引] 1.用IDEA打开微服务项目; 2.更新Maven依赖: 3.IntelliJ IDEA JDK配置; 4.修改代码: 5.运行微服务: 6.将代码变更提交到Github. 经过前面的努 ...

  6. 黑少微服务商店之Iron Cloud微服务开发云

    近日,由黑少微服务研发团队推出的Iron Cloud微服务开发云已经正式对外提供服务,这是国内第一家基于云端操作的微服务专业开发工具. Iron Cloud 微服务开发云(www.ironz.com) ...

  7. Java生鲜电商平台-SpringCloud微服务开发中的数据架构设计实战精讲

    Java生鲜电商平台-SpringCloud微服务开发中的数据架构设计实战精讲 Java生鲜电商平台:   微服务是当前非常流行的技术框架,通过服务的小型化.原子化以及分布式架构的弹性伸缩和高可用性, ...

  8. mPass多租户系统微服务开发平台

    目录 项目总体架构图 基于SpringBoot2.x.SpringCloud并采用前后端分离的企业级微服务,多租户系统架构微服务开发平台 mPaaS(Microservice PaaS)为租户业务开发 ...

  9. python 微服务开发书中几个方便的python框架

    python 微服务开发是一本讲python 如果进行微服务开发的实战类书籍,里面包含了几个很不错的python 模块,记录下,方便后期回顾学习 处理并发的模块 greenlet && ...

随机推荐

  1. 基于层级表达的高效网络搜索方法 | ICLR 2018

    论文基于层级表达提出高效的进化算法来进行神经网络结构搜索,通过层层堆叠来构建强大的卷积结构.论文的搜索方法简单,从实验结果看来,达到很不错的准确率,值得学习   来源:[晓飞的算法工程笔记] 公众号 ...

  2. 使用Kubernetes、K3s和Traefik2进行本地开发

    作者简介 Vyacheslav,拥有运维和项目管理经验的软件工程师 这篇文章将承接我此前搭建的本地Docker开发环境,具体步骤已经放在在以下网址: https://github.com/Vorone ...

  3. 手摸手带你理解Vue的Computed原理

    前言 computed 在 Vue 中是很常用的属性配置,它能够随着依赖属性的变化而变化,为我们带来很大便利.那么本文就来带大家全面理解 computed 的内部原理以及工作流程. 在这之前,希望你能 ...

  4. 入门大数据---Hbase_Java_API

    一.简述 截至到目前 (2019.04),HBase 有两个主要的版本,分别是 1.x 和 2.x ,两个版本的 Java API 有所不同,1.x 中某些方法在 2.x 中被标识为 @depreca ...

  5. linux版本百度网盘只能登录一次的解决方法

    rm -rf ~/baidunetdisk 重新启动百度网盘,解决-

  6. P2220 [HAOI2012]容易题【快速幂】

    题目描述 为了使得大家高兴,小Q特意出个自认为的简单题(easy)来满足大家,这道简单题是描述如下: 有一个数列A已知对于所有的A[i]都是1~n的自然数,并且知道对于一些A[i]不能取哪些值,我们定 ...

  7. 恕我直言你可能真的不会java第10篇-集合元素归约

    Stream API为我们提供了Stream.reduce用来实现集合元素的归约.reduce函数有三个参数: Identity标识:一个元素,它是归约操作的初始值,如果流为空,则为默认结果. Acc ...

  8. JAVA7新属性之放宽switch的使用限制

    在Java7发布之后,关于switch的用法上,除了char,byte,short,int之外,允许了String.例如(不可以为null): public class Title { public ...

  9. 【秒懂Java】【02_搭建开发环境】01_Java开发必备

    这篇文章主要讲解:要想使用Java来开发软件,需要做哪些准备工作? 配置电脑 作为一名开发人员,对文件的类型.大小等信息是比较敏感的,所以建议你的电脑做2个配置: 显示文件扩展名 文件扩展名(File ...

  10. css中 出现height为100%失效的原因及解决方案

    我们都知道需要给html和body标签设置了高度height:100%之后,再给内部的div设置height:100%的时候,内部div的高度100%才会起到作用.这是由于:%是一个相对父元素计算得来 ...