扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
好程序员Java学习路线分享redis快速入门,Redis的启动
创新互联建站专注于乌尔禾企业网站建设,响应式网站设计,成都做商城网站。乌尔禾网站建设公司,为乌尔禾等地区提供建站服务。全流程按需策划设计,专业设计,全程项目跟踪,创新互联建站专业和态度为您提供的服务
1) 不带配置文件启动 docker run -p 6379:6379 redis
2) 带配置文件启动
docker run -p 6379:6379 -v /usr/local/docker/redis/redis.conf:/usr/local/etc/redis/redis.conf redis redis-server /usr/local/etc/redis/redis.conf
3)使用docker容器内的客户端来操作redis服务器
以交互的方式进入到redis容器,再在/usr/local/bin/使用redis-cli工具连接redis服务器
得输密码
auth java1904
1)从官方下载tar.gz压缩包,上传到linux中
2)解压
tar -zxvf ...
3)下载make
apt-get install make
4)下载gcc,因为redis是c写的,需要gcc工具
apt-get intall gcc
5) 进入解压出来的文件夹内,然后使用make进行编译
6)进入 src,执行./redis-server ../redis.conf 开启服务端
7)使用redis内部的客户端,来连接服务端,对redis服务端进行操作
src里 执行 ./redis-cli
redis.conf
在启动redis服务器时,可以通过配置文件里面的参数的设置,来设置服务器,如果启动redis服务器,不带配置文件,那么参数都是默认值。
# bind 127.0.0.1 注释掉
在连接时需要输入密码
redis自带的客户端: redis-cli
redis.clients jedis 2.9.0
public class MyRedis { public static void main(String[] args) { Jedis jedis = new Jedis("192.168.2.128",6379); jedis.auth("java1904"); jedis.set("两个月后的目标","12k"); String target = jedis.get("两个月后的目标"); System.out.println(target); } }
set key value 添加/修改 键值对
get key ==> value 根据键得到值
del key1 [key2...] 根据键删除键值对,返回值删除的个数
mset k1 v1 k2 v2 [key value ...] 一次性插入多个值
mget k1 k2 一次性拿多个值
incr 对整数进行自增,浮点数也不行: set k1 1000 incr k1
decr 对整数进行递减
incrby 键 步长 一次增长指定步长的值
decrby 键 步长 一次减少指定步长的值
数据类型的特点:
键 - 值: 键值对
而且 键里可以存放多个键值对
hset k1 键-值
hget k1 键
hmset k1 键-值 键-值 ...
hmget k1 键 键...
hdel k1 键 键...
其他命令:
hlen k1
查看k1有几个键值对
hexists k1 键
查看键是否存在于k1中
hgetall k1
获得K1中的所有的键值对
注意: 在实际使用时,往往会使用这种命名方式: 通过“:”对键名进行分割,以起到语义化的效果。
比如 “user:1001:dreams” : 用户id是1001的这个用户的所有梦想
如果键冲突了,那么如果之前的数据类型与现在的数据类型不同,则会报这个异常:
redis.clients.jedis.exceptions.JedisDataException: WRONGTYPE Operation against a key holding the wrong kind of value
使用jedis进行操作时,hmset中需要存入map集合
HashMapmap = new HashMap (); map.put("d1","10000"); map.put("d2","20000"); jedis.hmset("user:1001:dreams",map);
hash类型的应用场景: 存对象时更方便
列表可以实现栈和队列的效果
lpop 从左边出列队
rpush 和 rpop
模拟栈的效果:
模拟队列的效果: 先进先出
其他命令:
LLEN key,查询列表的长度
LINDEX key index,获取指定索引的值 get(int index)
LSET key index value,设置指定索引的值
Ltrim key start end 保留指定索引范围的值
Sadd key element [element] 添加元素
Scard key 计算元素个数
Smembers key 获取所有的元素
Srem key element [element] 删除元素
Sismember key element 判断元素是否在集合中,存在返回1,否则返回0
Spop key 从集合随机弹出元素
是一个有序的集合
常用命令:
Zadd key score member [score member ...] 添加成员,并为每个成员设置分数
Zcard key 计算成员的个数
Zscore key member 计算某个成员的分数
Zrank key member 计算某个成员的排名
Zincrby key increment member 增加成员的分数
Zrange key start end withscores 返回指定排名范围的成员
zrevrange key start end 逆序展示
Zrem key member [member] 删除成员、
jedis的操作
@Test public void testZset(){ Jedis jedis = new Jedis("192.168.2.128",6379); jedis.auth("java1904"); HashMapmap = new HashMap (); map.put("l1",100d); map.put("l2",200d); // map是一个HashMap 的map jedis.zadd("order1",map); jedis.zincrby("order1",200d,"l1"); Set order1 = jedis.zrevrange("order1", 0, -1); System.out.println(order1); }
package com.qf.redis.util; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; public class JedisPoolUtil { private static JedisPool pool ; static{ JedisPoolConfig config = new JedisPoolConfig(); config.setMaxIdle(100); config.setMaxWaitMillis(2000); config.setMaxTotal(200); String host = "192.168.2.128"; pool = new JedisPool(config,host); } public static Jedis getJedisFromPool(){ return pool.getResource(); } }
使用连接池:
Jedis jedis = JedisPoolUtil.getJedisFromPool();
jedis.auth("java1904");
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流