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

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

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
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

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/99e3d2d52dd21ebf51720c60fec11472.html