redis基本使用

redis 基础知识

基本特点

Redis 与其他 key - value 缓存产品有以下三个特点:

Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
Redis支持数据的备份,即master-slave模式的数据备份。

基本数据类型

string

基本操作 :
set :设值
get :获取值

127.0.0.1:6379> set name jr
OK
127.0.0.1:6379> get name
"jr"
127.0.0.1:6379>

list

基本操作 :
lpush:设值
lrange: 获取值

127.0.0.1:6379> lpush ages 1
(integer) 1
127.0.0.1:6379> lpush ages 2
(integer) 2
127.0.0.1:6379> lpush ages 3
(integer) 3
127.0.0.1:6379> lrange ages 0 2
1) "3"
2) "2"
3) "1"
127.0.0.1:6379> 

显示顺序插入的倒叙

hash

基本操作 :
hmset:设值
hget: 获取值

127.0.0.1:6379> hmset runnoob name "jt" age 23 sex "name"
OK
127.0.0.1:6379> hget runnoob name
"jt"
127.0.0.1:6379>

set

基本操作 :
sadd :设值
smembers : 获取值

127.0.0.1:6379> sadd keys car
(integer) 1
127.0.0.1:6379> sadd keys  bus
(integer) 1
127.0.0.1:6379> sadd keys  airplay
(integer) 1
127.0.0.1:6379> smembers keys
1) "bus"
2) "airplay"
3) "car"
127.0.0.1:6379>

这个时无序的

zset

基本操作 :
zadd :设值
zrange : 获取值

127.0.0.1:6379> zadd maker  2 import
(integer) 1
127.0.0.1:6379> zadd maker  1 other
(integer) 1
127.0.0.1:6379> zadd maker  3 nog
(integer) 1
127.0.0.1:6379> zrange maker 02
(error) ERR wrong number of arguments for 'zrange' command
127.0.0.1:6379> zrange maker 0 2
1) "other"
2) "import"
3) "nog"
127.0.0.1:6379>

科看到显示的顺序时按照 规定的顺序来的

服务实例的创建

在实际中我们通常时创建一个实例,但有时存在创建多个的情况,下面说以下创建多个的情况,一个的就更容易了。

复制多个配置文件

redis基本使用_第1张图片

修改每个配置文件中的内容

(1)修改端口

(2)修改dump文件

redis基本使用_第2张图片
redis基本使用_第3张图片
如果要添加密碼,和規定日志文件,也可修改以下參數

redis基本使用_第4张图片
redis基本使用_第5张图片

启动多个实例

redis基本使用_第6张图片
在cmd 中运行相应的配置文件,可启动多个实例

分片数据的存储

public static void testShard(){
//定义redis的配置
PoolConfig poolconfig = new PoolConfig();
poolconfig.setMaxTotal(1000); //表示redis的最大连接数——最大1000个线程
poolconfig.setMinIdle(5); //表示最小空闲数量
//定义redis的多个节点机器
List list = new ArrayList<>();
//为集合添加参数
list.add(new JedisShardInfo(“localhost”, 6379));
list.add(new JedisShardInfo(“localhost”, 6380));
list.add(new JedisShardInfo(“localhost”, 6381));
//定义redis分片连接池
ShardedJedisPool jedisPool = new ShardedJedisPool(poolconfig, list);
//获取连接操作redis
ShardedJedis shardedJedis = jedisPool.getResource();
//向redis中添加20个记录查看分片结果
for(int i = 0; i < 30; i++){
//增加的记录格式为 key=NUM_i value=i
shardedJedis.set(“NUM_”+i, “”+i);
}
}

以上是在java 代码中实现的分片数据存储

分区的不足

分区是多台redis共同作用的,如果其中一台出现了宕机现象,则整个分片都将不能使用,虽然是在一定程度上缓减了内存的压力,但是没有实现高可用。
涉及多个key的操作通常是不被支持的。举例来说,当两个set映射到不同的redis实例上时,你就不能对这两个set执行交集操作。
涉及多个key的redis事务不能使用。
当使用分区时,数据处理较为复杂,比如你需要处理多个rdb/aof文件,并且从多个实例和主机备份持久化文件。
高可用的解决方案:可以采用哨兵机制实现主从复制从而实现高可用。

redis性能查看与监控常用工具

1.redis-benchmark

redis基准信息,redis服务器性能检测
redis-benchmark -h localhost -p 6379 -c 100 -n 100000
100个并发连接,100000个请求,检测host为localhost 端口为6379的redis服务器性能

使用场景

目前公司的redis 主要用于会话共享 以及数据缓存。

你可能感兴趣的:(redis)