JMS微服务远程调用性能测试 vs .Net Core gRPC服务
gRPC性能测试(.net 5)
创建一个最简单的gRPC服务,服务器代码如下:
using Grpc.Core; using Microsoft.Extensions.Logging; using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; namespace GrpcService1 { public class GreeterService : Greeter.GreeterBase { private readonly ILogger<GreeterService> _logger; public GreeterService(ILogger<GreeterService> logger) { _logger = logger; } public override Task<HelloReply> SayHello(HelloRequest request, ServerCallContext context) { return Task.FromResult(new HelloReply { Message = "Hello " + request.Name + DateTime.Now.ToString("HH:mm:ss") }); } } }
创建一个c#控制台程序作为gRPC客户端,代码如下:
using System; using System.Net.Http; using System.Threading.Tasks; using Grpc.Net.Client; namespace GrpcGreeterClient { class Program { static async Task Main(string[] args) { System.Threading.Thread.Sleep(3000); // The port number(5001) must match the port of the gRPC server. using var channel = GrpcChannel.ForAddress("http://localhost:5000"); var client = new Greeter.GreeterClient(channel); System.Diagnostics.Stopwatch sw = new System.Diagnostics.Stopwatch(); sw.Start(); for (int i = 0; i < 1000; i++) { var reply = await client.SayHelloAsync( new HelloRequest { Name = "GreeterClient" }); //Console.WriteLine("Greeting: " + reply.Message); } sw.Stop(); Console.WriteLine("用时:" + sw.ElapsedMilliseconds + "ms"); Console.WriteLine("Press any key to exit..."); Console.ReadKey(); } } }
同时启动这两个工程,最后客户端调用1000次服务器,用时:1405ms
注:服务器端已经关闭日志,开启日志的话,用时7000多ms
JMS性能测试(.net 5)
创建一个最简单的微服务,代码如下:
using System; using System.Collections.Generic; using System.Text; namespace JMS.MicroServiceHost2.Controllers { public class DemoController : BaseController { public string Hello(string name) { return "Hello " + name + DateTime.Now.ToString("HH:mm:ss"); } } }
创建一个c#控制台程序作为客户端,代码如下:
using System; using System.Net.Http; using System.Threading.Tasks; using Grpc.Net.Client; namespace GrpcGreeterClient { class Program { static async Task Main(string[] args) { System.Threading.Thread.Sleep(3000); using (JMS.JMSClient jmsClient = new JMS.JMSClient("47.52.0.186", 8900)) { var service = jmsClient.GetMicroService("DemoService"); System.Diagnostics.Stopwatch sw = new System.Diagnostics.Stopwatch(); sw.Start(); for (int i = 0; i < 1000; i++) { var ret = service.Invoke<string>("Hello", "GreeterClient"); } sw.Stop(); Console.WriteLine("用时:" + sw.ElapsedMilliseconds + "ms"); } Console.WriteLine("Press any key to exit..."); Console.ReadKey(); } } }
同时启动这两个工程,最后客户端调用1000次服务器,用时:154ms
分类:
JMS
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)