设为首页 收藏本站
查看: 1086|回复: 0

[经验分享] redis学习及实践3---Jedis、JedisPool、Jedis分布式实例介绍

[复制链接]

尚未签到

发表于 2018-11-7 09:04:13 | 显示全部楼层 |阅读模式
package com.pptv.redis;  
import java.util.ArrayList;
  
import java.util.List;
  
import redis.clients.jedis.Jedis;
  
import redis.clients.jedis.JedisPool;
  
import redis.clients.jedis.JedisPoolConfig;
  
import redis.clients.jedis.JedisShardInfo;
  
import redis.clients.jedis.ShardedJedis;
  
import redis.clients.jedis.ShardedJedisPool;
  
/**
  
* redis的Java客户端Jedis测试验证
  
*
  
* @author
  
*/

  
public>  
/**
  
* 非切片客户端链接
  
*/
  
private Jedis jedis;
  
/**
  
* 非切片链接池
  
*/
  
private JedisPool jedisPool;
  
/**
  
* 切片客户端链接
  
*/
  
private ShardedJedis shardedJedis;
  
/**
  
* 切片链接池
  
*/
  
private ShardedJedisPool shardedJedisPool;
  
private String ip = "172.16.205.186";
  
/**
  
* 构造函数
  
*/
  
public Test() {
  
initialPool();
  
initialShardedPool();
  
shardedJedis = shardedJedisPool.getResource();
  
jedis = jedisPool.getResource();
  
}
  
private void initialPool() {
  
// 池基本配置
  
JedisPoolConfig config = new JedisPoolConfig();
  
config.setMaxActive(20);
  
config.setMaxIdle(5);
  
config.setMaxWait(1000l);
  
config.setTestOnBorrow(false);
  
jedisPool = new JedisPool(config, ip, 6379);
  
}
  
/**
  
* 初始化切片池
  
*/
  
private void initialShardedPool() {
  
// 池基本配置
  
JedisPoolConfig config = new JedisPoolConfig();
  
config.setMaxActive(20);
  
config.setMaxIdle(5);
  
config.setMaxWait(1000l);
  
config.setTestOnBorrow(false);
  
// slave链接
  
List shards = new ArrayList();
  
shards.add(new JedisShardInfo(ip, 6379, "master"));
  
// 构造池
  
shardedJedisPool = new ShardedJedisPool(config, shards);
  
}
  
public void show() {
  
// key检测
  
testKey();
  
// string检测
  
testString();
  
// list检测
  
testList();
  
// set检测
  
testSet();
  
// sortedSet检测
  
testSortedSet();
  
// hash检测
  
testHash();
  
shardedJedisPool.returnResource(shardedJedis);
  
}
  
private void testKey() {
  
System.out.println("=============key==========================");
  
// 清空数据
  
System.out.println(jedis.flushDB());
  
System.out.println(jedis.echo("foo"));
  
// 判断key否存在
  
System.out.println(shardedJedis.exists("foo"));
  
shardedJedis.set("key", "values");
  
System.out.println(shardedJedis.exists("key"));
  
}
  
private void testString() {
  
System.out.println("=============String==========================");
  
// 清空数据
  
System.out.println(jedis.flushDB());
  
// 存储数据
  
shardedJedis.set("foo", "bar");
  
System.out.println(shardedJedis.get("foo"));
  
// 若key不存在,则存储
  
shardedJedis.setnx("foo", "foo not exits");
  
System.out.println(shardedJedis.get("foo"));
  
// 覆盖数据
  
shardedJedis.set("foo", "foo update");
  
System.out.println(shardedJedis.get("foo"));
  
// 追加数据
  
shardedJedis.append("foo", " hello, world");
  
System.out.println(shardedJedis.get("foo"));
  
// 设置key的有效期,并存储数据
  
shardedJedis.setex("foo", 2, "foo not exits");
  
System.out.println(shardedJedis.get("foo"));
  
try {
  
Thread.sleep(3000);
  
} catch (InterruptedException e) {
  
}
  
System.out.println(shardedJedis.get("foo"));
  
// 获取并更改数据
  
shardedJedis.set("foo", "foo update");
  
System.out.println(shardedJedis.getSet("foo", "foo modify"));
  
// 截取value的值
  
System.out.println(shardedJedis.getrange("foo", 1, 3));
  
System.out.println(jedis.mset("mset1", "mvalue1", "mset2", "mvalue2",
  
"mset3", "mvalue3", "mset4", "mvalue4"));
  
System.out.println(jedis.mget("mset1", "mset2", "mset3", "mset4"));
  
System.out.println(jedis.del(new String[] { "foo", "foo1", "foo3" }));
  
}
  
