开发者社区> JKXQJ> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

java redis 入门

简介: 简介      Redis是一个开源,先进的key-value存储,并用于构建高性能,可扩展的Web应用程序的完美解决方案。      Redis从它的许多竞争继承来的三个主要特点:           Redis数据库完全在内存中,使用磁盘仅用于持久性。           相比许多键值数据存储,Redis拥有一套较为丰富的数据类型。           Redis可以将数据复
+关注继续查看

简介
     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/cinience/RedisStudio

当然你也可以双击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(final Jedis jedis) {
        if (jedis != null) {
            jedisPool.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记得释放资源哦!
		 }



版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Redis 的 Java 客户端
Redis 的 Java 客户端
11 0
java Redis工具类
java Redis工具类
319 0
Java编程——Redis详解
  Redis简介   Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。   Redis 与其他 key - value 缓存产品有以下三个特点:   Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。Redis支持数据的备份,即master-slave模式的数据备份。Redis 优势:性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。丰富的数据类型 –
76 0
五:利用java使用redis
一:下载驱动包   http://static.runoob.com/download/jedis-2.9.0.jar 二:连接测试使用 string: 1 package string; 2 3 import redis.
925 0
【Redis】Java之Redis工具类
我就不介绍Redis是什么了。 (一个月前写的工具类,一直忘记分享了,算是比较全的Java-Redis工具类) 直接上代码吧。 先给出在spring 中配置Redis的代码。
1398 0
Redis与Java - 实践
Redis与Java - 实践 标签 : Java与NoSQL Transaction Redis事务(transaction)是一组命令的集合,同命令一样也是Redis的最小执行单位, Redis保证一个事务内的命令执行不被其他命令影响.
1098 0
Redis——java代码读写redis
一,简单Jedis读写       Jedis jedis=new Jedis("127.0.0.1",6379);//连接的是我本地的服务 System.out.println("成功连接到服务器=="); /*存取string类型*/ jedis.
887 0
+关注
JKXQJ
好好学习,天天向上
362
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载