Skip to content

plm-lee/gotools

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gotools

mq连接池

1、导入package:

go get github.com/plm-lee/gotools/mq

2、使用连接池:

在mq中声明了一个全局的mq连接池,[var ConnPool *Pool], 因此在使用mq包时不需要调用者自己声明,mq包内部会自动从mq池中取空闲的连接

package main

import (
 "github.com/plm-lee/gotools/mq"
 "log"
)

//InitConnPool() 可以传入三个mq连接地址,默认第一个连接失败会切换到其他地址
func Init(){
    mq.InitConnPool(Addr,Addr1, Addr2, MaxIdle)
}

func main()  {
	Init() //初始化
	
	//mq 推送消息为json字符串
	strtmp := `{name:"test"}`
	
    mq.Publish("3rd.in.exchange", "direct", "sms.key", strtmp, true) //publish
    
    worker := CommonConsumer(RouterMqExchange, RouterMqQueue, RouterMqKey, RouterMqTag)
    
    //启动消费者
    go worker.StartUp()
    
    select{}
}

//创建消费者
func CommonConsumer(exchange, queue, key, ctag string) *mq.Consumer {
	consumer, err := mq.NewConsumer(
		exchange,
		"direct",
		queue,
		key,
		ctag,    //simple-consumer
		handler) // call back Fun
	log.Fatal(err, "[ERROR] Consumer 启动失败")
	return consumer
}

//消费者业务逻辑
func handler(in string) (out string, err error) {

	log.Println("[mq json] json:", in)
	
	//TODO...
	return "", nil
}

redis

1、导入package

go get github.com/plm-lee/gotools/redispool

2、使用redis连接池

var ConnPool *redis.Pool
var ConnPoolLocalNet *redis.Pool

redis内部声明了两个连接池,(本地redis连接池及远程连接池,本质上都是一样)

package main

import "github.com/plm-lee/gotools/redispool"

func main()  {
	//初始化
    redispool.InitConnPool(Addr, Password, Db, MaxIdle)
    redispool.InitConnPoolLocal(Addr, Password, Db, MaxIdle)
    
    //获取连接
    rc := redispool.ConnPool.Get()
    defer rc.Close() //使用完记得close
    
    //或者
    rc := redispool.ConnPoolLocalNet.Get()
    defer rc.Close() //使用完记得close
    
    //使用Do()方法
    rc.Do("RPOP", "key-test")   
}

About

golang工具库

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages