go语言与MySQL数据库(连接池)

 

导入包:

import "database/sql"
import _ "github.com/go-sql-driver/mysql"

使用sql.Open函数创建一个连接池对象,不是单个连接。在open的时候并没有去连接数据库,只有在执行query、exce方法的时候才会去实际连接数据库。在一个应用中同样的库连接只需要保存一个sql.Open之后的db对象就可以了,不需要多次open。代码入:

 

var db *sql.DB

 

func init() {

    db, _ = sql.Open("mysql""root:@tcp(127.0.0.1:3306)/test?charset=utf8")

    db.SetMaxOpenConns(2000)

    db.SetMaxIdleConns(1000)

    db.Ping()

}

连接池的实现关键在于SetMaxOpenConns和SetMaxIdleConns,其中:

 

SetMaxOpenConns用于设置最大打开的连接数,默认值为0表示不限制。
SetMaxIdleConns用于设置闲置的连接数。设置最大的连接数,可以避免并发太高导致连接mysql出现too many connections的错误。设置闲置的连接数则当开启的一个连接使用完成后可以放在池里等候下一次使用。

在使用query和exce操作数据库时,query需要管理连接,也就是把连接释放,归还连接池,通常采用defer db.Close();而exce在执行完对数据库的操作后会自动释放。比如:

rows, err := db.MysqlDB.Query(querystring)
defer rows.Close()

有些地方说rows在遍历完之后会释放连接,但我自己写的有些地方并没有释放掉,比如在实现用户登录的时候,我没有使用defer rows.Close(),结果在做压力测试的时候,数据库一下子就报“Too many connections”,单次登录不断刷新登录页面登录,使用show  processlist;命令查询数据库的进程,发现是不断增大的,说明登录的时候使用的连接没有被释放,加了defer rows.Close()才得以解决问题。

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Golang中,数据库连接是通过内部实现的连接来实现的。连接的建立是惰性的,当你需要连接的时候,连接会自动帮你创建。你不需要手动操作连接,一切都由Golang来完成。 在Golang的标准库database/sql/sql.go中实现了数据库连接。当我们使用sql.Open函数来创建连接时,实际上就是在使用连接。例如,使用以下代码创建一个MySQL连接: db, err := sql.Open("mysql", "xxxx") 此外,我们还可以参考已经成熟并广泛使用的MySQL连接库和Redis连接库来了解连接的实现方式。这些库通过实现连接来提供更高效的数据库连接管理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [使用mysql数据库与go进行交互](https://blog.csdn.net/tianlongtc/article/details/80115240)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Golang连接的几种实现案例](https://blog.csdn.net/asd1126163471/article/details/127020095)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值