当前位置: 首页 > news >正文

Java使用Redis的详细教程

Redis是一个基于内存的key-value结构数据库,即非关系型数据库,具有高性能、丰富的数据类型、持久化、高可用性和分布式等特点。在Java项目中,Redis通常用于缓存、分布式锁、计数器、消息队列和排行榜等场景。以下是在Java中使用Redis的详细教程:

一、Redis的安装与启动

  1. 下载与安装

    • 可以从Redis的官方网站或其他可信的下载源获取Redis的安装包。
    • 按照安装包的说明进行安装,通常包括解压、编译(如果需要)和配置等步骤。
  2. 启动Redis服务端

    • 在安装目录下找到redis-server.exe文件,并运行它。可以指定配置文件来启动Redis服务,例如:redis-server.exe redis.windows.conf
  3. 启动Redis客户端

    • 在安装目录下找到redis-cli.exe文件,并运行它。默认情况下,它会连接到本地的Redis服务(即6379端口)。
    • 可以使用keys *命令来测试Redis服务是否启动正确。

二、Java操作Redis的常用客户端

在Java中操作Redis,常用的客户端有Jedis、Lettuce和Spring Data Redis等。以下是这些客户端的简要介绍和使用示例:

  1. Jedis

    • Jedis是Redis官方推荐的Java客户端,封装了Redis的底层通信协议,提供了丰富的API来操作Redis。
    • 使用示例:
      Jedis jedis = new Jedis("localhost", 6379);  
      jedis.set("key", "value");  
      String value = jedis.get("key");  
      System.out.println("Value is " + value);  
      jedis.close();
  2. Lettuce

    • Lettuce是一个基于Netty的异步非阻塞Redis客户端,提供了高性能的Redis操作。
    • 使用示例:
      RedisURI redisUri = RedisURI.builder()  .withHost("127.0.0.1")  .withPort(6379)  .withPassword("yourpassword")  .withTimeout(Duration.of(10, ChronoUnit.SECONDS))  .build();  
      RedisClient redisClient = RedisClient.create(redisUri);  
      StatefulRedisConnection<String, String> connection = redisClient.connect();  
      RedisCommands<String, String> commands = connection.sync();  
      commands.set("username", "xmr");  
      String value = commands.get("username");  
      System.out.println("Value is " + value);  
      connection.close();  
      redisClient.shutdown();

  3. Spring Data Redis

    • Spring Data Redis是Spring框架提供的一个对Redis的抽象层,简化了Redis的操作,并提供了与Spring框架的无缝集成。
    • 使用示例(在Spring Boot项目中):
      • pom.xml文件中添加Spring Data Redis的依赖:
        <dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-data-redis</artifactId>  
        </dependency>
      • application.propertiesapplication.yml文件中配置Redis的连接信息:
        spring.redis.host=localhost  
        spring.redis.port=6379  
        spring.redis.password=yourpassword
      • 编写配置类,创建RedisTemplate对象:
        @Configuration  
        public class RedisConfiguration {  @Bean  public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {  RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();  redisTemplate.setConnectionFactory(redisConnectionFactory);  redisTemplate.setKeySerializer(new StringRedisSerializer());  redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());  return redisTemplate;  }  
        }
      • 在业务代码中使用RedisTemplate来操作Redis:
        @Autowired  
        private RedisTemplate<String, Object> redisTemplate;  public void setValue(String key, Object value) {  redisTemplate.opsForValue().set(key, value);  
        }  public Object getValue(String key) {  return redisTemplate.opsForValue().get(key);  
        }

三、Redis常用数据类型与命令

Redis支持多种数据类型,包括字符串(String)、哈希(Hash)、列表(List)、集合(Set)和有序集合(Sorted Set)等。以下是这些数据类型的常用命令:

  1. 字符串(String)

    • SET key value:设置指定key的值。
    • GET key:获取指定key的值。
    • SETEX key seconds value:设置指定key的值,并将key的过期时间设为seconds秒。
    • SETNX key value:只有在key不存在时设置key的值。
  2. 哈希(Hash)

    • HSET key field value:将哈希表key中的字段field的值设为value。
    • HGET key field:获取存储在哈希表中指定字段的值。
    • HDEL key field:删除存储在哈希表中的指定字段。
    • HKEYS key:获取哈希表中所有字段。
    • HVALS key:获取哈希表中所有值。
  3. 列表(List)

    • LPUSH key value1 [value2]:将一个或多个值插入列表头部(左侧)。
    • LRANGE key start stop:获取列表指定范围内的元素。
    • RPOP key:移除并获取列表最后一个元素。
    • LLEN key:获取列表长度。
  4. 集合(Set)

    • SADD key member1 [member2]:向集合添加一个或多个成员。
    • SMEMBERS key:返回集合中的所有成员。
    • SCARD key:获取集合的成员数。
    • SINTER key1 [key2]:返回给定所有集合的交集。
    • SUNION key1 [key2]:返回所有给定集合的并集。
    • SREM key member1 [member2]:删除集合中的一个或多个成员。
  5. 有序集合(Sorted Set)

    • ZADD key score1 member1 [score2 member2]:向有序集合添加一个或多个成员。
    • ZRANGE key start stop [WITHSCORES]:通过索引区间返回有序集合中指定区间内的成员。
    • ZINCRBY key increment member:有序集合中对指定成员的分数加上增量increment。
    • ZREM key member [member...]:移除有序集合中的一个或多个成员。

