golang 从零开始实现一个redis客户端(二)构建连接池

本文档介绍了如何使用Golang从零开始构建一个Redis连接池,包括回顾了先前创建的简单同步执行客户端,详细阐述了最终的目录结构和期望实现的功能,并通过流程图解析了NewClient和SendCommand的执行过程,同时提供了相关代码实现。
摘要由CSDN通过智能技术生成

回顾

    上一篇博客我们构建了一个简单的同步执行的能发送命令到redis服务器的例子,这次我们尝试构建一个连接池,可以让GO并发执行redis命令

最终的目录结构

其中 redis.go是供外部调用的主文件,options.go是可配置的相关参数,internal/pool下是跟连接池相关的

最终想要实现成的结果

package main

import (
	"github.com/learn-go/redis"

)

func main() {
	
	client := redis.NewClient(&redis.Options{
		Addr:     "localhost:6379",
	})

	client.SendCommand("SET hello world")

}

实现流程图

1. NewClient过程

2.SendCommand过程

 

具体实现代码

redis.go

package redis

import(
	"github.com/learn-go/redis/internal/pool"
)

type Client struct {
	opt      *Options
	connPool pool.Pooler

}

//发送命令
func (c *Client) SendCommand(cmd string) error {
	cn, err := c.getConn()
	if err != nil {
		return err
	}

	cn.WithWrite(cmd)
	c.releaseConn(cn)

	return err

}
//释放连接
func (c *Client) releaseConn(cn *pool.Conn){
	c.connPool.Put(cn)
}
//获取一个可用连接
func (c *Client) getConn() (*pool.Conn, error) {
	cn, err := c.connPool.Get()
	if err != nil {
		return nil, err
	}
	return cn, nil
}

//生成一个redis客户端
func NewClient(opt *Options) *Client {
	opt.init()
	c := Client{
		opt:      opt,
		connPool: newConnPool(opt),
	}

	return &c   
}

options.go

package redis

import(
	"time"
	"runtime"
	"net"
	"github.com/learn-go/redis/internal/pool"
)

type Options struct {
	// The network type, either tcp or unix.
	// Default is tcp.

	//network类型,
	Network string
	// 服务器地址 格式是host:port  localhost:6379
	Addr string

	//连接函数
	Dialer func() (net.Conn, error)

	// Dial timeout for establishing new connections.
	// Default is 5 se
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值