赞
踩
session:服务器端为每个回话创建的一个用于数据共享的对象
session依赖于jsessionid这个cookie
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
面向的列的存储
。 列式存储
。 海量存储
。 易于扩展
。 稀疏
。 高并发
学习:查看:https://how2j.cn/k/redis/redis-commands/1369.html
总结:查看:https://zhuanlan.zhihu.com/p/37982685
键值形式的nosql
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命令
下载:https://github.com/ServiceStack/redis-windows/tree/master/downloads
解压缩
在redis文件夹中创建一个startup.cmd文件
启动文件: 执行redix-server时 需要加载redis.windows.conf配置文件
redis默认端口:6379
双击redis-cli.exe即可打开客户端
测试redis对五种数据库类型的操作命令
参考:https://how2j.cn/k/redis/redis-commands/1369.html
<!--测试jedis-->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
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+"次"); } }
只master安装即可
[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
[root@java26master ~]# yum install -y gcc-c++
[root@java26master ~]# yum install -y tcl
[root@java26master redis-5.0.4]# pwd
/root/redis-5.0.4
[root@java26master redis-5.0.4]# make
[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
最好结果
[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@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
注释掉:第69行
[root@java26master bin]# pwd
/usr/soft/redis/bin
[root@java26master bin]# ./redis-server
此窗口一致保持打开 关闭就是关闭了redis服务器
[root@java26master bin]# pwd
/usr/soft/redis/bin
[root@java26master bin]# ./redis-cli
127.0.0.1:6379>
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
参考:https://www.cnblogs.com/heqiuyong/p/10468109.html
88 # 启动密码
89 protected-mode yes
90 # 设置远程密码
91 requirepass 123456
<!--测试jedis-->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
<!--spring通过redis实现session共享的jar-->
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
<version>1.2.2.RELEASE</version>
</dependency>
<!--添加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>
位置: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>
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 即可
更改步骤:参考第五步的:2 、3、4
如果报错404:说明redis连接失败:重新执行 步骤13 14 15即可
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。