阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Linux下Redis数据库安装使用及Go语言操作Redis

126次阅读
没有评论

共计 4198 个字符,预计需要花费 11 分钟才能阅读完成。

Redis 简介
Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

Redis 是 NoSQL 技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色

Redis 特性

1)Redis 与其他 key – value 缓存产品有以下三个特点:
2)Redis 支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
3)Redis 不仅仅支持简单的 key-value 类型的数据,同时还提供 list,set,zset,hash 等数据结构的存储。
4)Redis 支持数据的备份,即 master-slave 模式的数据备份。

Redis 优势

1)性能极高 – Redis 能读的速度是 110000 次 /s, 写的速度是 81000 次 /s。
2)丰富的数据类型 – Redis 支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
3)原子 – Redis 的所有操作都是原子性的,同时 Redis 还支持对几个操作全并后的原子性执行。
4)丰富的特性 – Redis 还支持 publish/subscribe, 通知, key 过期等等特性。

Redis 应用场景

1)用来做缓存 (ehcache/memcached)——redis 的所有数据是放在内存中的(内存数据库)
2) 可以在某些特定应用场景下替代传统数据库——比如社交类的应用
3) 在一些大型系统中,巧妙地实现一些特定的功能:session 共享、购物车
4) 只要你有丰富的想象力,redis 可以用在可以给你无限的惊喜…….

安装
接下来以 Ubuntu 18.04 系统为例安装 Redis 数据库:

step1: 下载
wget http://download.redis.io/releases/redis-3.2.8.tar.gz

step2: 解压
tar -zxvf redis-3.2.8.tar.gz

step3: 复制,放到 usr/local/redis ⽬录下
sudo mv ./redis-3.2.8 /usr/local/redis/

step4: 进⼊ redis ⽬录
cd /usr/local/redis/

step5: 生成
a) 安装 c 语言编译器 gcc
sudo apt-get install gcc
b)安装编译命令 make
sudo apt-get install make(这一步可能会出问题,根据提示执行命令)
c)生成
sudo make(比较慢)

step6: 进入 src 下测试, 这段运⾏时间会较⻓
sudo make test

可能会遇到下面的问题

Linux 下 Redis 数据库安装使用及 Go 语言操作 Redis

解决方法
cd
wget http://downloads.sourceforge.net/tcl/tcl8.6.1-src.tar.gz
sudo tar xzvf tcl8.6.1-src.tar.gz  -C /usr/local/
cd  /usr/local/tcl8.6.1/unix/
sudo ./configure
sudo make(时间比较长)
sudo make install

我们继续来安装

step7: 安装到 usr/local/redis, 将 redis 的命令安装到 /usr/local/bin/ ⽬录
sudo make install(时间比较长)

step8: 安装完成后,我们进入目录 /usr/local/bin 中查看
cd /usr/local/bin

ls -all  看到以下文件

Linux 下 Redis 数据库安装使用及 Go 语言操作 Redis

a)redis-server      redis 服务器
b)redis-cli          redis 命令行客户端
c)redis-benchmark  redis 性能测试工具
d)redis-check-aof    AOF 文件修复工具
e)redis-check-rdb    RDB 文件检索工具

配置系统文件