四、高级特性

  1. 持久化

    • RDB(Redis Database Backup):将Redis数据库的状态以快照的形式保存到磁盘上。
    • AOF(Append Only File):将Redis执行的所有写命令记录到一个追加日志文件中。
  2. 主从复制

    • 将一个Redis服务器设置为主服务器,其他Redis服务器设置为从服务器。从服务器会定期向主服务器发送同步请求,主服务器将数据同步到从服务器。
  3. Sentinel

    • Redis Sentinel是Redis的高可用解决方案之一。它可以监控Redis主从服务器的状态,当主服务器出现故障时,自动将从服务器提升为主服务器,实现故障自动切换。

通过以上教程,您可以在Java项目中顺利地使用Redis来存储和操作数据。同时,Redis的丰富特性和高级功能也将为您的项目带来更多的便利和性能提升。

相关文章:

  • AIGC: 10 AI转文服务器的搭建过程记录
  • CTMO时代下的营销新力量:2+1链动模式AI智能名片商城小程序
  • 【React】react项目中的redux使用
  • git初级使用学习(图文)
  • Java零工市场小程序如何改变自由职业者生活
  • android.bp cc_test
  • 【MySQL内置数据库】 mysql
  • HTTP 1.0 2.0 3.0详解
  • GO语言环境搭建和字符说明
  • Android studio配置AVD虚拟机
  • Unity实战案例全解析:RTS游戏的框选和阵型功能 总结
  • 关于Elastic Search与MySQL之间的数据同步
  • 如何利用ChatGPT开发一个盈利的AI写作助手网站
  • k8s集群搭建(保姆级教程以及遇到的各种问题解决)
  • CSDN 的 GIt 是没东西吗
  • Android 控件背景颜色处理
  • Docker下部署自己的LNMP工作环境
  • go append函数以及写入
  • Invalidate和postInvalidate的区别
  • Iterator 和 for...of 循环
  • JavaScript 事件——“事件类型”中“HTML5事件”的注意要点
  • JavaScript对象详解
  • MySQL常见的两种存储引擎:MyISAM与InnoDB的爱恨情仇
  • nginx 配置多 域名 + 多 https
  • nginx(二):进阶配置介绍--rewrite用法,压缩,https虚拟主机等
  • PHP 7 修改了什么呢 -- 2
  • React16时代,该用什么姿势写 React ?
  • Sublime Text 2/3 绑定Eclipse快捷键
  • 回顾 Swift 多平台移植进度 #2
  • 那些被忽略的 JavaScript 数组方法细节
  • 前端js -- this指向总结。
  • 说说动画卡顿的解决方案
  • 温故知新之javascript面向对象
  • 再次简单明了总结flex布局,一看就懂...
  • ​​​​​​​sokit v1.3抓手机应用socket数据包: Socket是传输控制层协议,WebSocket是应用层协议。
  • ​TypeScript都不会用,也敢说会前端?
  • ​必胜客礼品卡回收多少钱,回收平台哪家好
  • (2015)JS ES6 必知的十个 特性
  • (2024,Vision-LSTM,ViL,xLSTM,ViT,ViM,双向扫描)xLSTM 作为通用视觉骨干
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (6)添加vue-cookie
  • (poj1.3.2)1791(构造法模拟)
  • (附源码)springboot 房产中介系统 毕业设计 312341
  • (计算机网络)物理层
  • (六)软件测试分工
  • (完整代码)R语言中利用SVM-RFE机器学习算法筛选关键因子
  • (一)RocketMQ初步认识
  • (轉)JSON.stringify 语法实例讲解
  • (轉貼) 2008 Altera 亞洲創新大賽 台灣學生成果傲視全球 [照片花絮] (SOC) (News)
  • .describe() python_Python-Win32com-Excel
  • .NET 6 Mysql Canal (CDC 增量同步,捕获变更数据) 案例版
  • .NET CORE使用Redis分布式锁续命(续期)问题
  • .net SqlSugarHelper
  • .NET 同步与异步 之 原子操作和自旋锁(Interlocked、SpinLock)(九)
  • .NET/C# 编译期能确定的字符串会在字符串暂存池中不会被 GC 垃圾回收掉