为什么要学习golang

最早接触golang是因为对区块链感兴趣,因为golang的并发和内置的网络库还有大公司的支持,先天比较适合区块链,很多著名的框架都是golang写,比如geth

再后来,到新加坡Shopee工作,技术栈从Java切换成了golang,更要好好学习golang的语言特性了

如下是之前列的一个学习路线图

1.数据类型(含struct)

  • 每个类型占用多少字节

  • 最大值 最小值,有无封装;溢出怎么处理

  • 内置的map和slice两个特色的数据类型

  • struct结构如何在区块或者头部定义中使用

2.关键字及流程语法(浅尝,主要还是在项目中完善)

  • chan是重点(这个大大简化了java中池的实现,和goroutine一起实现了类似Netty的功能,所以geth实现其实比Ethereumj要简单)

3.包管理

熟练使用gx和github

4.标准库和著名第三方库(大头)

fmt

strings

os

math(safemath自己实现一个)

CLI 和 config(或者说是flag类,当然fabric用cobra; config的viper库)

net

重点是密码学的包,有没有和spongycastle一样的包

5.序列化和反序列化 protobuf

6.go有netty这层吗?看看其如何net nio裸编码

7.goroutine并发

8.高级并发性能,对比geth和quorum

9.性能测试 caliper工具,热点分析 metrics+influxdb+grafana


市面上的golang框架比较多,这个是国人开发的,比较容易上手,所以起步者可以take a look这个框架
https://github.com/PinkHello/go-starter

build

  • local
> cd .
> docker build . --file deploy/Dockerfile --tag {ImageTag}
  • github action
> { secrets.ACCESS_USERNAME }: `your docker hub username`

be deploy

docker networkgo_starter_network
> docker network create go_starter_network
mysqlnsq
# MYSQL start
> cd deploy/mysql
> docker-compose up -d
# NSQ start
> cd deploy/nsq
> docker-compose up -d
be server
# go-starter start
> cd deploy
> docker-compose up -d

  1. golang如何有pom类似机制(依赖)
  2. gorm的id字段问题出在哪
  3. swagger是怎么集成进去

昨天给看的一个go语言开源项目做了贡献,发现了其一个bug,帮忙做了个补丁,已经被项目所有者接受了。这是第二次做开源贡献,之前改过个以太坊的一个轻微级别的issue