为什么要学习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
- golang如何有pom类似机制(依赖)
- gorm的id字段问题出在哪
- swagger是怎么集成进去
昨天给看的一个go语言开源项目做了贡献,发现了其一个bug,帮忙做了个补丁,已经被项目所有者接受了。这是第二次做开源贡献,之前改过个以太坊的一个轻微级别的issue