为.Net Core 3.1 WebAPI 新增gRPC支持

这里简单记录下如何为.NetCore3.1的WebAPI项目新增gRPC支持,.Net 5 6 7大体上也差不多是这个思路,应该比3.1要简单一些,就不多赘述了,有需要可以参照本文问问gpt就足以了。 首先nuget引用包 Grpc.AspNetCore ,注意如果是3.1版本需要2.56版本的,2.57开始仅支持.net 6 7 8版本,而.Net Core 2.1是不能使用gRPC的,因为2.…

0评论

Docker、WSL启动时卡住的解决办法

偶尔会发生Windows下Docker启动时卡在Starting the Docker Engine...的情况,vscode进行wsl开发时也会发生这种情况,经过调查后,发现跟一个叫做LxssManager的进程有关,废话不多说,直接写解决方案。 #停止LxssManager服务 net stop LxssManager #启动LxssManager服务 net start LxssManage…

0评论

再记参数传递

之前虽然写过一篇值传递和引用传递的文章来讨论这个,但是当时还是太年轻了,写的过于理论化,今天遇到个坑,靠着gpt给我解读,今天总算是把这个知识点巩固好了,直接上结论。 值传递就是把传进来的值copy一份在函数体内使用,引用传递就是把外部变量对象在内存中的地址。 golang写的太少,忘了go的参数传递全都是按值传递的,也就是说,无论传递的是结构体还是结构体的指针,到了函数体内部实际上都是一份cop…

0评论

使用traefik-ingress代理https后端服务

服务器用的pve做虚拟机平台,然后pve的web面板是强制https的,我想用traefik-ingress去代理作为外部tls的pve,查了总计快20个小时,尝试了三次,终于得出解决方案,这里简单记录一下。 首先是用traefik的CRD定义一个ServersTransport: apiVersion: traefik.containo.us/v1alpha1 kind: ServersTran…

2评论

.NetCore WebApi通过中间件实现参数的日志打印

线上环境为了防止上下游扯皮,是有必要把接口的输入输出打印到日志中的,这样出了问题能够快速定位问题,没出问题也能直接把日志糊在对面脸上抓紧时间下班。 之前在.Net FrameWork的实现其实挺简单的,就是Global.aspx里的生命周期函数里写上就可以了,但是转到core之后,想当然的使用Filter来实现,遇到了不少问题,比如使用ActionFilter时,触发过滤器的时候,RequestB…

0评论

.NetCore的WebClient简单使用备忘

Http请求是web服务经常使用的东西,.NetCore主流使用的类库是WebClient,但是有时候经常要写一个post请求的时候,提笔忘字,防止以后忘了又得找一遍,这里直接记录一下简单的使用方法。 首先是Get请求,主要需要注意的是Encoding需要设置。 然后就是POST请求,发送一个对象作为body: 这里一定记得要设置ContentType和Encoding,不然接口会报错,因为协议不…

0评论

EasyNetQ异构异项目发布与订阅

最近因为业务架构需要,编写一个支付订单结果通知的服务,但发布方和订阅方不在同一个项目内,虽然两者的框架都是EasyNetQ,但版本差距很大,发布方是3.x,接受方是6.x,在订阅消息时遇到了一些问题,这里记录下解决方案。 首先就是市面上的所有主流消息队列框架封装的都过于完善,在发布消息和订阅消息时,会对消息的Body以外的属性,比如Header做一些额外的操作,以帮助框架完成更高级的功能,但这带来…

0评论

Serilog使用多个Logger实现多文件日志

因为一个统计业务的需求,需要将业务数据和系统日志分为两个文件进行记录,记录之后由日志收集系统收集到不同的ES的索引内,这里记录一下多Logger的配置方式。 首先必不可少的是,先安装Serilog.Expressions这个nuget包,网上查了很多资料鲜有提到需要安装这个包,导致踩了一个很深的坑,原因是更多的程序员喜欢使用代码内配置Serilog,而不是使用appsettings.json进行配…

0评论

值类型和引用类型作为参数的4种传递方式

最近在学习golang,对指针方面的一些概念有些迷惑,下了些功夫把相关的知识学习了一下,这里做个总结。 主要还是关于值传递和引用传递方面的东西,基本可以分为4种,只论结果,其他的网上已经说烂了。 值类型值传递 无论是golang、java、c#,值类型在作为参数传递时,都是深拷贝直接传递值的,因为值类型的内存分配在栈中,内存地址直接保存了值类型的真实值,在作为参数传递的时候,直接拷贝其值,所以在方…

0评论

MySql多表动态行转列

最近写了个特别复杂的业务,涉及到一个比较难写的Sql语句,在行转列的基础上需要多表动态联查,也就是说,查询结果的列数是可变的,数量根据联查的表的行数来决定,先贴出语句: CREATE DEFINER=`root`@`%` PROCEDURE `sp_getpointlist`(projectType INT) BEGIN SET @ProjectType = projectType; SET @S…

0评论