Redis的总结及使用

Redis的使用

一:session

session:服务器端为每个回话创建的一个用于数据共享的对象

​ session依赖于jsessionid这个cookie

  • 为什么一台电脑 成功 三台服务器失败:原因:session失效
    在这里插入图片描述

二: NOSQL

NOSQL:not only sql 非关系型数据库

关系型数据库:以二维表的形式来存储和管理数据

优点:

1 数据安全:rdbms对数据有严格的数据完整性约束

2 支持复杂的数据查询: 表与表之间可以创建外键约束

3 支持事务

缺点

1:增删改查效率低

2:无法应对海亮数据的操作

NOSQL数据库: NoSQL仅仅是一个概念,泛指非关系型的数据库,区别于关系数据库,它们不保证关系数据的ACID特性

大数据量,高性能,NoSQL数据库都具有非常高的读写性能,尤其在大数据量下,同样表现优秀。这得益于它的无关系性,数据库的结构简单

常见类型

1:键值类型的nosql:redis

​ 通过key便于查询 通过key实现对value的crud

​ 。同时在内存和硬盘上保存数据

​ 。可以进行非常快速的保存和读取处理

2:文档类型的nosql:MongDB

​ 通过文件来保存数据

​ 。可以实现复杂的数据查询

3:列簇型的nosql: hbase

​ 面向的列的存储

​ 。 列式存储

​ 。 海量存储

​ 。 易于扩展

​ 。 稀疏

​ 。 高并发

三:redis

学习:查看:https://how2j.cn/k/redis/redis-commands/1369.html

总结:查看:https://zhuanlan.zhihu.com/p/37982685

