redigo库来实现redis的操作:https://github.com/gomodule/redigo

Redis常用操作

示例代码:

  1. package main
  2.  
  3. import (
  4. "github.com/gomodule/redigo/redis"
  5. "fmt"
  6. "time"
  7. )
  8.  
  9. func initRedis() (dial redis.Conn, err error) {
  10. dial, err = redis.Dial("tcp", "172.16.65.183:30001")
  11. if err != nil {
  12. panic(err)
  13. }
  14. return dial, nil
  15. }
  16.  
  17. func testSetGet(dial redis.Conn) {
  18. // 设置一个Key和value
  19. dial.Do("set", "abc", "this is a test")
  20.  
  21. // 设置过期时间
  22. dial.Do("expire", "abc", )
  23.  
  24. // 读取指定key的value
  25. reply, err := dial.Do("get", "abc")
  26. str, err := redis.String(reply, err)
  27. if err != nil {
  28. panic(err)
  29. }
  30. fmt.Println(str)
  31. }
  32.  
  33. func testHSetGet(dial redis.Conn) {
  34. key := "abc"
  35. value := "this is a book test"
  36.  
  37. // 设置一个hash表来存储
  38. reply, err := dial.Do("hset", "books", key, value)
  39. if err != nil {
  40. panic(err)
  41. }
  42. fmt.Println(reply)
  43. reply2, err := dial.Do("hget", "books", key)
  44. str, err := redis.String(reply2, err)
  45. if err != nil {
  46. panic(err)
  47. }
  48. fmt.Println(str)
  49. }
  50.  
  51. func testMSetGet(dial redis.Conn) {
  52. key := "abc"
  53. value := "this is a test book"
  54. key2 := "golang"
  55. value2 := "this is a golang book"
  56.  
  57. // 一次设置多个key
  58. dial.Do("mset", "books", key, value, key2, value2)
  59. str, err := redis.Strings(dial.Do("mget", "books",key, key2))
  60. if err != nil {
  61. panic(err)
  62. }
  63. fmt.Println(str)
  64. }
  65.  
  66. func main() {
  67. dial, _ := initRedis()
  68. testSetGet(dial)
  69. testHSetGet(dial)
  70. testMSetGet(dial)
  71.  
  72. time.Sleep( * time.Second)
  73. reply, err := dial.Do("get", "abc")
  74. str, err := redis.String(reply, err)
  75. if err != nil {
  76. panic(err)
  77. }
  78. fmt.Println("get abc", str)
  79.  
  80. defer dial.Close()
  81. }

Redis连接池

连接池使用场景

对于一些大对象,或者初始化过程较长的可复用的对象,我们如果每次都new对象出来,那么意味着会耗费大量的时间。

我们可以将这些对象缓存起来,当接口调用完毕后,不是销毁对象,当下次使用的时候,直接从对象池中拿出来即可。

示例代码:

  1. package main
  2.  
  3. import (
  4. "github.com/gomodule/redigo/redis"
  5. "time"
  6. "fmt"
  7. )
  8.  
  9. func initRedisPool(serverAddr string, passwd string) (pool *redis.Pool) {
  10. pool = &redis.Pool{
  11. MaxIdle: ,
  12. MaxActive: ,
  13. IdleTimeout: * time.Second,
  14. Dial: func() (redis.Conn, error) {
  15. conn, err := redis.Dial("tcp", serverAddr)
  16. if err != nil {
  17. return nil, err
  18. }
  19. if len(passwd) > {
  20. _, err := conn.Do("auth", passwd)
  21. if err != nil {
  22. return nil, err
  23. }
  24. }
  25. return conn, nil
  26. },
  27. TestOnBorrow: func(c redis.Conn, t time.Time) error {
  28. if time.Since(t) < time.Minute {
  29. return nil
  30. }
  31. _, err := c.Do("ping")
  32. return err
  33. },
  34. }
  35. return pool
  36. }
  37.  
  38. func testRedisPool() {
  39. redisPool := initRedisPool("172.16.65.181:30001", "")
  40. // 获取一个redis连接
  41. conn := redisPool.Get()
  42.  
  43. key := "name"
  44. value := "golang"
  45. conn.Do("hset", "books", key, value)
  46. val, err := redis.String(conn.Do("hget", "books", key))
  47. if err != nil {
  48. panic(err)
  49. }
  50. conn.Close()
  51. fmt.Println(val)
  52. }
  53.  
  54. func main() {
  55. testRedisPool()
  56. }

