波斯马BOSSMA Information Technology

2022年 发布的所有日志

Golang:将日志以Json格式输出到Kafka

发布时间:2022年5月16日 / 分类:Go / 抢沙发

在上一篇文章中我实现了一个支持Debug、Info、Error等多个级别的日志库,并将日志写到了磁盘文件中,代码比较简单,适合练手。有兴趣的可以通过这个链接前往:https://github.com/bosima/ylog/releases/tag/v1.0.2 工程实践中,我们往往还需要对日志进行采集,将日志归集到...

Golang:手撸一个支持六个级别的日志库

发布时间:2022年5月15日 / 分类:Go / 抢沙发

Golang标准日志库提供的日志输出方法有Print、Fatal、Panic等,没有常见的Debug、Info、Error等日志级别,用起来不太顺手。这篇文章就来手撸一个自己的日志库,可以记录不同级别的日志。 其实对于追求简单来说,Golang标准日志库的三个输出方法也够用了,理解起来也很容易...

使用grpcurl测试gRPC服务

发布时间:2022年5月11日 / 分类:Tools / 抢沙发

grpcurl可以像curl访问http服务一样访问gRPC服务,所以可以用来测试gRPC服务是否正常。 假设有这样一个服务,proto定义为: syntax = "proto3"; option go_package="/proto"; package Business; service Hello { rpc Say (SayRequest) returns...

go-micro集成RabbitMQ实战和原理

发布时间:2022年5月7日 / 分类:Go / 抢沙发

在go-micro中异步消息的收发是通过Broker这个组件来完成的,底层实现有RabbitMQ、Kafka、Redis等等很多种方式,这篇文章主要介绍go-micro使用RabbitMQ收发数据的方法和原理。 Broker的核心功能 Broker的核心功能是Publish和Subscribe,也就是发布和订阅。它们的定义是:...

sqlx操作MySQL实战及其ORM原理 

发布时间:2022年5月6日 / 分类:Go / 抢沙发

sqlx是Golang中的一个知名三方库,其为Go标准库database/sql提供了一组扩展支持。使用它可以方便的在数据行与Golang的结构体、映射和切片之间进行转换,从这个角度可以说它是一个ORM框架;它还封装了一系列地常用SQL操作方法,让我们用起来更爽。 sqlx实战 这里以操作My...

go-micro集成链路跟踪的方法及其中间件原理

发布时间:2022年5月5日 / 分类:Go / 抢沙发

前几天有个同学想了解下如何在go-micro中做链路跟踪,这几天正好看到wrapper这块,wrapper这个东西在某些框架中也称为中间件,里边有个opentracing的插件,正好用来做链路追踪。opentracing是个规范,还需要搭配一个具体的实现,比如zipkin、jeager等,这里选择zipkin。 ...

RDManager新版本:使用PuTTY代替Poderosa

发布时间:2022年4月29日 / 分类:Tools / 抢沙发

RDManager是我编写的一个远程管理工具,特点是可以一起管理Windows和Linux服务器。最初的版本是2017年写的,最近几年也一直在用,有些小毛病一直不爽,今天改了一下。 原因 之前集成的Poderosa是一个比较早期的版本,使用SSH Shell的场景中,有时会出现不支持新协议,导...

go-micro使用Consul做服务发现的方法和原理

发布时间:2022年4月25日 / 分类:Go / 抢沙发

go-micro v4默认使用mdns做服务发现。不过也支持采用其它的服务发现中间件,因为多年来一直使用Consul做服务发现,为了方便和其它服务集成,所以还是选择了Consul。这篇文章将介绍go-micro使用Consul做服务发现的方法。关于Consul的使用方式请参考我的另一篇文章:使用Consul...

go-micro开发RPC服务及其运行原理

发布时间:2022年4月24日 / 分类:Go / 抢沙发

go-micro是一个知名的golang微服务框架,最新版本是v4,这篇文章将介绍go-micro v4开发RPC服务的方法及其运作原理。 基本概念 go-micro有几个重要的概念,后边开发RPC服务和介绍其运行原理的时候会用到,这里先熟悉下: Service:代表一个go-micro应用程序,Service...

解决go-micro与其它框架之间的gRPC通信问题

发布时间:2022年4月22日 / 分类:Go / 抢沙发

在之前的文章中分别介绍了使用gRPC官方插件和go-micro插件开发gRPC应用程序的方式,都能正常走通。不过当两者混合使用的时候,互相访问就成了问题。比如使用go-micro插件生成的gRPC客户端访问基于gRPC官方插件创建的服务端时就会出现如下错误: {"id":"go.m...