作为4年JAVA工程师的我,业余时间使用Go语言来开发一个名为leavemsg项目,中文名是时光留言网。在一台4核8G内存的服务器上做压测的时候发现查询接口不到500TPS。因为项目架构是httpserver+mgo+mongodb4.0,不可能这么低。经过一晚上的排除和优化。最终达到8000TPS+。
第一步
- 修改连接数据库的IP地址为本地127.0.0.1。
使用了外网IP作为数据库连接的IP,错误。因为本项目的服务和 mongodb 是部署在一起的。因此修改为127.0.0.1,即本地访问。仅此一步:
提升:500TPS > 6000TPS
第二步
- 替换更好的mongodb驱动。
github.com/globalsign/mgo替换gopkg.in/mgo.v2。原因是globalsign/mgo驱动是在gopkg.in/mgo.v2的基础上进行优化和修复了一些bug的版本。其中bson性能得到优化。
提升:6000TPS>7500TPS ab压测命令, 10W请求,1000个客户端 : ab -n 100000 -c 1000 -p text.json
附上替换驱动的前后对比的代码调用图。
请注意替换驱动之前,bson 序列化 方法占了15.59%耗时。
从21.79%到15.59%,bson序列化大概减少了28%的耗时。
这里给出依赖地址。可以直接引用到工程里面。只需要更换依赖并不需要修改代码。因为API都是一样的。
import ( "github.com/globalsign/mgo" "github.com/globalsign/mgo/bson" )
第三步
修改连接数
连接数从100到1000。
提升:7500TPS > 8200TPS ab压测命令,30W请求,1000个客户端: ab -n 300000 -c 1000 -p text.json