• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

go系列(3)- go框架beego以及redis的使用

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

这篇讲讲如何在beego框架使用redis。

golang中比较好用的第三方开源redisclient有:

第一种的使用见该篇文档 https://www.jianshu.com/p/80f83e42ee11
本文主要讲述第二种的使用。
 
1.接上两篇文章,切换到工作目录
cd /data/work/go

2.下载redis

go get -u github.com/astaxie/beego/cache/redis

3.安装完上述步骤之后,会在$GOPATH/src/github.com/gomodule下边有个redigo,如图

4.在使用的时候引入

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

注意:

1.当使用beego不需要模版的时候,可以在配置文件中关闭,以避免不必要的报错,默认是加载模版的,vim app/config,加入如下行

autorender = false

2.当go get github.com/**比较慢的时候,可以查到该host对应的ip,然后配到/etc/hosts

先用ip查找工具查到github.com对应的ip

如图,然后在/etc/hosts加入如下代码

192.30.253.112 github.com

 

 

好了,那我们就写个程序来验证下beego和redis的使用吧。

package controllers

import (
    "github.com/astaxie/beego"
    "github.com/gomodule/redigo/redis"
    "fmt"
    "time"
)

const PASSWORD string = "******"
const OK string = "ok"
const NO string = "no"

type DictController struct {
    beego.Controller
}

func newPool(idc, prekey string) *redis.Pool {
    var redisConn map[string]string = map[string]string{
         "beijing":"127.0.0.1:6379",
         "tianjin":"10.10.10.10:6379"}

    return &redis.Pool {
        MaxIdle:3,
        IdleTimeout: 240 * time.Second,
        Dial: func () (redis.Conn, error) {
            c, err := redis.Dial("tcp", redisConn[idc])
            if err != nil {
                return nil, err
            }
            if _, err := c.Do("AUTH", PASSWORD); err != nil {
                c.Close()
                return nil, err
            }
            if _, err := c.Do("SELECT", 0); err != nil {
                c.Close()
                return nil, err
            }
            return c, nil
        },
    }
}

func (c *DictController) GetDictData() string {
    userid,err := c.GetInt("userid")
    idc :=c.GetString("idc")
    prekey :=c.GetString("prekey")
    if err != nil {
        fmt.Printf("用户id[%d]参数出错", userid)
        return NO
    }

    var pool *redis.Pool = newPool(idc, prekey)
    conn := pool.Get()
    value, err := conn.Do("lrange", prekey, 0, -1)
    if err != nil {
        fmt.Printf("用户id[%d]从redis读取数据出错", userid)
        return NO
    }
    type ids []int
    data,_ := redis.Ints(value, err)
    for _,v := range data {
        if v==userid {
            fmt.Printf("用户id[%d]在黑名单中", userid)
            return OK
        }
    }
    fmt.Printf("用户id[%d]不在黑名单中", userid)
    return NO
}

 

注意:

1.助手函数

data,_ := redis.Ints(value, err)这行很关键,当从redis读取的数据不能用单纯的go的类型转换去转换,一定要用redis自带的回复助手函数去转,否则转出来的是不正确的。

在开始的官方文档中有提到,叫reply helper

 

reply helper functions(回复助手函数)
Bool,Int,Bytes,map,String,Strings和Values函数将回复转换为特定类型的值。为了方便地包含对连接Do和Receive方法的调用,这些函数采用了类型为error的第二个参数。如果错误是非nil,则辅助函数返回错误。如果错误为nil,则该函数将回复转换为指定的类型

2.归还连接池

当使用完之后,一定要记得归还连接池,否则会一直占用端口,压测一直上不去,就是这个问题

defer conn.Close(),如下红色代码,添加一行归还的操作

func (c *DictController) GetDictData() string {
    userid,err := c.GetInt("userid")
    idc :=c.GetString("idc")
    prekey :=c.GetString("prekey")
    if err != nil {
        fmt.Printf("用户id[%d]参数出错", userid)
        return NO
    }

    var pool *redis.Pool = newPool(idc, prekey)
    conn := pool.Get()

    defer conn.Close()

    value, err := conn.Do("lrange", prekey, 0, -1)
    if err != nil {
        fmt.Printf("用户id[%d]从redis读取数据出错", userid)
        return NO
    }
    type ids []int
    data,_ := redis.Ints(value, err)
    for _,v := range data {
        if v==userid {
            fmt.Printf("用户id[%d]在黑名单中", userid)
            return OK
        }
    }
    fmt.Printf("用户id[%d]不在黑名单中", userid)
    return NO
}

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
go语言学习历程发布时间:2022-07-10
下一篇:
vscodego开发主要插件发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap