java redis 入门

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 简介      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实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
1天前
|
人工智能 前端开发 Java
Java语言开发的AI智慧导诊系统源码springboot+redis 3D互联网智导诊系统源码
智慧导诊解决盲目就诊问题,减轻分诊工作压力。降低挂错号比例,优化就诊流程,有效提高线上线下医疗机构接诊效率。可通过人体画像选择症状部位,了解对应病症信息和推荐就医科室。
27 10
|
3天前
|
缓存 NoSQL Java
使用Redis进行Java缓存策略设计
【4月更文挑战第16天】在高并发Java应用中,Redis作为缓存中间件提升性能。本文探讨如何使用Redis设计缓存策略。Redis是开源内存数据结构存储系统,支持多种数据结构。Java中常用Redis客户端有Jedis和Lettuce。缓存设计遵循一致性、失效、雪崩、穿透和预热原则。常见缓存模式包括Cache-Aside、Read-Through、Write-Through和Write-Behind。示例展示了使用Jedis实现Cache-Aside模式。优化策略包括分布式锁、缓存预热、随机过期时间、限流和降级,以应对缓存挑战。
|
8天前
|
运维 NoSQL 算法
Java开发-深入理解Redis Cluster的工作原理
综上所述,Redis Cluster通过数据分片、节点发现、主从复制、数据迁移、故障检测和客户端路由等机制,实现了一个分布式的、高可用的Redis解决方案。它允许数据分布在多个节点上,提供了自动故障转移和读写分离的功能,适用于需要大规模、高性能、高可用性的应用场景。
15 0
|
12天前
|
存储 缓存 NoSQL
Java手撸一个缓存类似Redis
`LocalExpiringCache`是Java实现的一个本地缓存类,使用ConcurrentHashMap存储键值对,并通过ScheduledExecutorService定时清理过期的缓存项。类中包含`put`、`get`、`remove`等方法操作缓存,并有`clearCache`方法来清除过期的缓存条目。初始化时,会注册一个定时任务,每500毫秒检查并清理一次过期缓存。单例模式确保了类的唯一实例。
11 0
|
20天前
|
关系型数据库 Java 开发工具
Java入门高频考查基础知识9(15问万字参考答案)
本文探讨了Spring Cloud的工作原理,包括注册中心的心跳机制、服务发现机制,以及Eureka默认的负载均衡策略。同时,概述了Spring Boot中常用的注解及其实现方式,并深入讨论了Spring事务的注解、回滚条件、传播性和隔离级别。文章还介绍了MySQL的存储引擎及其区别,特别关注了InnoDB如何实现MySQL的事务处理。此外,本文还详细探讨了MySQL索引,包括B+树的原理和设计索引的方法。最后,比较了Git和SVN的区别,并介绍了Git命令的底层原理及流程。
29 0
Java入门高频考查基础知识9(15问万字参考答案)
|
20天前
|
存储 缓存 算法
Java入门高频考查基础知识4(字节跳动面试题18题2.5万字参考答案)
最重要的是保持自信和冷静。提前准备,并对自己的知识和经验有自信,这样您就能在面试中展现出最佳的表现。祝您面试顺利!Java 是一种广泛使用的面向对象编程语言,在软件开发领域有着重要的地位。Java 提供了丰富的库和强大的特性,适用于多种应用场景,包括企业应用、移动应用、嵌入式系统等。下是几个面试技巧:复习核心概念、熟悉常见问题、编码实践、项目经验准备、注意优缺点、积极参与互动、准备好问题问对方和知其所以然等,多准备最好轻松能举一反三。
46 0
Java入门高频考查基础知识4(字节跳动面试题18题2.5万字参考答案)
|
20天前
|
存储 算法 JavaScript
Java入门高频考查算法逻辑基础知识3-编程篇(超详细18题1.8万字参考编程实现)
解决这类问题时,建议采取下面的步骤: 理解数学原理:确保你懂得基本的数学公式和法则,这对于制定解决方案至关重要。 优化算法:了解时间复杂度和空间复杂度,并寻找优化的机会。特别注意避免不必要的重复计算。 代码实践:多编写实践代码,并确保你的代码是高效、清晰且稳健的。 错误检查和测试:要为你的代码编写测试案例,测试标准的、边缘情况以及异常输入。 进行复杂问题简化:面对复杂的问题时,先尝试简化问题,然后逐步分析和解决。 沟通和解释:在编写代码的时候清晰地沟通你的思路,不仅要写出正确的代码,还要能向面试官解释你的
32 0
|
20天前
|
存储 Java 编译器
Java入门高频考查基础知识2(超详细28题2.5万字答案)
多态是面向对象编程中的一个重要概念,它允许不同类的对象对同一消息作出不同的响应。在具体实现上,多态允许一个父类的引用指向其子类的对象,并根据实际指向的对象的类型来调用相应的方法。在 Java 中,多态可以通过以下几种方式实现:在同一个类中,方法名相同,但形参列表不同,实现了多态。子类可以重写(覆盖)其父类的方法,实现多态。在父类引用中调用该方法时,根据实际指向的子类对象的类型来调用相应的方法实现。
38 0
|
21天前
|
编解码 算法 安全
【Java技术专题】「入门到精通系列」深入探索Java技术中常用到的六种加密技术和实现
【Java技术专题】「入门到精通系列」深入探索Java技术中常用到的六种加密技术和实现
44 0
|
23天前
|
存储 NoSQL Java
Redis 数据结构操作入门
Redis 数据结构操作入门
15 0