波斯马BOSSMA Information Technology

Go 下的日志

Go使用双检锁最佳实践

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

不安全的双检锁 从其他语言转入Go语言的同学经常会陷入一个思考:如何创建一个单例? 有些同学可能会把其它语言中的双检锁模式移植过来,双检锁模式也称为懒汉模式,首次用到的时候才创建实例。大部分人首次用Golang写出来的实例大概是这样的: type Conn struct { ...

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标准日志库的三个输出方法也够用了,理解起来也很容易...

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。 ...

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...

go-micro开发gRPC应用程序

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

go-micro是golang的一个微服务框架。 go-micro各个版本之间的兼容性问题一直被诟病,前几年go-micro更是分化出了两个分支: 一个延续了go-micro,只不过转到了其公司CEO的个人Github仓库中,访问地址: asim/go-micro: A Go microservices framework (github.com) ...