redis基础操作

/**
 * redis的Java客户端Jedis测试验证
 *
 * @author
 */
public class Test {
  /**
   * 非切片客户端链接
   */
  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<JedisShardInfo> shards = new ArrayList<JedisShardInfo>();
    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();
  }
}
时间: 2024-08-29 02:55:50

redis基础操作的相关文章

Redis 基础操作

[Redis 基础操作] 1.ECHO message. Returns message. 2.PHING Returns PONG if no argument is provided, otherwise return a copy of the argument as a bulk. This command is often used to test if a connection is still alive, or to measure latency. 3.SELECT index

Redis基础操作学习

1. 设置值,取值. set ,get.删除映射,del    .注意,不能使用=复制,假如使用set name=1,执行成功,只能以get name=1取值为空. 2. 整型变量自动增加使用incr命令. 3.设置变量有效期,expire   , 查看变量有效期,单位为秒.ttl  -1表示永不过期,-2表示不存在了.注意,重新赋值后,有效期被重置. 4.Redis支持存储List(有序的).重要的一些命令是 RPUSH, LPUSH, LLEN, LRANGE, LPOP, 和 RPOP.

redis 基础操作教程

1.linux 安装redis : Linux 下安装 下载地址:http://redis.io/download,下载最新稳定版本. 本教程使用的最新文档版本为 2.8.17,下载并安装: $ wget http://download.redis.io/releases/redis-2.8.17.tar.gz $ tar xzf redis-2.8.17.tar.gz $ cd redis-2.8.17 $ make make完后 redis-2.8.17目录下会出现编译后的redis服务程序

Java代码redis基础操作

maven依赖包: 1 <dependency> 2 <groupId>redis.clients</groupId> 3 <artifactId>jedis</artifactId> 4 <version>2.9.0</version> 5 </dependency> 6 <dependency> 7 <groupId>org.apache.commons</groupId>

Redis数据库基础操作

MySQL和Redis的区别 """ redis: 内存数据库(读写快,IO操作少).非关系型(操作数据方便) mysql: 硬盘数据库(数据持久化,IO操作多).关系型(操作数据间关系) 大量访问的临时数据,才有redis数据库更优 """ redis和memcache的区别 """ redis: 操作字符串.列表.字典.无序集合.有序集合 | 支持数据持久化(数据丢失可以找回.可以将数据同步给mysql) | 高

Redis数据库操作、持久化详解及内存管理基础概览

Redis数据库操作.持久化详解及内存管理基础概览 前言 ? 上篇主要介绍了redis的编译安装流程以及redis常用的两个命令工具,本文主要讲述redis的数据库相关操作:增删改查等等,以及简述理解redis持久化原理和配置操作. Redis数据库操作 Redis 数据库常用命令(一般大小写均可)--比较简单,直接介绍语法,自行尝试验证当然这些只是冰山一角,例如不同的数据类型对应的操作都不一样,有研究兴趣的可以深入了解.单个数据库命令: set--写入数据 语法:set key value g

REDIS基础笔记

Redis基础笔记 资源链接 简介 简介 安装 五种数据类型及相应命令 1. 字符串类型 2. 散列类型 3. 列表类型 4. 集合类型 5. 有序集合 其他 事务 SORT 生存时间 任务队列 发布/订阅模式 Python中使用Redis 实际实例 管理 其他 资源链接 推荐书籍:<Redis入门指南> 资源列表: redis命令速查command | CMD索引-中文 | CMD树-中文 redis源码github 下载地址redis.io The Little Redis book 入口

linux redis基础应用 主从服务器配置

Redis基础应用 redis是一个开源的可基于内存可持久化的日志型,key-value数据库redis的存储分为内存存储,磁盘存储和log文件三部分配置文件中有三个参数对其进行配置 优势:和memcached相比,它支持存储的value类型相对更多,包括strings,lists,zsets(sorted set)和hashesredis会周期性的吧更新的数据写入磁盘或者把修改操作写入追加的记录文件并且在此基础上实现了master-slave(主从)同步 redis服务器服务器程序:redis

Redis 基础应用

Redis 基础应用(一) ============================================================================== 概述: ============================================================================== Redis简介  1.简介 ★Redis REmote DIctionary Server(Redis) 是一个由Salvatore Sanfili