键值形式的nosql

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TsaWh2YH-1602669209397)(C:\Users\ASUS\Desktop\imgs\1602646306776.png)]

  • string相关命令

    SET key value 设置key=value

    GET key 获得键key对应的值

    GETRANGE key start end 得到字符串的子字符串存放在一个键

    GETSET key value 设置键的字符串值,并返回旧值

    GETBIT key offset 返回存储在键位值的字符串值的偏移

    MGET key1 [key2…] 得到所有的给定键的值

    SETBIT key offset value 设置或清除该位在存储在键的字符串值偏移

    SETEX key seconds value 键到期时设置值

    SETNX key value 设置键的值,只有当该键不存在

    SETRANGE key offset value 覆盖字符串的一部分从指定键的偏移

    STRLEN key 得到存储在键的值的长度

    MSET key value [key value…] 设置多个键和多个值

    MSETNX key value [key value…] 设置多个键多个值,只有在当没有按键的存在时

    PSETEX key milliseconds value 设置键的毫秒值和到期时间

    INCR key 增加键的整数值一次

    INCRBY key increment 由给定的数量递增键的整数值

    INCRBYFLOAT key increment 由给定的数量递增键的浮点值

    DECR key 递减键一次的整数值

    DECRBY key decrement 由给定数目递减键的整数值

    APPEND key value 追加值到一个键

    DEL key 如果存在删除键

    DUMP key 返回存储在指定键的值的序列化版本

    EXISTS key 此命令检查该键是否存在

    EXPIRE key seconds 指定键的过期时间

    EXPIREAT key timestamp 指定的键过期时间。在这里,时间是在Unix时间戳格式

    PEXPIRE key milliseconds 设置键以毫秒为单位到期

    PEXPIREAT key milliseconds-timestamp 设置键在Unix时间戳指定为毫秒到期

    KEYS pattern 查找与指定模式匹配的所有键

    MOVE key db 移动键到另一个数据库

    PERSIST key 移除过期的键

    PTTL key 以毫秒为单位获取剩余时间的到期键。

    TTL key 获取键到期的剩余时间。

    RANDOMKEY 从Redis返回随机键

    RENAME key newkey 更改键的名称

    RENAMENX key newkey 重命名键,如果新的键不存在

    TYPE key 返回存储在键的数据类型的值。

  • list相关命令

    BLPOP key1 [key2 ] timeout 取出并获取列表中的第一个元素,或阻塞,直到有可用

    BRPOP key1 [key2 ] timeout 取出并获取列表中的最后一个元素,或阻塞,直到有可用

    BRPOPLPUSH source destination timeout 从列表中弹出一个值,它推到另一个列表并返回它;或阻塞,直到有可用

    LINDEX key index 从一个列表其索引获取对应的元素

    LINSERT key BEFORE|AFTER pivot value 在列表中的其他元素之后或之前插入一个元素

    LLEN key 获取列表的长度

    LPOP key 获取并取出列表中的第一个元素

    LPUSH key value1 [value2] 在前面加上一个或多个值的列表

    LPUSHX key value 在前面加上一个值列表,仅当列表中存在

    LRANGE key start stop 从一个列表获取各种元素

    LREM key count value 从列表中删除元素

    LSET key index value 在列表中的索引设置一个元素的值

    LTRIM key start stop 修剪列表到指定的范围内

    RPOP key 取出并获取列表中的最后一个元素

    RPOPLPUSH source destination 删除最后一个元素的列表,将其附加到另一个列表并返回它

    RPUSH key value1 [value2] 添加一个或多个值到列表

    RPUSHX key value 添加一个值列表,仅当列表中存在

  • set相关命令

    SADD key member [member …] 添加一个或者多个元素到集合(set)里

    SCARD key 获取集合里面的元素数量

    SDIFF key [key …] 获得队列不存在的元素

    SDIFFSTORE destination key [key …] 获得队列不存在的元素,并存储在一个关键的结果集

    SINTER key [key …] 获得两个集合的交集

    SINTERSTORE destination key [key …] 获得两个集合的交集,并存储在一个集合中

    SISMEMBER key member 确定一个给定的值是一个集合的成员

    SMEMBERS key 获取集合里面的所有key

    SMOVE source destination member 移动集合里面的一个key到另一个集合

    SPOP key [count] 获取并删除一个集合里面的元素

    SRANDMEMBER key [count] 从集合里面随机获取一个元素

    SREM key member [member …] 从集合里删除一个或多个元素,不存在的元素会被忽略

    SUNION key [key …] 添加多个set元素

    SUNIONSTORE destination key [key …] 合并set元素,并将结果存入新的set里面

    SSCAN key cursor [MATCH pattern] [COUNT count] 迭代set里面的元素

  • sorted set相关命令

    ZADD key score1 member1 [score2 member2] 添加一个或多个成员到有序集合,或者如果它已经存在更新其分数

    ZCARD key 得到的有序集合成员的数量

    ZCOUNT key min max 计算一个有序集合成员与给定值范围内的分数

    ZINCRBY key increment member 在有序集合增加成员的分数

    ZINTERSTORE destination numkeys key [key …] 多重交叉排序集合,并存储生成一个新的键有序集合。

    ZLEXCOUNT key min max 计算一个给定的字典范围之间的有序集合成员的数量

    ZRANGE key start stop [WITHSCORES] 由索引返回一个成员范围的有序集合(从低到高)

    ZRANGEBYLEX key min max [LIMIT offset count]返回一个成员范围的有序集合(由字典范围)

    ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 返回有序集key中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员,有序集成员按 score 值递增(从小到大)次序排列

    ZRANK key member 确定成员的索引中有序集合

    ZREM key member [member …] 从有序集合中删除一个或多个成员,不存在的成员将被忽略

    ZREMRANGEBYLEX key min max 删除所有成员在给定的字典范围之间的有序集合

    ZREMRANGEBYRANK key start stop 在给定的索引之内删除所有成员的有序集合

    ZREMRANGEBYSCORE key min max 在给定的分数之内删除所有成员的有序集合

    ZREVRANGE key start stop [WITHSCORES] 返回一个成员范围的有序集合,通过索引,以分数排序,从高分到低分

    ZREVRANGEBYSCORE key max min [WITHSCORES] 返回一个成员范围的有序集合,以socre排序从高到低

    ZREVRANK key member 确定一个有序集合成员的索引,以分数排序,从高分到低分

    ZSCORE key member 获取给定成员相关联的分数在一个有序集合

    ZUNIONSTORE destination numkeys key [key …] 添加多个集排序,所得排序集合存储在一个新的键

    ZSCAN key cursor [MATCH pattern] [COUNT count] 增量迭代排序元素集和相关的分数

  • hash相关命令

    HDEL key field[field…] 删除对象的一个或几个属性域,不存在的属性将被忽略

    HEXISTS key field 查看对象是否存在该属性域

    HGET key field 获取对象中该field属性域的值

    HGETALL key 获取对象的所有属性域和值

    HINCRBY key field value 将该对象中指定域的值增加给定的value,原子自增操作,只能是integer的属性值可以使用

    HINCRBYFLOAT key field increment 将该对象中指定域的值增加给定的浮点数

    HKEYS key 获取对象的所有属性字段

    HVALS key 获取对象的所有属性值

    HLEN key 获取对象的所有属性字段的总数

    HMGET key field[field…] 获取对象的一个或多个指定字段的值

    HSET key field value 设置对象指定字段的值

    HMSET key field value [field value …] 同时设置对象中一个或多个字段的值

    HSETNX key field value 只在对象不存在指定的字段时才设置字段的值

    HSTRLEN key field 返回对象指定field的value的字符串长度,如果该对象或者field不存在,返回0.

    HSCAN key cursor [MATCH pattern] [COUNT count] 类似SCAN命令

    四 :windows安装和使用redis

  • 下载:https://github.com/ServiceStack/redis-windows/tree/master/downloads

  • 解压缩

  • 在redis文件夹中创建一个startup.cmd文件