private void testList() {
  
System.out.println("=============list==========================");
  
// 清空数据
  
System.out.println(jedis.flushDB());
  
// 添加数据
  
shardedJedis.lpush("lists", "vector");
  
shardedJedis.lpush("lists", "ArrayList");
  
shardedJedis.lpush("lists", "LinkedList");
  
// 数组长度
  
System.out.println(shardedJedis.llen("lists"));
  
// 排序
  
//      System.out.println(shardedJedis.sort("lists"));
  
// 字串
  
System.out.println(shardedJedis.lrange("lists", 0, 3));
  
// 修改列表中单个值
  
shardedJedis.lset("lists", 0, "hello list!");
  
// 获取列表指定下标的值
  
System.out.println(shardedJedis.lindex("lists", 1));
  
// 删除列表指定下标的值
  
System.out.println(shardedJedis.lrem("lists", 1, "vector"));
  
// 删除区间以外的数据
  
System.out.println(shardedJedis.ltrim("lists", 0, 1));
  
// 列表出栈
  
System.out.println(shardedJedis.lpop("lists"));
  
// 整个列表值
  
System.out.println(shardedJedis.lrange("lists", 0, -1));
  
}
  
private void testSet() {
  
System.out.println("=============set==========================");
  
// 清空数据
  
System.out.println(jedis.flushDB());
  
// 添加数据
  
shardedJedis.sadd("sets", "HashSet");
  
shardedJedis.sadd("sets", "SortedSet");
  
shardedJedis.sadd("sets", "TreeSet");
  
// 判断value是否在列表中
  
System.out.println(shardedJedis.sismember("sets", "TreeSet"));
  
;
  
// 整个列表值
  
System.out.println(shardedJedis.smembers("sets"));
  
// 删除指定元素
  
System.out.println(shardedJedis.srem("sets", "SortedSet"));
  
// 出栈
  
System.out.println(shardedJedis.spop("sets"));
  
System.out.println(shardedJedis.smembers("sets"));
  
//
  
shardedJedis.sadd("sets1", "HashSet1");
  
shardedJedis.sadd("sets1", "SortedSet1");
  
shardedJedis.sadd("sets1", "TreeSet");
  
shardedJedis.sadd("sets2", "HashSet2");
  
shardedJedis.sadd("sets2", "SortedSet1");
  
shardedJedis.sadd("sets2", "TreeSet1");
  
// 交集
  
System.out.println(jedis.sinter("sets1", "sets2"));
  
// 并集
  
System.out.println(jedis.sunion("sets1", "sets2"));
  
// 差集
  
System.out.println(jedis.sdiff("sets1", "sets2"));
  
}
  
private void testSortedSet() {
  
System.out.println("=============zset==========================");
  
// 清空数据
  
System.out.println(jedis.flushDB());
  
// 添加数据
  
shardedJedis.zadd("zset", 10.1, "hello");
  
shardedJedis.zadd("zset", 10.0, ":");
  
shardedJedis.zadd("zset", 9.0, "zset");
  
shardedJedis.zadd("zset", 11.0, "zset!");
  
// 元素个数
  
System.out.println(shardedJedis.zcard("zset"));
  
// 元素下标
  
System.out.println(shardedJedis.zscore("zset", "zset"));
  
// 集合子集
  
System.out.println(shardedJedis.zrange("zset", 0, -1));
  
// 删除元素
  
System.out.println(shardedJedis.zrem("zset", "zset!"));
  
System.out.println(shardedJedis.zcount("zset", 9.5, 10.5));
  
// 整个集合值
  
System.out.println(shardedJedis.zrange("zset", 0, -1));
  
}
  
private void testHash() {
  
System.out.println("=============hash==========================");
  
// 清空数据
  
System.out.println(jedis.flushDB());
  
// 添加数据
  
shardedJedis.hset("hashs", "entryKey", "entryValue");
  
shardedJedis.hset("hashs", "entryKey1", "entryValue1");
  
shardedJedis.hset("hashs", "entryKey2", "entryValue2");
  
// 判断某个值是否存在
  
System.out.println(shardedJedis.hexists("hashs", "entryKey"));
  
// 获取指定的值
  
System.out.println(shardedJedis.hget("hashs", "entryKey"));
  
// 批量获取指定的值
  
System.out
  
.println(shardedJedis.hmget("hashs", "entryKey", "entryKey1"));
  
// 删除指定的值
  
System.out.println(shardedJedis.hdel("hashs", "entryKey"));
  
// 为key中的域 field 的值加上增量 increment
  
System.out.println(shardedJedis.hincrBy("hashs", "entryKey", 123l));
  
// 获取所有的keys
  
System.out.println(shardedJedis.hkeys("hashs"));
  
// 获取所有的values
  
System.out.println(shardedJedis.hvals("hashs"));
  
}
  
/**
  
* @param args
  
*/
  
public static void main(String[] args) {
  
new Test().show();
  
}
  
}



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-631761-1-1.html 上篇帖子: redis学习及实践2---Redis的master/slave复制 下篇帖子: redis学习及实践4---redis集群及相关性能分析
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表