参考下面的连接:

https://mp.weixin.qq.com/s?__biz=MzU5MjAxMDc1Ng==&mid=2247483899&idx=1&sn=b103ca28fb0674ae87fa073981d6fd08&chksm=fe270a90c950838617959c341581438acbdfb993020d1fc1a0d6baaa1b019058e5c26e976473&mpshare=1&scene=23&srcid=&sharer_sharetime=1588766854496&sharer_shareid=f556102554c3e8d6752418dddc22f428#rd

main.go

package main

import (
"fmt"
"haimait/learn/base/redis_dome01/utils"
) func main(){
test1()
} func test1() {
utils.RedisSet("age",18,0)
get, err := utils.RedisGet("age2")
if err !=nil {
fmt.Println("err:",err)
return
}
fmt.Println(get)
}

redis_api.go

package utils

import (
"encoding/json"
"fmt"
"strings"
"time" "github.com/ansel1/merry"
"github.com/astaxie/beego/logs"
"github.com/go-redis/redis"
) var RedisClient *redis.Client func init() {
NewClient()
} func NewClient() *redis.Client {
if RedisClient != nil {
return RedisClient
} RedisClient = redis.NewClient(&redis.Options{
Addr: "182.92.234.23:6379",
Password: "123456", // no password set
DB: 0, // use default DB
}) _, err := RedisClient.Ping().Result()
if err != nil {
logs.Error("redis connection failed: ", err.Error())
} return RedisClient
} func RedisSet(key string, value interface{}, expire int) error {
if expire > 0 {
err := RedisClient.Do("SET", key, value, "PX", expire).Err()
if err != nil {
logs.Error("RedisSet Error! key:", key, "Details:", err.Error())
return err
}
} else {
err := RedisClient.Do("SET", key, value).Err()
if err != nil {
logs.Error("RedisSet Error! key:", key, "Details:", err.Error())
return err
}
} return nil
}
func RedisKeyExists(key string) (bool, error) {
ok, err := RedisClient.Do("EXISTS", key).Bool()
return ok, err
} func RedisGet(key string) (string, error) {
value, err := RedisClient.Do("GET", key).String()
if err != nil {
return "", nil
} return value, nil
} func RedisGetResult(key string) (interface{}, error) {
v, err := RedisClient.Do("GET", key).Result()
if err == redis.Nil {
return v, nil
}
return v, err
} func RedisGetInt(key string) (int, error) {
v, err := RedisClient.Do("GET", key).Int()
if err == redis.Nil {
return 0, nil
}
return v, err
} func RedisGetInt64(key string) (int64, error) {
v, err := RedisClient.Do("GET", key).Int64()
if err == redis.Nil {
return 0, nil
}
return v, err
} func RedisGetUint64(key string) (uint64, error) {
v, err := RedisClient.Do("GET", key).Uint64()
if err == redis.Nil {
return 0, nil
}
return v, err
} func RedisGetFloat64(key string) (float64, error) {
v, err := RedisClient.Do("GET", key).Float64()
if err == redis.Nil {
return 0.0, nil
}
return v, err
} func RedisExpire(key string, expire int) error {
err := RedisClient.Do("EXPIRE", key, expire).Err()
if err != nil {
logs.Error("RedisExpire Error!", key, "Details:", err.Error())
return err
} return nil
} func RedisPTTL(key string) (int, error) {
ttl, err := RedisClient.Do("PTTL", key).Int()
if err != nil {
return -1, err
} return ttl, nil
} func RedisTTL(key string) (int, error) {
ttl, err := RedisClient.Do("TTL", key).Int()
if err != nil {
return -1, err
} return ttl, nil
} func RedisSetJson(key string, value interface{}, expire int) error {
jsonData, _ := json.Marshal(value)
if expire > 0 {
err := RedisClient.Do("SET", key, jsonData, "PX", expire).Err()
if err != nil {
logs.Error("RedisSetJson Error! key:", key, "Details:", err.Error())
return err
}
} else {
err := RedisClient.Do("SET", key, jsonData).Err()
if err != nil {
logs.Error("RedisSetJson Error! key:", key, "Details:", err.Error())
return err
}
} return nil
} func RedisGetJson(key string) ([]byte, error) {
value, err := RedisClient.Do("GET", key).String()
if err != nil {
return nil, nil
} return []byte(value), nil
} func RedisDel(key string) error {
err := RedisClient.Do("DEL", key).Err()
if err != nil {
logs.Error("RedisDel Error! key:", key, "Details:", err.Error())
}
return err
} func RedisHGet(key, field string) (string, error) {
value, err := RedisClient.Do("HGET", key, field).String()
if err != nil {
return "", nil
} return value, nil
} func RedisHSet(key, field, value string) error {
err := RedisClient.Do("HSET", key, field, value).Err()
if err != nil {
logs.Error("RedisHSet Error!", key, "field:", field, "Details:", err.Error())
}
return err
} func RedisHDel(key, field string) error {
err := RedisClient.Do("HDEL", key, field).Err()
if err != nil {
logs.Error("RedisHDel Error!", key, "field:", field, "Details:", err.Error())
}
return err
} func RedisZAdd(key, member, score string) error {
err := RedisClient.Do("ZADD", key, score, member).Err()
if err != nil {
logs.Error("RedisZAdd Error!", key, "member:", member, "score:", score, "Details:", err.Error())
}
return err
} func RedisZRank(key, member string) (int, error) {
rank, err := RedisClient.Do("ZRANK", key, member).Int()
if err == redis.Nil {
return -1, nil
} if err != nil {
logs.Error("RedisZRank Error!", key, "member:", member, "Details:", err.Error())
return -1, nil
} return rank, err
} func RedisZRange(key string, start, stop int) (values []string, err error) {
values, err = RedisClient.ZRange(key, int64(start), int64(stop)).Result()
if err != nil {
logs.Error("RedisZRange Error!", key, "start:", start, "stop:", stop, "Details:", err.Error())
return
} return
} func RedisZRangeWithScores(key string, start, stop int) (values []redis.Z, err error) {
values, err = RedisClient.ZRangeWithScores(key, int64(start), int64(stop)).Result()
if err != nil {
logs.Error("RedisZRange Error!", key, "start:", start, "stop:", stop, "Details:", err.Error())
return
} return
} func RedisZRem(key, member string) error {
err := RedisClient.Do("ZREM", key, member).Err()
if err != nil {
logs.Error("RedisZRem Error!", key, "member:", member, "Details:", err.Error())
}
return err
} func RedisRPUSH(key string, member string) (err error) {
err = RedisClient.Do("RPUSH", key, member).Err()
if err != nil {
logs.Error("RedisRPUSH Error!", key, member, "Details:", err.Error())
return
} return
} func RedisBLPOP(timeout time.Duration, keys ...string) (value []string, err error) {
value, err = RedisClient.BLPop(timeout, keys...).Result()
if err == redis.Nil {
err = nil
return
} if err != nil {
logs.Error("BLPop Error!", keys, timeout, "Details:", err.Error())
return
}
return
} func RedisLLEN(key string) (value int64, err error) {
value, err = RedisClient.LLen(key).Result()
if err != nil {
logs.Error("RedisLLEN Error!", key, "Details:", err.Error())
return
} return
} func RedisLRange(key string, start, stop int) (values []string, err error) {
values, err = RedisClient.LRange(key, int64(start), int64(stop)).Result()
if err != nil {
logs.Error("RedisLRange Error!", key, "start:", start, "stop:", stop, "Details:", err.Error())
return
} return
} func RedisKeys(pattern string) (keys []string, err error) {
keys, err = RedisClient.Keys(pattern).Result()
if err != nil {
logs.Error("RedisKeys Error!", pattern, "Details:", err.Error())
return
} return
} // RedisListAllValuesWithPrefix will take in a key prefix and return the value of all the keys that contain that prefix
func RedisListAllValuesWithPrefix(prefix string) (map[string]string, error) {
// Grab all the keys with the prefix
keys, err := getKeys(fmt.Sprintf("%s*", prefix))
if err != nil {
return nil, err
} // We will now iterate through all of the values to
values, err := getKeyAndValuesMap(keys, prefix) return values, nil
} // getKeys will take a certain prefix that the keys share and return a list of all the keys
func getKeys(prefix string) ([]string, error) {
var allKeys []string
var cursor uint64
count := int64(10) // count specifies how many keys should be returned in every Scan call for {
var keys []string
var err error
keys, cursor, err = RedisClient.Scan(cursor, prefix, count).Result()
if err != nil {
return nil, merry.Appendf(err, "error retrieving '%s' keys", prefix)
} allKeys = append(allKeys, keys...) if cursor == 0 {
break
} } return allKeys, nil
} // getKeyAndValuesMap generates a [string]string map structure that will associate an ID with the token value stored in Redis
func getKeyAndValuesMap(keys []string, prefix string) (map[string]string, error) {
values := make(map[string]string)
for _, key := range keys {
value, err := RedisClient.Do("GET", key).String()
if err != nil {
return nil, merry.Appendf(err, "error retrieving value for key %s", key)
} // Strip off the prefix from the key so that we save the key to the user ID
strippedKey := strings.Split(key, prefix)
values[strippedKey[1]] = value
} return values, nil
} func RedisBatchDel(key ...string) error {
err := RedisClient.Del(key...).Err()
if err != nil {
logs.Error("RedisBatchDel Error! key:", key, "Details:", err.Error())
}
return err
} func RedisMset(pairs ...interface{}) error {
err := RedisClient.MSet(pairs...).Err()
if err != nil {
logs.Error("RedisMset Error! pairs:", pairs, "Details:", err.Error())
}
return err
}