Go Redis 开发的更多相关文章

  1. ASP.NET Redis 开发

    文件并发(日志处理)--队列--Redis+Log4Net Redis简介 Redis是一个开源的,使用C语言编写,面向“键/值”对类型数据的分布式NoSQL数据库系统,特点是高性能,持久存储,适应高 ...

  2. ASP.NET c# Redis 开发

    Redis简介 Redis是一个开源的,使用C语言编写,面向“键/值”对类型数据的分布式NoSQL数据库系统,特点是高性能,持久存储,适应高并发的应用场景.Redis纯粹为应用而产生,它是一个高性能的 ...

  3. ASP.NET Redis 开发 入门

    ASP.NET Redis 开发   文件并发(日志处理)--队列--Redis+Log4Net Redis简介 Redis是一个开源的,使用C语言编写,面向“键/值”对类型数据的分布式NoSQL数据 ...

  4. Redis开发与运维:SDS

    STRING 我们会经常打交道的string类型,在redis中拥有广泛的使用.也是开启redis数据类型的基础. 在我最最开始接触的redis的时候,总是以为字符串类型就是值的类型是字符串. 比如: ...

  5. Redis开发与运维学习笔记

    <Redis开发与运维>读书笔记   一.初始Redis 1.Redis特性与优点 速度快.redis所有数据都存放于内存:是用C语言实现,更加贴近硬件:使用了单线程架构,避免了多线程竞争 ...

  6. 完整阿里云Redis开发规范

    完整阿里云Redis开发规范 原文地址 本文主要介绍在使用阿里云Redis的开发规范,从下面几个方面进行说明. 键值设计 命令使用 客户端使用 相关工具 删除bigkey 通过本文的介绍可以减少使用R ...

  7. redis开发使用规范

    redis开发使用规范 1.冷热数据分离,不要将所有数据全部都放在Redis中 根据业务只将高频热数据存储到Redis中[QPS大于5000],对于低频冷数据可以使用mysql等基于磁盘的存储方式. ...

  8. 在windows环境里,用Docker搭建Redis开发环境(新书第一个章节)

    大家都知道高并发分布式组件的重要性,而且如果要进大厂,这些技术不可或缺.但这些技术的学习难点在于,大多数项目里的分布式组件,都是搭建在Linux系统上,在自己的windows机器上很难搭建开发环境,如 ...

  9. 《Redis开发与运维》

    第1章 初识Redis 1. Redis介绍: Redis是一种基于键值对(key-value)的NoSQL数据库. 与很多键值对数据库不同的是,Redis中的值可以是由string(字符串).has ...

  10. 阿里云 Redis 开发规范

    阿里云Redis开发规范-阿里云开发者社区 https://developer.aliyun.com/article/531067 https://mp.weixin.qq.com/s/UWE1Kx6 ...

随机推荐

  1. Laragon集成开发环境+配置Xdebug+postman运行Xdebug

    [ Laravel 5.5 文档 ] 快速入门 —— 使用 Laragon 在 Windows 中搭建 Laravel 开发环境:http://laravelacademy.org/post/7754 ...

  2. LeetCode: Validate Binary Search Tree [098]

    [题目] Given a binary tree, determine if it is a valid binary search tree (BST). Assume a BST is defin ...

  3. Linux下用户管理、目录结构

    linux的文件系统是采用层级式的树状目录结构,在此结构中的最上层是根目录“/”,然后在此目录下再创建其他的目录. 目录介绍: / root,存放root用户的相关文件 home,存放普通用户的相关文 ...

  4. 利用Lucene将被索引文件目录中的所有文件建立索引

    1.新建两个文件夹htm和index,其中htm中存放被索引的文件,index文件中存放建立的索引文件. 2.新建解析目录中所有文件的类,用来解析指定目录下的所有文件. import java.io. ...

  5. ios如何在当前工程中添加编辑新建的FramesWork

    本文转载至 http://www.apkbus.com/android-131519-1-1.html,感谢原文作者的分享.     naniboy 该用户从未签到   可能很多大牛都见过FaceBo ...

  6. TP数据删除

    [数据删除及执行原生sql语句] delete()  返回受影响的记录条数 $goods -> delete(30);   删除主键值等于30的记录信息 $goods -> delete( ...

  7. LeetCode Problem 9:Palindrome Number回文数

    描述:Determine whether an integer is a palindrome. Do this without extra space. Some hints: Could nega ...

  8. 【BZOJ2730】[HNOI2012]矿场搭建 Tarjan

    [BZOJ2730][HNOI2012]矿场搭建 Description 煤矿工地可以看成是由隧道连接挖煤点组成的无向图.为安全起见,希望在工地发生事故时所有挖煤点的工人都能有一条出路逃到救援出口处. ...

  9. 导出excel页面假死

    如果是asp.net页面 public override void VerifyRenderingInServerForm(Control control)    {} 如果是Sharepoint w ...

  10. 项目中调用ExcelCom组件时的配置流程

    异常提示如下:         Microsoft Office Excel 不能访问文件“*.xls”. 可能的原因有:        1 文件名称或路径不存在.       2 文件正被其他程序使 ...