package main

import (
"fmt"
"github.com/gomodule/redigo/redis"
) func main() {
// 官方地址:https://godoc.org/github.com/gomodule/redigo/redis#pkg-examples
/***************************** redis连接 *********************************/
// option := redis.DialPassword("123456") 如果redis有密码,放在第三个选项
c, err := redis.Dial("tcp", "127.0.0.1:6379")
if err != nil {
fmt.Println(err)
return
}
defer c.Close() /***************************** Do方法 *************************************/
// 执行redis语句的通用方法
// 可执行的命令参考 :https://redis.io/commands // set name card 成功返回ok
res,err := c.Do("SET", "NAME", "card")
if err != nil {
fmt.Println(err)
}
fmt.Println(res) // get name 成功返回interface{}
res, err = c.Do("GET", "NAME")
if err != nil {
fmt.Println(err)
}
// 进行类型断言
switch t := res.(type) {
case []byte:
fmt.Println(string(t))
} /***************************** 管道 *************************************/
// redigo支持管道操作Send(),Flush(),Receive() // Send() 发送命令到输出缓冲区。
// Send(commandName string, args ...interface{}) error // Flush() 写入命令并刷新输出缓冲区。
// Flush() error // Receive()接收服务器的返回值
// Receive() (reply interface{}, err error) c.Send("SET", "foo", "bar") // 设置语句到缓冲区
c.Send("GET", "foo") // 设置语句到缓冲区
c.Flush() // 发送语句
res,_ =c.Receive() // 接收第一个Send()的返回值
fmt.Println(res)
res,_ = c.Receive() // 接收第二个Send()的返回值
fmt.Println(res) // Do方法结合了Send,Flush和Receive方法的功能。
// Do方法首先写入命令并刷新输出缓冲区。
// 接下来,Do方法接收所有待处理的回复,包括Do执行的命令的回复。
// 如果收到的任何回复都是错误,则Do返回错误。 如果没有错误,则Do返回最后一个返回值。
// 如果Do方法的命令参数是“”,则Do方法将刷新输出缓冲区并接收挂起的回复而不发送命令。 // MULTI类似于事务的begin commit事务处理
c.Send("MULTI")
c.Send("INCR", "money")
c.Send("INCR", "count")
r, err := c.Do("EXEC")
fmt.Println(r) // [1,1] /***************************** 并发 *************************************/
// redigo支持一个并发调用Receive()方法和一个并发调用Send()和Flush()方法
// 不支持其他并发,包括对Do方法的并发调用
// 如果需要完全并发访问redis,需要使用线程安全池goroutine中获取,使用和释放连接。
// 从线程中返回具有前一段时间描述的并发限制
// 关于redis连接池会单独写一个 /***************************** 发布和订阅 *******************************/
// 扩展:SUBSCRIBE、UNSUBSCRIBE和PUBLISH 三个命令实现了发布与订阅信息泛型.
// 在这个实现中, 发送者(发送信息的客户端)不是将信息直接发送给特定的接收者(接收信息的客户端),
// 而是将信息发送给频道(channel), 然后由频道将信息转发给所有对这个频道感兴趣的订阅者。 
// 也就是说发送者无须知道任何关于订阅者的信息, 而订阅者也无须知道是那个客户端给它发送信息,
// 它只要关注自己感兴趣的频道即可
// 对发布者和订阅者进行解构(decoupling),可以极大地提高系统的扩展性(scalability),
// 并得到一个更动态的网络拓扑(network topology)。
// redis可以订阅任意数量的频道。 // 通过使用Send(),Flush(),和Receive()方法实现 Pub / Sub订阅者。 // 订阅者
// c.Send("SUBSCRIBE", "example")
// c.Flush()
// for {
// reply, err := c.Receive()
// if err != nil{
// fmt.Println(err)
// }
// // 处理接收到的信息
// fmt.Println(reply)
// } // PubSubConn类型使用便捷方法包装Conn以实现订阅者。
// Subscribe,PSubscribe,Unsubscribe和PUnsubscribe方法发送和刷新订阅管理命令。
// receive方法将推送的消息转换为方便的类型,以便在switch中使用。
// psc := redis.PubSubConn{Conn:c}
// psc.Subscribe("example")
// for {
// switch v := psc.Receive().(type) {
// case redis.Message:
// fmt.Printf("%s: message: %s \n", v.Channel, v.Data)
// case redis.Subscription:
// fmt.Printf("%s: %s %d\n", v.Channel, v.Kind, v.Count)
// case error:
// fmt.Println(v)
// }
// } /***************************** 返回值助手函数 *******************************/
// Bool,Int,Bytes,String,Strings和Values函数将返回值转换为特定类型的值。
// 为了方便地包含对连接Do和Receive方法的调用,这些函数采用了类型error的第二个参数。
// 如果错误是非nil,则辅助函数返回错误。 如果错误为nil,则该函数将回复转换为指定的类型
exists, err := redis.Bool(c.Do("EXISTS", "foo"))
if err != nil {
// handle error return from c.Do or type conversion error.
}
fmt.Println(exists)
}