​ 启动文件: 执行redix-server时 需要加载redis.windows.conf配置文件在这里插入图片描述

  • 双击startup.cmd即可
    在这里插入图片描述

redis默认端口:6379

  • 双击redis-cli.exe即可打开客户端
    在这里插入图片描述

  • 测试redis对五种数据库类型的操作命令

    参考:https://how2j.cn/k/redis/redis-commands/1369.html

五:javaAPI操作redis

  • 1 引入jedis依赖
<!--测试jedis-->
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>2.9.0</version>
</dependency>
  • 2 创建测试类
public class TestJedis {
    public static void main(String[] args) {
        //创建一个jedis对象  指定redis服务器的链接参数
        //参数1:redis服务器ip
        //参数2:redis服务器端口
        //参数3:连接服务器等待的最大时间
        Jedis jedis=new Jedis("192.168.217.25",6379,100000);
        long time1=System.currentTimeMillis();
        int i;
        for (i = 1; true ; i++) {
            long time2=System.currentTimeMillis();
            if(time2-time1>1000){break;}
            //添加数据
            jedis.set("test",i+"");
            //redis中命令和jedis的方法时对应的
        }
        jedis.close();//关闭连接
        System.out.println("执行了"+i+"次");
    }
}

六: vm上安装redis:

只master安装即可

  • 上传redis-5.0.4.tar.gz到/root下并解压缩
[root@java26master ~]# pwd
/root
[root@java26master ~]# rz
[root@java26master ~]# ll
-rw-r--r--  1 root root   1966337 6月  21 2019 redis-5.0.4.tar.gz
[root@java26master ~]# tar -zxvf redis-5.0.4.tar.gz
  • redis是c语言写的 需要安装gcc-c++和tcl
[root@java26master ~]# yum install -y gcc-c++
[root@java26master ~]# yum install -y tcl
  • 对redis进行编译::make 如果有错误 多执行几次make
[root@java26master redis-5.0.4]# pwd
/root/redis-5.0.4
[root@java26master redis-5.0.4]# make
  • 对安装环境进行测试::make test
[root@java26master redis-5.0.4]# pwd
/root/redis-5.0.4
[root@java26master redis-5.0.4]# make test

错误1:
在这里插入图片描述

错误2:
在这里插入图片描述在这里插入图片描述
更改虚拟机配置需要先关闭虚拟机: shutdown -h now

最好结果
在这里插入图片描述

  • 安装redis到/usr/soft/redis目录下: make PREFIX=/usr/soft/redis install
[root@java26master redis-5.0.4]# make  PREFIX=/usr/soft/redis install
cd src && make install
make[1]: 进入目录“/root/redis-5.0.4/src”

Hint: It's a good idea to run 'make test' ;)

    INSTALL install
    INSTALL install
    INSTALL install
    INSTALL install
    INSTALL install
make[1]: 离开目录“/root/redis-5.0.4/src”
[root@java26master redis]# cd /usr/soft/redis/bin
[root@java26master bin]# ll
总用量 32712
-rwxr-xr-x 1 root root 4367376 10月 14 15:01 redis-benchmark
-rwxr-xr-x 1 root root 8103288 10月 14 15:01 redis-check-aof
-rwxr-xr-x 1 root root 8103288 10月 14 15:01 redis-check-rdb
-rwxr-xr-x 1 root root 4807712 10月 14 15:01 redis-cli
lrwxrwxrwx 1 root root      12 10月 14 15:01 redis-sentinel -> redis-server
-rwxr-xr-x 1 root root 8103288 10月 14 15:01 redis-server
  • 把/root/redis-5.0.4/redis.conf文件复制到/usr/soft/redis/bin/目录下
[root@java26master redis-5.0.4]# cp  /root/redis-5.0.4/redis.conf  /usr/soft/redis/bin/
[root@java26master redis-5.0.4]# cd /usr/soft/redis/bin
[root@java26master bin]# ll
总用量 32776
-rwxr-xr-x 1 root root 4367376 10月 14 15:01 redis-benchmark
-rwxr-xr-x 1 root root 8103288 10月 14 15:01 redis-check-aof
-rwxr-xr-x 1 root root 8103288 10月 14 15:01 redis-check-rdb
-rwxr-xr-x 1 root root 4807712 10月 14 15:01 redis-cli
-rw-r--r-- 1 root root   62155 10月 14 15:04 redis.conf
lrwxrwxrwx 1 root root      12 10月 14 15:01 redis-sentinel -> redis-server
-rwxr-xr-x 1 root root 8103288 10月 14 15:01 redis-server
  • 对/usr/soft/redis/bin/redis.conf进行编辑

