golang操作reids
时间: 2023-12-09 17:05:14 浏览: 109
golang可以通过redis包来操作redis数据库。可以使用Dial函数来连接redis数据库,使用Do函数来执行redis命令。以下是golang操作redis的一些常见命令:
1. Set/Get 接口:使用Do函数执行Set和Get命令来设置和获取键值对。
2. 操作Hash:使用Do函数执行HSet和HGet命令来设置和获取hash类型的键值对。
3. 给数据设置有效时间:使用Do函数执行Expire命令来设置键的过期时间。
4. 操作List:使用Do函数执行LPush和RPop命令来操作list类型的数据。
5. Redis 链接池:可以使用redis包中的Pool函数来创建redis连接池,以提高连接效率。
相关问题
golang 调用redis集群
在 Golang 中使用 Redis 集群,可以使用官方提供的 Redis 客户端库 Redigo。Redigo 提供了连接池、管道、事务等功能,非常适合高并发场景下的 Redis 操作。
以下是一个使用 Redigo 连接 Redis 集群的示例:
```go
package main
import (
"fmt"
"time"
"github.com/gomodule/redigo/redis"
)
func main() {
cluster := &redis.Cluster{
MaxRedirects: 8,
StartupNodes: []string{
"redis://node1:6379",
"redis://node2:6379",
"redis://node3:6379",
},
DialTimeout: 10 * time.Second,
ReadTimeout: 100 * time.Millisecond,
WriteTimeout: 100 * time.Millisecond,
}
conn, err := cluster.Get()
if err != nil {
panic(err)
}
defer conn.Close()
_, err = conn.Do("SET", "key", "value")
if err != nil {
panic(err)
}
value, err := redis.String(conn.Do("GET", "key"))
if err != nil {
panic(err)
}
fmt.Println(value)
}
```
在以上示例中,我们使用了 `redis.Cluster` 结构体来连接 Redis 集群,`MaxRedirects` 指定了最大重定向次数,`StartupNodes` 指定了集群中的节点地址,`DialTimeout`、`ReadTimeout`、`WriteTimeout` 分别指定了建立连接、读取数据、写入数据的超时时间。
使用 `cluster.Get()` 方法可以获取一个连接,使用完后需要调用 `conn.Close()` 方法释放连接。在获取到连接后,我们可以使用 `conn.Do()` 方法来执行 Redis 命令,也可以使用 `redis.String()`、`redis.Int()` 等方法来获取命令执行结果。
需要注意的是,在 Redis 集群中使用 `SET`、`GET` 等单个键操作命令时,Redigo 会自动进行分片操作,将请求发送到正确的节点。但是在使用一些不支持分片的命令时,需要手动指定节点。例如使用 `MGET` 命令时,需要使用 `redis.MultiConn.Do()` 方法并手动指定节点。
golang 实现redis分布式锁
实现 Redis 分布式锁的基本思路是利用 Redis 的 SETNX 命令(SET if Not eXists)实现。SETNX 命令会在 key 不存在的情况下,将 key 的值设为 value,如果 key 已经存在,则不做任何操作。
以下是一个简单的 Golang 实现 Redis 分布式锁的代码示例:
```go
package redislock
import (
"fmt"
"time"
"github.com/go-redis/redis/v7"
)
type RedisLock struct {
redisClient *redis.Client
key string
value string
expiration time.Duration
}
func NewRedisLock(redisClient *redis.Client, key, value string, expiration time.Duration) *RedisLock {
return &RedisLock{
redisClient: redisClient,
key: key,
value: value,
expiration: expiration,
}
}
func (r *RedisLock) Lock() (bool, error) {
success, err := r.redisClient.SetNX(r.key, r.value, r.expiration).Result()
if err != nil {
return false, err
}
return success, nil
}
func (r *RedisLock) Unlock() error {
err := r.redisClient.Del(r.key).Err()
if err != nil {
return err
}
return nil
}
```
在上面的代码中,NewRedisLock 函数用于创建一个 RedisLock 实例,需要传入 Redis 客户端、锁的 key、锁的值、锁的过期时间。Lock 方法用于尝试获取锁,如果获取成功,返回 true,否则返回 false。Unlock 方法用于释放锁。
以下是一个简单的使用示例:
```go
package main
import (
"fmt"
"time"
"github.com/go-redis/redis/v7"
"github.com/yourusername/redislock"
)
func main() {
redisClient := redis.NewClient(&redis.Options{
Addr: "localhost:6379",
DB: 0,
})
lock := redislock.NewRedisLock(redisClient, "my-lock", "my-value", 10*time.Second)
success, err := lock.Lock()
if err != nil {
fmt.Println("failed to acquire lock:", err)
return
}
if !success {
fmt.Println("lock is already held by another process")
return
}
defer lock.Unlock()
// Do some work
}
```
在上面的示例中,我们创建了一个 Redis 客户端,并且创建了一个 RedisLock 实例。然后,我们调用 Lock 方法尝试获取锁,如果获取成功,就可以进行一些需要加锁的操作。最后,我们调用 Unlock 方法释放锁。
阅读全文