go使用redis连接池技术操作redis数据库实例

我们都知道,在程序开发中,网络链接的开销是比较大的, 当我们在链接redis 时,如果是操作一次就执行一次DIal拨号,那性能是很低的,redis的效率瞬间就被你降低了50%, 提速redis使用性能的第一步就是使用连接池技术,废话不多说,直接上代码:

Go 复制代码
package main

import (
	"fmt"

	"github.com/gomodule/redigo/redis"
)

// 定义全局变量
var pool *redis.Pool

// 当程序启动时就初始化这个函数,在main之前执行
func init() {
	pool = &redis.Pool{
		MaxIdle:     8,   //最大空闲链接数
		MaxActive:   0,   // 表示和数据库的最大链接数,0表示没有限制
		IdleTimeout: 100, //最大空闲时间
		Dial: func() (redis.Conn, error) { //从连接池中取出一个链接
			return redis.Dial("tcp", "localhost:6378")
		},
	}
}

func RedisDo(commandName string, args ...interface{}) (reply interface{}, err error) {
	// 普通方式链接redis,这个效率太低,因为每次都要取拨号链接 网络开销太大
	// conn, err := redis.Dial("tcp", "localhost:6378")
	// if err != nil {
	// 	fmt.Printf("Redis Connect Error: %v", err)
	// }

	conn := pool.Get() // 从连接池中获取一个redis链接

	defer conn.Close() // 用完关闭,
	// 这里的参数可变参数 args 在再次调用的时候需要使用...进行解构,否则这个参数的类型就改变了
	reply, err = conn.Do(commandName, args...)
	if err != nil {
		fmt.Printf("Redis命令 set失败: %v", err)
	}
	return
}
func main() {
	RedisDo("set", "name2", "Tekin from golang")
	if rep, err := RedisDo("get", "name2"); err == nil {
		str, _ := redis.String(rep, err)
		fmt.Printf("str=%v", str)
	} else {
		fmt.Println(err)
	}
}
相关推荐
elastic_solr16 分钟前
医药采购系统平台第10天02:按药品分类的统计&按供货商统计&按医院统计&统计数据的导出&DWR的配置和应用
大数据·数据库
聪明的墨菲特i1 小时前
SQL进阶知识:三、事务控制
数据库·sql·mysql·数据库开发·事务控制
·薯条大王1 小时前
Node.js 开发用户登录功能(使用mysql实现)
数据库·mysql·node.js
朴拙数科2 小时前
基于Python将MongoDB文本数据通过text2vec-large-chinese模型向量化并存储到Milvus数据库的完整实现方案
数据库·python·mongodb
咸鱼睡不醒_2 小时前
CentOS7安装MySQL教程
数据库·mysql
E___V___E2 小时前
黑马点评redis改 part 5
数据库·redis·缓存
洛神灬殇3 小时前
【Redis技术进阶之路】「系统架构系列中篇」高可用之Master-Slave主从架构的复制问题(分析旧版点制功能)
redis·后端·架构
打码人的日常分享3 小时前
网络安全风险评估报告书模版(Word)
运维·数据库·微服务·制造·需求分析
闪电麦坤953 小时前
计算机组成与体系结构:缓存(Cache)
缓存·计算机组成与体系结构
mc.byte3 小时前
移动端使用keep-alive将页面缓存和滚动缓存具体实现方法 - 详解
前端·javascript·缓存