广告
返回顶部
首页 > 资讯 > 后端开发 > GO >Go实现Redis连接池方法
  • 146
分享到

Go实现Redis连接池方法

2024-04-02 19:04:59 146人浏览 安东尼
摘要

目录一、什么是连接池,连接池有什么用 二、代码展示 一、什么是连接池,连接池有什么用 先看看别人是怎么介绍连接池的吧: 连接池基本的思想是在系统初始化的时候,将数据库连接作为对象存

一、什么是连接池,连接池有什么用

先看看别人是怎么介绍连接池的吧:

连接池基本的思想是在系统初始化的时候,将数据库连接作为对象存储在内存中,当用户需要访问数据库时,并非建立一个新的连接,而是从连接池中取出一个已建立的空闲连接对象。使用完毕后,用户也并非将连接关闭,而是将连接放回连接池中,以供下一个请求访问使用。而连接的建立、断开都由连接池自身来管理。同时,还可以通过设置连接池的参数来控制连接池中的初始连接数、连接的上下限数以及每个连接的最大使用次数、最大空闲时间等等。也可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。

下面我来简单解释一下,因为每次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;i<10;i++{
        go getConnFromPoolAndHappy(pool,i)
    }
    //保持主协程存活
    time.Sleep(3*time.Second)
​
}
​
func getConnFromPoolAndHappy(pool *redis.Pool, i int)  {
    //通过连接池获得连接
    conn := pool.Get()
    //延时关闭连接
    defer conn.Close()
    //使用连接操作数据
    reply, err := conn.Do("set", "conn"+strconv.Itoa(i), i)
    s, _ := redis.String(reply, err)
    fmt.Println(s)
}

MaxActive: 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连接池方法的文章就介绍到这了,更多相关Go Redis连接池内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: Go实现Redis连接池方法

本文链接: https://www.lsjlt.com/news/132410.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Go实现Redis连接池方法
    目录一、什么是连接池,连接池有什么用 二、代码展示 一、什么是连接池,连接池有什么用 先看看别人是怎么介绍连接池的吧: 连接池基本的思想是在系统初始化的时候,将数据库连接作为对象存...
    99+
    2022-11-12
  • Go连接池设计与实现的方法是什么
    这篇“Go连接池设计与实现的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Go连接池设计与实现的方法是什么”文章吧...
    99+
    2023-07-06
  • 怎么用Java实现redis连接池
    这篇文章主要介绍“怎么用Java实现redis连接池”,在日常操作中,相信很多人在怎么用Java实现redis连接池问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Jav...
    99+
    2022-10-18
  • node连接redis的方法实现
    本篇文章介绍nodejs连接redis,以及redis的基本使用。 安装redis。 cnpm i redis -S 封装redis配置信息。 config/db.js // re...
    99+
    2023-02-27
    node连接redis node redis连接
  • spring-data-redis连接操作redis的实现方法
    本篇内容介绍了“spring-data-redis连接操作redis的实现方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Java连接re...
    99+
    2023-06-20
  • Redis连接池配置及初始化实现
    加入db选择后的redis连接池配置代码 public class RedisPoolConfigure { //Redis服务器IP private String ADD...
    99+
    2022-11-12
  • 浅谈Go连接池的设计与实现
    目录为什么需要连接池连接池设计GetPut总结开源实现Get:Put:sql.DB为什么需要连接池 如果不用连接池,而是每次请求都创建一个连接是比较昂贵的,因此需要完成3次tcp握手...
    99+
    2023-05-15
    Go连接池
  • Go语言配置数据库连接池的实现
    目录配置连接池SetMaxOpenConns方法SetMaxIdleConns方法SetConnMaxLifetime方法SetConnMaxIdleTime方法实操一波配置连...
    99+
    2022-06-07
    数据库连接 GO 连接 数据 数据库连接池 连接池 go语言 数据库
  • 数据库连接池的原理?连接池使用什么数据结构实现?实现连接池?
    早期我们怎么进行数据库操作呢? 1、原理:一般来说,Java应用程序访问数据库的过程是: 加载数据库驱动程序; 通过jdbc建立数据库连接; 访问数据库,执行SQL语句; 断开数据库连接。 2、代码 1 //查询所有用户 ...
    99+
    2015-09-26
    数据库连接池的原理?连接池使用什么数据结构实现?实现连接池?
  • GO实现协程池管理的方法
    使用channel实现协程池 通过 Channel 实现 Goroutine Pool,缺点是会造成协程的频繁开辟和注销,但好在简单灵活通用。 package main imp...
    99+
    2022-11-12
  • php如何让Swoole/Pool进程池实现Redis持久连接
    本篇内容主要讲解“php如何让Swoole/Pool进程池实现Redis持久连接”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“php如何让Swoole/Pool进程池实现Redis持久连接”吧!...
    99+
    2023-07-05
  • php如何实现连接池
    本篇内容介绍了“php如何实现连接池”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是连接池在实际应用开...
    99+
    2022-10-19
  • springboot连接redis并动态切换database的实现方法
    众所周知,redis多有个db,在jedis中可以使用select方法去动态的选择redis的database,但在springboot提供的StringRedisTemplate中...
    99+
    2022-11-13
  • python自制简易mysql连接池的实现方法是什么
    这篇文章主要讲解了“python自制简易mysql连接池的实现方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python自制简易mysql连接池的实现方法是什么”吧!连接池是什么连...
    99+
    2023-06-25
  • springboot2.0配置连接池(hikari、druid)的方法
    *******************如果你看到这一行,说明爬虫在本人还没有发布完成的时候就抓走了我的文章,导致内容不完整,请查看原文**************** springb...
    99+
    2022-11-12
  • 聊聊php怎么让Swoole/Pool进程池实现Redis持久连接
    本篇文章给大家带来了关于php的相关知识,其中主要介绍了通过PHPphp让Swoole/Pool进程池实现Redis持久连接,感兴趣的朋友下面一起来看一下吧,希望对大家有帮助。php 让 Swoole | Pool进程池实现Redis持久连...
    99+
    2023-05-14
    php
  • spring-data-redis连接操作redis的实现
    Java连接redis的客户端有很多,其中比较常用的是Jedis. (参考:redis client) spring-data-redis则是对Jedis进行了高度封装,使用起来非常...
    99+
    2022-11-12
  • Python中怎么实现MySQL连接池
    本篇文章给大家分享的是有关Python中怎么实现MySQL连接池,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。python编程中可以使用MyS...
    99+
    2022-10-18
  • redis的性能测试和实现客户端连接的方法
    这篇文章将为大家详细讲解有关redis的性能测试和实现客户端连接的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Redis 性能测试 语法redis-ben...
    99+
    2022-10-18
  • go连接mysql的方法是什么
    今天小编给大家分享一下go连接mysql的方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、mysql建表创建us...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作