java redis 入门

来源:互联网 发布:网络直播发展史 编辑:程序博客网 时间:2024/05/16 23:36

简介
     Redis是一个开源,先进的key-value存储,并用于构建高性能,可扩展的Web应用程序的完美解决方案。
     Redis从它的许多竞争继承来的三个主要特点:
          Redis数据库完全在内存中,使用磁盘仅用于持久性。
          相比许多键值数据存储,Redis拥有一套较为丰富的数据类型。
          Redis可以将数据复制到任意数量的从服务器。
    Redis 优势
         异常快速:Redis的速度非常快,每秒能执行约11万集合,每秒约81000+条记录。
         支持丰富的数据类型:Redis支持最大多数开发人员已经知道像列表,集合,有序集合,散列数据类型。这使得它非常容易解决各种各样的问题,因为我们知道哪些问题是可以处理通过它的数据类型更好。
         操作都是原子性:所有Redis操作是原子的,这保证了如果两个客户端同时访问的Redis服务器将获得更新后的值。
        多功能实用工具:Redis是一个多实用的工具,可以在多个用例如缓存,消息,队列使用(Redis原生支持发布/订阅),任何短暂的数据,应用程序,如Web应用程序会话,网页命中计数等。

特点:

Redis跟memcache不同的是,储存在Redis中的数据是持久化的,断电或重启后,数据也不会丢失。因为Redis的存储分为内存存储、磁盘存储和log文件三部分,重启后,Redis可以从磁盘重新将数据加载到内存中,这些可以通过配置文件对其进行配置,正因为这样,Redis才能实现持久化。Redis支持主从模式,可以配置集群,这样更利于支撑起大型的项目,这也是Redis的一大亮点。


1、下载 

windows版本  https://github.com/MSOpenTech/redis/releases

下载之后解压缩


2、配置

打开 redis.windows.conf文件

找到requirepass后面配置你的密码即可

还可以配置其他项,如 Maxmemory 设置redis能够使用的最大内存


3、运行

命令行运行: redis-server  redis.windows.conf

为了方便可以把他写成bat文件,以便执行。

这里推荐一个方便的redis可视化管理工具  https://github.com/uglide/RedisDesktopManager

当然你也可以双击redis-cli.exe 来运行redis的命令行


4、java运行redis

首先需要一个jedis的jar包

可以在maven的pom文件里添加

<dependency>    <groupId>redis.clients</groupId>    <artifactId>jedis</artifactId>    <version>2.9.0</version></dependency>

5、redisUtil.java

import redis.clients.jedis.Jedis;import redis.clients.jedis.JedisPool;import redis.clients.jedis.JedisPoolConfig;public final class RedisUtil {    //Redis服务器IP    private static String ADDR = "127.0.0.1";    //Redis的端口号    private static int PORT = 6379;    //访问密码    private static String AUTH = "123";    //可用连接实例的最大数目,默认值为8    //如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。    private static int MAX_ACTIVE = 1024;    //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。    private static int MAX_IDLE = 200;    //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;    private static int MAX_WAIT = 10000;    private static int TIMEOUT = 10000;    //在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;    private static boolean TEST_ON_BORROW = true;    private static JedisPool jedisPool = null;    /**     * 初始化Redis连接池     */    static {        try {            JedisPoolConfig config = new JedisPoolConfig();            config.setMaxWaitMillis(MAX_WAIT);            config.setMaxIdle(MAX_IDLE);            config.setMaxTotal(MAX_ACTIVE);            config.setTestOnBorrow(TEST_ON_BORROW);            jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH);        } catch (Exception e) {            e.printStackTrace();        }    }        /**     * 获取Jedis实例     * @return     */    public synchronized static Jedis getJedis() {        try {            if (jedisPool != null) {                Jedis resource = jedisPool.getResource();                return resource;            } else {                return null;            }        } catch (Exception e) {            e.printStackTrace();            return null;        }    }        /**     * 释放jedis资源,用完之后记得释放jedis资源     * @param jedis     */    public static void returnResource(Jedis jedis) {        if (jedis != null) {            jedis.close();        }    }    }

6、有了上面的工具类,你就可以很方便的用java操作redis了,下面是一些简单的例子

   public static void main(String[] args) {      Jedis jedis=RedisUtil.getJedis();              jedis.set("name","jinkai");//向key-->name中放入了value-->xinxin             System.out.println(jedis.get("name"));//执行结果:xinxin             jedis.append("name", " is the best!"); //拼接           System.out.println(jedis.get("name"));            jedis.del("name");  //删除某个键           System.out.println(jedis.get("name"));           //设置多个键值对           jedis.mset("name","jinkai","age","23","qq","1434262447");           jedis.incr("age"); //进行加1操作           System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq"));                       //redis操作Map   Map<String, String> map = new HashMap<String, String>();           map.put("name", "jinkai");           map.put("age", "24");           map.put("qq", "1434262447");           jedis.hmset("user",map);           List<String> rsmap = jedis.hmget("user", "name", "age", "qq");           System.out.println(rsmap);             //删除map中的某个键值                 jedis.hdel("user","age");               System.out.println(jedis.hmget("user", "age")); //因为删除了,所以返回的是null                 System.out.println(jedis.hlen("user")); //返回key为user的键中存放的值的个数2                System.out.println(jedis.exists("user"));//是否存在key为user的记录 返回true                 System.out.println(jedis.hkeys("user"));//返回map对象中的所有key                 System.out.println(jedis.hvals("user"));//返回map对象中的所有value                Iterator<String> iter=jedis.hkeys("user").iterator();                 while (iter.hasNext()){                      String key = iter.next();                      System.out.println(key+":"+jedis.hmget("user",key));                 }                             //jedis操作List            //先向key java framework中存放三条数据              jedis.lpush("java framework","spring");              jedis.lpush("java framework","struts");              jedis.lpush("java framework","hibernate");              //再取出所有数据jedis.lrange是按范围取出,              // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有              System.out.println(jedis.lrange("java framework",0,-1));              jedis.del("java framework");            jedis.rpush("java framework","spring");              jedis.rpush("java framework","struts");              jedis.rpush("java framework","hibernate");             System.out.println(jedis.lrange("java framework",0,-1));                           // jedis操作Set             jedis.sadd("username","jinkai");              jedis.sadd("username","liaoshengcai");                  jedis.sadd("username","zhouyu");                  jedis.sadd("username","yiqian");                jedis.sadd("username","who");                   //移除who                jedis.srem("username","who");                  System.out.println(jedis.smembers("username"));//获取所有加入的value                  System.out.println(jedis.sismember("username", "who"));//判断 who 是否是user集合的元素                  System.out.println(jedis.srandmember("username"));  //随机返回一个元素                System.out.println(jedis.scard("username"));//返回集合的元素个数                          //jedis 排序              jedis.rpush("a", "1");              jedis.lpush("a","6");              jedis.lpush("a","3");              jedis.lpush("a","9");              System.out.println(jedis.lrange("a",0,-1)); // [9, 3, 6, 1]              System.out.println(jedis.sort("a")); //[1, 3, 6, 9]  //输入排序后结果              System.out.println(jedis.lrange("a",0,-1));                           RedisUtil.returnResource(jedis);   //用完redis记得释放资源哦! }



1 0