step9: 配置⽂件,移动到 /etc/ ⽬录下
配置⽂件⽬录为 /usr/local/redis/redis.conf
sudo cp /usr/local/redis/redis.conf /etc/redis/
Redis 的配置信息在 /etc/redis/redis.conf 下:
查看
sudo vi /etc/redis/redis.conf
核心配置选项
绑定 ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实 ip
bind 127.0.0.1
端⼝,默认为 6379
port 6379
是否以守护进程运⾏
a) 如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务
b) 如果以⾮守护进程运⾏,则当前终端被阻塞
c) 设置为 yes 表示守护进程,设置为 no 表示⾮守护进程
d) 推荐设置为 yes
daemonize yes
数据⽂件
dbfilename dump.rdb
数据⽂件存储路径
dir /var/lib/redis
⽇志⽂件
logfile /var/log/redis/redis-server.log
数据库,默认有 16 个
database 16
主从复制,类似于双机备份。
slaveof
服务器端和客户端命令
服务器端
服务器端的命令为 redis-server
可以使⽤ help 查看帮助⽂档
redis-server –help
推荐使⽤服务的⽅式管理 redis 服务
启动
sudo service redis start
停⽌
sudo service redis stop
重启 sudo service redis restart
个人习惯
ps -aux|grep redis 查看 redis 服务器进程
sudo kill -9 pid 杀死 redis 服务器
sudo redis-server /etc/redis/redis.conf 指定加载的配置文件
客户端
客户端的命令为 redis-cli
可以使⽤ help 查看帮助⽂档
redis-cli –help
连接 redis
redis-cli
运⾏测试命令
ping
出现 PONG 表示数据库连接成功了
切换数据库
数据库没有名称,默认有 16 个,通过 0 -15 来标识,连接 redis 默认选择第一个数据库
select n
数据库结构
redis 是 key-value 的数据结构,每条数据都是⼀个键值对
键的类型是字符串
注意:键不能重复

Linux 下 Redis 数据库安装使用及 Go 语言操作 Redis

值的类型分为五种:
1)字符串 string
2)哈希 hash
3)列表 list
4)集合 set
5)有序集合 zset:
数据库操作行为
1)保存
2)修改
3)获取
4)删除

通过 go 语言和 redis 数据库进行交互

安装命令
go get -u-v github.com/gomodule/redigo/redis

安装完成后,回到家目录创建 test.go, 把下面代码复制到 test.go 里面,编译执行 test.go,之后在 redis 中查找到键 c1 值为 hello,说明安装成功

package main
import (“github.com/gomodule/redigo/redis”)
func main(){
        conn,_ := redis.Dial(“tcp”, “:6379”)
        defer conn.Close()
        conn.Do(“set”, “c1”, “hello”)
}

操作方法
Go 操作 redis 文档 https://godoc.org/github.com/gomodule/redigo/redis
连接数据库
Dial(network, address string)(conn,err)

执行数据库操作命令
Send(commandName string, args …interface{}) error
Flush() error
Receive() (reply interface{}, err error)

Send 函数发出指令,flush 将连接的输出缓冲区刷新到服务器,Receive 接收服务器返回的数据
例如:
c.Send(“SET”, “foo”, “bar”)
c.Send(“GET”, “foo”)
c.Flush()// 把缓冲区命令发到服务器
c.Receive() // 接收 set 请求返回的数据
v, err = c.Receive() // 接收 get 请求传输的数据

另外一种执行数据库操作命令
Do(commandName string, args …interface{}) (reply interface{}, err error)

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

exists, err := redis.Bool(c.Do(“EXISTS”, “foo”))
if err != nil {
// 处理错误代码
}
reflect.TypeOf(exists)// 打印 exists 类型

Scan 函数
func Scan(src [] interface {},dest … interface {})([] interface {},error)

Scan 函数从 src 复制到 dest 指向的值。
Dest 参数的值必须是整数,浮点数,布尔值,字符串,[]byte,interface{}或这些类型的切片。Scan 使用标准的 strconv 包将批量字符串转换为数字和布尔类型。

示例代码

var value1 int
var value2 string
reply, err := redis.Values(c.Do(“MGET”, “key1”, “key2”))
if err != nil {
    // 处理错误代码
}
 if _, err := redis.Scan(reply, &value1, &value2); err != nil {
    // 处理错误代码
}

序列化与反序列化
序列化(字节化)
var buffer bytes.Buffer// 容器
enc :=gob.NewEncoder(buffer)// 编码器
err:=enc.Encode(dest)// 编码

反序列化(反字节化)
dec := gob.NewDecoder(bytes.NewReader(buffer.bytes()))// 解码器
dec.Decode(src)// 解码

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计4198字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中