简述
作为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压测命令:ab -n 100000 -c 1000 -p text.json http://127.0.0.1/msg/find?uid=01DQT4BVD1GTWF9T2JCP5VH698
这里给出依赖地址。可以直接引用到工程里面。只需要更换依赖并不需要修改代码。因为API都是一样的。
import (
"github.com/globalsign/mgo"
"github.com/globalsign/mgo/bson"
)
第三步:修改连接数
连接数从100到1000。
提升:7500TPS > 8200TPS
ab压测命令:
ab -n 300000 -c 1000 -p text.json http://127.0.0.1/msg/find?uid=01DQT4BVD1GTWF9T2JCP5VH698
有疑问加站长微信联系(非本文作者)