redigo简单理解的更多相关文章

  1. git的简单理解及基础操作命令

    前端小白一枚,最近开始使用git,于是花了2天看了廖雪峰的git教程(偏实践,对于学习git的基础操作很有帮助哦),也在看<git版本控制管理>这本书(偏理论,内容完善,很不错),针对所学 ...

  2. 简单理解Struts2中拦截器与过滤器的区别及执行顺序

    简单理解Struts2中拦截器与过滤器的区别及执行顺序 当接收到一个httprequest , a) 当外部的httpservletrequest到来时 b) 初始到了servlet容器 传递给一个标 ...

  3. [转]简单理解Socket

    简单理解Socket 转自 http://www.cnblogs.com/dolphinX/p/3460545.html  题外话 前几天和朋友聊天,朋友问我怎么最近不写博客了,一个是因为最近在忙着公 ...

  4. Js 职责链模式 简单理解

    js 职责链模式 的简单理解.大叔的代码太高深了,不好理解. function Handler(s) { this.successor = s || null; this.handle = funct ...

  5. Deep learning:四十六(DropConnect简单理解)

    和maxout(maxout简单理解)一样,DropConnect也是在ICML2013上发表的,同样也是为了提高Deep Network的泛化能力的,两者都号称是对Dropout(Dropout简单 ...

  6. Deep learning:四十二(Denoise Autoencoder简单理解)

    前言: 当采用无监督的方法分层预训练深度网络的权值时,为了学习到较鲁棒的特征,可以在网络的可视层(即数据的输入层)引入随机噪声,这种方法称为Denoise Autoencoder(简称dAE),由Be ...

  7. 简单理解dropout

    dropout是CNN(卷积神经网络)中的一个trick,能防止过拟合. 关于dropout的详细内容,还是看论文原文好了: Hinton, G. E., et al. (2012). "I ...

  8. 我们为之奋斗过的C#-----C#的一个简单理解

    我们首先来简单叙述一下什么是.NET,以及C#的一个简单理解和他们俩的一个区别. 1 .NET概述 .NET是Microsoft.NET的简称,是基于Windows平台的一种技术.它包含了能在.NET ...

  9. 简单理解ECMAScript2015中的箭头函数新特性

    箭头函数(Arrow functions),是ECMAScript2015中新加的特性,它的产生,主要有以下两个原因:一是使得函数表达式(匿名函数)有更简洁的语法,二是它拥有词法作用域的this值,也 ...

随机推荐

  1. 4.Python3标准库--算法

    (一)functools:管理函数的工具 import functools ''' functools模块提供了一些工具来管理或扩展和其他callable对象,从而不必完全重写 ''' 1.修饰符 f ...

  2. git学习笔记三

    1.每个分支的历史版本维护信息位置是.git/logs/refs/heads/master,这个位置的信息是文本文件,不是引用. harvey@harvey-Virtual-Machine:~/dem ...

  3. P4819 [中山市选]杀人游戏

    题目描述 一位冷血的杀手潜入Na-wiat,并假装成平民.警察希望能在NN个人里面,查出谁是杀手.警察能够对每一个人进行查证,假如查证的对象是平民,他会告诉警察,他认识的人,谁是杀手,谁是平民.假如查 ...

  4. LeetCode解题报告—— Sum Root to Leaf Numbers & Surrounded Regions & Single Number II

    1. Sum Root to Leaf Numbers Given a binary tree containing digits from 0-9 only, each root-to-leaf p ...

  5. Maximum Gap——桶排序

    Given an unsorted array, find the maximum difference between the successive elements in its sorted f ...

  6. Centos查找大文件的办法

    find / -size +100M -exec ls -lh {} \; # 查看整体磁盘占用df -h #切换到这块磁盘检查一下这块磁盘的哪个文件夹占用高,再逐层去查找 du -h --max-d ...

  7. 确实,k8s的时代,ingress负载用traefik比nginx方便啊

    参考文档: https://mritd.me/2016/12/06/try-traefik-on-kubernetes/#13ingress 由于微服务架构以及 Docker 技术和 kubernet ...

  8. Linux和Windows双系统安装要点

    这里主要说下CentOS和Windows7的双系统安装遇到的一些问题 一.磁盘分区 这个不得不说下在Windows下坑爹的设定了,如果是用默认的磁盘划分,系统会自己先划出一个100M左右的区,关键还是 ...

  9. SPOJ - PHRASES K - Relevant Phrases of Annihilation

    K - Relevant Phrases of Annihilation 题目大意:给你 n 个串,问你最长的在每个字符串中出现两次且不重叠的子串的长度. 思路:二分长度,然后将height分块,看是 ...

  10. Openstack 清除openstack网络与路由 (十七)

    一)清除openstack网络与路由 “清除openstack网络与路由”和”添加openstack网络与路由”的操作步骤相反. 添加网络或路由时是先建 搭建网络>搭建子网>建立端口, 而 ...