Go实现Redis连接池方法
来源:脚本之家
时间:2022-12-28 07:55:34 421浏览 收藏
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《Go实现Redis连接池方法》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
一、什么是连接池,连接池有什么用
先看看别人是怎么介绍连接池的吧:
连接池基本的思想是在系统初始化的时候,将数据库连接作为对象存储在内存中,当用户需要访问数据库时,并非建立一个新的连接,而是从连接池中取出一个已建立的空闲连接对象。使用完毕后,用户也并非将连接关闭,而是将连接放回连接池中,以供下一个请求访问使用。而连接的建立、断开都由连接池自身来管理。同时,还可以通过设置连接池的参数来控制连接池中的初始连接数、连接的上下限数以及每个连接的最大使用次数、最大空闲时间等等。也可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。
下面我来简单解释一下,因为每次Redis客户端连接Redis服务端都需要一段时间,而处理各种操作的时间很多时候都很短,如果每次进行各种操作时都需要重新连接Redis,那么就会浪费大量时间。因此Redis引入连接池,连接池可以实现建立多个客户端连接而不释放,避免浪费IO资源,不使用的时候就放在连接池,这样就减少了连接数据库所需要的时间,提高效率。
连接池就是建一个池子和一定量的管道。每次当管道被取尽时,就不能继续消耗IO资源了,这样就保证了IO资源不会耗尽。
二、代码展示
package main import ( "fmt" "github.com/garyburd/redigo/redis" "strconv" "time" ) func main() { pool := &redis.Pool{ // Maximum number of connections allocated by the pool at a given time. // When zero, there is no limit on the number of connections in the pool. //最大活跃连接数,0代表无限 MaxActive: 888, //最大闲置连接数 // Maximum number of idle connections in the pool. MaxIdle: 20, //闲置连接的超时时间 // Close connections after remaining idle for this duration. If the value // is zero, then idle connections are not closed. Applications should set // the timeout to a value less than the server's timeout. IdleTimeout: time.Second * 100, //定义拨号获得连接的函数 // Dial is an application supplied function for creating and configuring a // connection. // // The connection returned from Dial must not be in a special state // (subscribed to pubsub channel, transaction started, ...). Dial: func() (redis.Conn, error) { return redis.Dial("tcp","127.0.0.1:6379"), } } //延迟关闭连接池 defer pool.Close() //IO并发连接 for i:=0;iMaxActive: 888
上面的代码表示在给定的时间内被连接池分配的最大连接数,当该值为0时,表示连接池的连接数是无上限的。
MaxIdle: 20
表示连接池闲置连接数的上限。
IdleTimeout: time.Second * 100
该值表示如果连接池的的连接闲置超过该值就会关闭连接。如果该值为零,连接池中闲置的连接就不会关闭。应用程序应该设置这个限制超时时间不超过服务端的限制超时时间。
Dial: func() (redis.Conn, error) { return redis.Dial("tcp", "127.0.0.1:6379") }该值为一个函数,该函数应该用于创造和配置连接。从Dial返回的连接不能处于特殊状态。
开辟一条并发协程执行该函数,因为for循环的范围是0-9,所以并发数为10,表示同时有10个人去连接池取管道。go getConnFromPoolAndHappy(pool,i)下列代码是用来保持主协程存活的。
time.Sleep(3*time.Second)下面表示通过连接池获得连接。也就是从池子拿一根管道。
conn := pool.Get()然后下面的代码是使用管道。
reply, err := conn.Do("set", "conn"+strconv.Itoa(i), i) s, _ := redis.String(reply, err) fmt.Println(s)如果一个人占着管道不用,就会被闲置。如果在闲置处太久不动,达到闲置连接的超时时间,就会被请走。
因为池子使用的都是同一个,所以需要使用池子的指针。pool := &redis.Pool到这里,我们也就讲完了《Go实现Redis连接池方法》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于golang的知识点!
-
286 收藏
-
117 收藏
-
185 收藏
-
426 收藏
-
134 收藏
-
317 收藏
-
430 收藏
-
451 收藏
-
311 收藏
-
408 收藏
-
317 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 安详的西牛
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢作者大大分享文章!
- 2023-02-07 08:06:21
-
- 迷人的金针菇
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者分享技术贴!
- 2023-01-13 07:18:50
-
- 明理的犀牛
- 细节满满,码起来,感谢老哥的这篇技术贴,我会继续支持!
- 2023-01-12 15:41:18
-
- 忧虑的大象
- 这篇博文出现的刚刚好,很详细,真优秀,已收藏,关注作者了!希望作者能多写Golang相关的文章。
- 2023-01-05 19:08:20
-
- 内向的铃铛
- 这篇技术文章太及时了,很详细,受益颇多,mark,关注博主了!希望博主能多写Golang相关的文章。
- 2022-12-29 03:56:36