redis 安装 和 基本操作

Redis 简介

Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。

Redis 是属于非关系型数据库
1.数据比模型较简单
2.需要灵活性更强的IT系统
3.对数据库性能要求较高
4.不需要高度的数据一致性
5.对于给定的key,比较容易映射复杂值的环境

Redis简介

优点:

对数据高并发读写
对海量数据的高效率存储和访问
对数据的可扩展性和高可用性

缺点:

redis(ACID处理非常简单)
ACID,指数据库事务正确执行的四个基本要素的缩写。包含:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。一个支持事务(Transaction)的数据库,必须要具有这四种特性,否则在事务过程(Transaction processing)当中无法保证数据的正确性,交易过程极可能达不到交易方的要求。
无法做到太复杂的关系型数据库模型
Redis持久化两种机制rdb和aof

Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。
Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

redis的安装

安装包

这里是安装 reids 服务端和客户端界面操作工具的安装包:

链接:https://pan.baidu.com/s/1nQ1TEUmSD2Xt70orjP8PxA
提取码:h8t9

redis的服务端安装

gcc编译c的,因为redis是c编写的,所以我们先安装下gcc

yum install gcc-c++

下载redis压缩包 并解压

reids的各个版本的下载地址:
http://download.redis.io/releases/

第一种方式是 在线安装
yum -y install wget
wget http://download.redis.io/releases/redis-5.0.2.tar.gz

第二种是直接去reis官网下载离线安装包,上传到Linux中,推荐使用第二种 (在网速不是很快的情况下,我百度云中已经提供了安装包)。

Tar -xvf redis-5.0.2.tar.gz(解压)

编译
cd redis-5.0.2/(进入目录)
Make(编译)

修改配置文件 redis.conf
redis-5.0.2 /redis.conf

将配置文件中的 daemonize 修改成 yes 。这是 开启守护进程,不开启的话,不能做其他操作
#daemonize no
daemonize yes

启动 redis
可以操作如下(指定redis.conf)
./src/redis-server redis.conf
在这里插入图片描述
使用reids客户端工具 reids-cli 测试是否成功
./src/redis-cli (使用redis)
连接上后运行ping 命令。如果输出如下结果就代表成功了:
在这里插入图片描述

可视化管理工具redis-desktop-manager安装与配置

安装比较简单,点击安装文件 下一步 下一步就好了,这里主要讲配置,我们使用客户端工具连接肯定是成不了的。要进行一些配置才能成功(我百度云中已经提供了安装包)。

修改 redis.conf 配置文件

# 这里是代表只能用本机连接
#bind 127.0.0.1                                       #注释这一行(69行)

#找到下面这一行并去除注释,并添加密码(396行)
#requirepass foobared                                 #修改前
requirepass root                                    #修改后

注:配置完成密码后,以后登录就密码按下面的命令进行登录
./redis-cli -h 127.0.0.1 -p 6379 -a root

开放端口
firewall-cmd --zone=public --add-port=6379/tcp --permanent
更新防火墙规则
firewall-cmd --reload

重启redis或Linux
service redis-server restart

reboot

测试使用客户端工具连接
在这里插入图片描述
在这里插入图片描述
下面代表连接成功:
在这里插入图片描述
当我们连接上后就可以进行一些操作,这里就简单演示一些查看指定数据库的 key(如果你刚刚安装,数据库中是没有数据的):
在这里插入图片描述

redis 基本操作

说明: 这里是使用 redis-cli 进行命令行操作

redis db0-15 的概念

redis有没有什么方法使不同的应用程序数据彼此分开同时又存储在相同的实例上呢?就相当于mysql数据库,不同的应用程序数据存储在不同的数据库下。

redis下,数据库是由一个整数索引标识,而不是由一个数据库名称。默认情况下,一个客户端连接到数据库0。redis配置文件中下面的参数来控制数据库总数:

databases 16

可以通过下面的命令来切换到不同的数据库下

select 2

随后,所有的命令将使用数据库3,知道你明确的切换到另一个数据库下。

每个数据库都有属于自己的空间,不必担心之间的key冲突。

不同的数据库下,相同的key取到各自的值。
flushdb命令清除数据,只会清除当前的数据库下的数据,不会影响到其他数据库。
flushall命令会清除这个实例的数据。在执行这个命令前要格外小心。

redis的数据类型

Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)
及zset(sorted set:有序集合)。

String(字符串)

string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。
string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。
string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。

基本操作(curd)

设置值set  key value
获取值 get key
删除值 del key

设置值定时有效过时则会返回nil(在reids中nil代表null的意思)

setex key seconds value

使用setrange 替换字符 offset 表示从第几位开始value是替换的值

 setrange key offset value

如果不存在就赋值返回为1,如果存在就返回为0

setnx key value

注意:一个键最大能存储 512MB。

Hash(哈希)

Redis hash 是一个键值(key=>value)对集合。
Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。

实例

redis 127.0.0.1:6379> HMSET cpc field1 "Hello" field2 "World"
"OK"
redis 127.0.0.1:6379> HGET cpc field1
"Hello"
redis 127.0.0.1:6379> HGET cpc field2
"World"

注意:实例中我们使用了 Redis HMSET, HGET 命令,HMSET 设置了两个 field=>value 对, HGET 获取对应 field 对应的 value。每个 hash 可以存储 232 -1 键值对(40多亿)。

List(列表)

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。像java里的队列
Lpush从头部添加一个元素
Rpush从尾部添加一个元素

实例

redis 127.0.0.1:6379> lpush test redis
(integer) 1
redis 127.0.0.1:6379> lpush test mongodb
(integer) 2
redis 127.0.0.1:6379> lpush test rabitmq
(integer) 3
redis 127.0.0.1:6379> lrange test 0 10
1) "rabitmq"
2) "mongodb"
3) "redis"
redis 127.0.0.1:6379>

注:列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。

Set(集合)

Redis的Set是string类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

**sadd 命令:**添加一个 string 元素到 key 对应的 set 集合中,成功返回1,如果元素已经在集合中返回 0,如果 key 对应的 set 不存在则返回错误。

sadd key member

实例:

redis 127.0.0.1:6379> sadd myset redis
(integer) 1
redis 127.0.0.1:6379> sadd myset mongodb
(integer) 1
redis 127.0.0.1:6379> sadd myset rabitmq
(integer) 1
redis 127.0.0.1:6379> sadd myset rabitmq
(integer) 0
redis 127.0.0.1:6379> smembers myset 

1) "redis"
2) "rabitmq"
3) "mongodb"

注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。 set 集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。

zset(sorted set:有序集合)

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。

zadd 命令
添加元素到集合,元素在集合中存在则更新对应score

zadd key score member 

实例:

redis 127.0.0.1:6379> zadd myzset 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd myzset 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd myzset 0 rabitmq
(integer) 1
redis 127.0.0.1:6379> zadd myzset 0 rabitmq
(integer) 0
redis 127.0.0.1:6379> > ZRANGEBYSCORE myzset 0 1000
1) "mongodb"
2) "rabitmq"
3) "redis"
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章