注释掉:第69行
在这里插入图片描述

七 启动和连接redis

  • 启动redis服务器端:进入/usr/soft/redis/bin下执行redis-server
[root@java26master bin]# pwd
/usr/soft/redis/bin
[root@java26master bin]# ./redis-server

此窗口一致保持打开 关闭就是关闭了redis服务器

  • 关闭redis方式:关闭窗口 或者 ctrl+c
  • 进入redis的客户端:进入/usr/soft/redis/bin下执行redis-cli
[root@java26master bin]# pwd
/usr/soft/redis/bin
[root@java26master bin]# ./redis-cli
127.0.0.1:6379> 
  • 一次性设置远程连接密码:(每次redis服务开启都需要通过客户端设置一次密码)
127.0.0.1:6379> config set requirepass 123456  #设置密码
OK
127.0.0.1:6379> set name 123
(error) NOAUTH Authentication required.
127.0.0.1:6379> auth 123456    #指定密码
OK
127.0.0.1:6379> set name 123
OK
  • 永久性设置远程连接密码:(经测试不起作用)修改配置文件:/usr/soft/redis/bin/redis.conf

参考:https://www.cnblogs.com/heqiuyong/p/10468109.html

  88 # 启动密码
  89 protected-mode yes
  90 # 设置远程密码
  91 requirepass 123456
  • 重启redis服务器

八 通过redis实现session共享

  • 1 引入jedis的依赖
<!--测试jedis-->
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>2.9.0</version>
</dependency>
  • 2 引入spring-session-redis的依赖
<!--spring通过redis实现session共享的jar-->
<dependency>
    <groupId>org.springframework.session</groupId>
    <artifactId>spring-session-data-redis</artifactId>
    <version>1.2.2.RELEASE</version>
</dependency>
  • 3 在web.xml中添加spring-session过滤器
<!--添加spring-session的过滤器-->
<filter>
    <filter-name>springSessionRepositoryFilter</filter-name>
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
    <filter-name>springSessionRepositoryFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
  • 4 在spring的核心配置文件中添加三个bean

​ 位置:spring_config.xml

注意:修改hostName和password

<!--配置jedis的池对象-->
<bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
    <property name="minIdle" value="300" />
    <property name="maxWaitMillis" value="1000" />
    <property name="testOnBorrow" value="true" />
</bean>
<!-- 添加RedisHttpSessionConfiguration用于session共享 -->
<bean class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"/>
<!--配置jedis的连接数据-->
<bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
    <property name="hostName" value="192.168.2.128"/>
    <property name="port" value="6379"/>
    <property name="password" value="123456"/>
    <property name="poolConfig" ref="poolConfig"/>
    <property name="usePool" value="true"/>
    <property name="database" value="1"/>
    <property name="timeout" value="3000"/>
</bean>
  • 5 先使用windows测试是否可以连接reids

1 把静态页面重新拉回到idea
在这里插入图片描述

2 修改1:
在这里插入图片描述

3 修改2:
在这里插入图片描述

4 修改3:
在这里插入图片描述

5 重启master上的redis服务

6 进入redis的客户端并设置密码为 123456

[root@java26master bin]# ./redis-cli
127.0.0.1:6379> config set requirepass 123456
OK
(error) NOAUTH Authentication required. 
127.0.0.1:6379> auth 123456
OK

7 启动idea的tomcat 测试成功

如果tomcat日志报错:redis connection 连接失败:重新执行 步骤5 6 7 即可

  • 6 把更改后 便于在集群上运行

​ 更改步骤:参考第五步的:2 、3、4

  • 7 屏蔽 test 、clean清空、package打包
  • 8 复制war文件到桌面上 并重命名为cloud.war
  • 9 关闭集群的所有tomcat
  • 10 删除三台服务器tomcat/webapps下的cloud和cloud.war
  • 11 上传桌面的cloud.war到三台服务器的tomcat/webapps下
  • 12 重启nginx
  • 13 重启redis服务+redis客户端重新设置密码为123456
  • 14 开启三台服务器的tomcat
  • 15 在浏览器输入 192.168.2.128:80/cloud36/index.html

​ 如果报错404:说明redis连接失败:重新执行 步骤13 14 15即可

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值