关于go run 运行,ctrl + c 关闭执行,mysql连接没有关闭的问题

fancyecommerce · · 1013 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

开发的时候,会用 `go run xxx.go`来运行golang,因为是web类的应用,因此会一直运行, 然后,我使用ctrl + c 来停掉,我发现,通过 ctrl + c 停掉的次数过多后,后面再通过 `go run xxx.go` 会报错无法连接mysql,重启机器后恢复正常 是不是 ctrl + c 停掉golang程序后,mysql的连接数还是占用着?导致超过mysql的最大连接数 也就是说ctrl + c停掉运行的golang,并没有全部释放占用的资源? 下面是我的使用方式: ``` package mysqldb import( _ "github.com/go-sql-driver/mysql" "github.com/go-xorm/xorm" "github.com/fecshopsoft/fec-go/config" "sync" "reflect" "strconv" ) var once sync.Once var engine *(xorm.Engine) func GetEngine() *(xorm.Engine){ once.Do(func() { // 用于设置最大打开的连接数 maxOpenConns := config.Get("maxOpenConns") // 用于设置闲置的连接数 maxIdleConns := config.Get("maxIdleConns") mysql_user := config.Get("mysql_user") mysql_password := config.Get("mysql_password") mysql_host := config.Get("mysql_host") mysql_port := config.Get("mysql_port") mysql_db := config.Get("mysql_db") charset := config.Get("charset") autocommit := config.Get("autocommit") // engine, err := xorm.NewEngine("mysql", "root:Zhaoy34ggsd@tcp(127.0.0.1:3306)/fec-go?charset=utf8&autocommit=true") mysql_str := mysql_user + ":" + mysql_password + "@tcp(" + mysql_host + ":" + mysql_port + ")/" + mysql_db + "?charset=" + charset + "&autocommit=" + autocommit //if mysql_str != "" {} var err error engine, err = xorm.NewEngine("mysql", mysql_str) if err != nil { panic(err.Error()) } moc, _ := strconv.Atoi(maxOpenConns) mic, _ := strconv.Atoi(maxIdleConns) engine.SetMaxOpenConns(int(moc)) engine.SetMaxIdleConns(int(mic)) }) return engine; } ``` 也就是长连接这种,使用的时候通过这个函数获取mysql engine

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1013 次点击  
加入收藏 微博
5 回复  |  直到 2018-05-17 14:32:26
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传