Go语言连接Redis之go-redis使用指南的更多相关文章

  1. go语言之行--golang操作redis、mysql大全

    一.redis 简介 redis(REmote DIctionary Server)是一个由Salvatore Sanfilippo写key-value存储系统,它由C语言编写.遵守BSD协议.支持网 ...

  2. Go语言系列- Socket编程和Redis

    Socket编程 一.socket编程概述 什么是socket编程? socket编程是计算机PC机器上2个程序通过一个双向的通信连接实现数据的交互,这个连接的一端就是一个socket.socket的 ...

  3. 本地连接虚拟机上面的redis

    想做一个抓取系统,想到用redis存储临时数据可能会比较好些,就想着装个虚拟机,在虚拟机上面安装redis,通过本地来访问虚拟机上面的redis. 虚拟机和redis安装成功之后,发现本地怎么都连接不 ...

  4. Redis系列-远程连接redis并给redis加锁

    假设两台redis服务器,ip分别为:192.168.1.101和192.168.1.103,如何在101上通过redis-cli访问103上的redis呢?在远程连接103之前,先讲下redis-c ...

  5. Jmeter连接Redis,获取Redis数据集

    Redis(REmote DIctionary Server)是一个开源的内存数据结构存储,用作数据库,缓存和消息代理. 本博文是分享jmeter怎么连接使用Redis数据库. 安装Redis数据集J ...

  6. java连接CentOS7上的redis

    这篇博客写得挺全的: https://blog.csdn.net/achenyuan/article/details/78521831?locationNum=3&fps=1 我也是跟着这篇博 ...

  7. RedisDesktopManager远程连接Linux系统的Redis服务

    linux下安装redis :https://www.runoob.com/redis/redis-install.html 进入 src 运行redis   : ./redis-server 打开另 ...

  8. python通过连接池连接redis,操作redis队列

    在每次使用redis都进行连接的话会拉低redis的效率,都知道redis是基于内存的数据库,效率贼高,所以每次进行连接比真正使用消耗的资源和时间还多.所以为了节省资源,减少多次连接损耗,连接池的作用 ...

  9. 通过nginx转发,用外网连接阿里云的redis,报Unexpected end of stream的解决办法

    一.在与redis同一个内网的服务器上A的nginx做了下面的设置 stream { upstream redis { server  redis.rds.aliyuncs.com:6379 max_ ...

  10. RUST actix-web连接有密码的Redis数据库

    RUST actix-web连接有密码的Redis数据库 actix-web的example里面,使用了自己的actix-redis,但是我尝试了一下,并不好用 替换成另一连接池,deadpool-r ...

随机推荐

  1. 一个可以让你有更多时间摸鱼的WPF控件(二)

    前言 上文介绍了如何通过一个Form自定义控件来简化数据的录入,并自动实现数据校验,自动布局排列等功能.本文继续介绍如何优化表格控件的使用,缩减代码量,实现工作效率的提升. 一.功能实现 上文中分析了 ...

  2. 腾讯tvp之路

    王清培 腾讯tvp之路

  3. 安卓开发数据可视化---导入数据到excel表格

    现在是2021-03-12 00::39 刚刚完成了一个小软件部分功能,现在把出现的问题总结如下: 一.首先要下载jar包 网址:https://mvnrepository.com/artifact/ ...

  4. Node 项目通过 .npmrc 文件指定依赖安装源

    背景 npm 命令运行时,往往通过命令行指定相关配置,最常用的便是使用 --registry 来指定依赖的安装源. npm install --registry=https://registry.np ...

  5. OpenHarmony加速行业应用落地,多款软件发行版正通过兼容性测评

    4 月 25 日,OpenAtom OpenHarmony(以下简称"OpenHarmony")技术日在深圳举办,大会聚焦 OpenHarmony 3.1 Release 版本核心 ...

  6. 带你玩转OpenHarmony AI-基于海思NNIE的AI能力自定义

    简介 相信大家从玩转OpenAtom OpenHarmony(简称"OpenHarmony")AI系列专题的其他文章中,已经拓展了OpenHarmony AI在智慧出行.智慧办公等 ...

  7. 数仓调优实战:GUC参数调优

    本文分享自华为云社区<GaussDB(DWS)性能调优系列实战篇七:十八般武艺之GUC参数调优>,作者: 黎明的风. 1. 前言 适用版本:[8.1.1及以上] GaussDB(DWS)性 ...

  8. SQline安装

    SQLite 安装 SQLite 的一个重要的特性是零配置的,这意味着不需要复杂的安装或管理.本章将讲解 Windows.Linux 和 Mac OS X 上的安装设置. 在 Windows 上安装 ...

  9. mybatis复习(一)

    原始连接数据库步骤: 1.导入JDBC驱动包 Class.forName("com.mysql.jdbc.Driver"); 2.获取连接对象(连接目标数据库) Connectio ...

  10. iOS系统崩溃的捕获

    iOS系统崩溃的捕获 相信大家在开发iOS程序的时候肯定写过各种Bug,而其中最为严重的Bug就是会导致崩溃的Bug(一般来说妥妥的P1级).在应用软件大大小小的各种异常中,崩溃确实是最让人难以接受的 ...