redis的客户端

article/2025/9/19 16:15:22

关系型数据库存储在磁盘当中,非关系型数据库存储在内存中 

Jedis

第一步:导入依赖包

    <dependencies><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>3.7.0</version></dependency><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter</artifactId><version>5.7.0</version><scope>test</scope></dependency><dependency><groupId>org.slf4j</groupId><artifactId>slf4j-nop</artifactId><version>1.7.2</version></dependency></dependencies>

第二步:建立连接

private Jedis jedis;@BeforeEachvoid setUp(){//建立连接jedis=new Jedis("localhost",6379);//设置密码(window端我没有设置密码)//jedis.auth("123456");//选择库jedis.select(0);}

第三步:操作库

@Testvoid testString(){//插入数据String result = jedis.set("name", "张三");System.out.println("result="+result);//获取数据String name = jedis.get("name");System.out.println("name="+name);}

第四步:关闭资源

@AfterEachvoid tearDown(){//释放资源if (jedis!=null){jedis.close();}}

 jedis本身线程不安全,频繁的创建和销毁连接是有性能损耗的,推荐使用Jedis连接池代替Jedis直连方式

Jedis连接池

public class JedisConnectionFactory {private static final JedisPool jedisPool;static {//配置连接池JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();//最大连接jedisPoolConfig.setMaxTotal(8);//设置最大空闲连接jedisPoolConfig.setMaxIdle(8);//设置最小空闲连接jedisPoolConfig.setMinIdle(0);//设置无连接时等待时间jedisPoolConfig.setMaxWaitMillis(1000);//创建连接池jedisPool=new JedisPool(jedisPoolConfig,"localhost",6379,1000);}//获取对象public static Jedis getJedis(){return jedisPool.getResource();}
}

上面第二步中建立连接修改为

        //建立连接//jedis=new Jedis("localhost",6379);jedis= JedisConnectionFactory.getJedis();

SpringDataRedis  

第一步:引入spring-boot-starter-data-redis依赖

<!--redis依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><!--commons-pool依赖--><dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId></dependency>
<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.5.7</version><relativePath/> <!-- lookup parent from repository --></parent>

 第二步:在application.yaml配置Redis信息,需要把版本号降低为2.5.7

spring:redis:port: 6379lettuce:pool:max-active: 8max-idle: 8min-idle: 0max-wait: 1000mshost: 127.0.0.1

第三步:注入RedisTemplate

@Autowiredprivate RedisTemplate redisTemplate;@Testvoid testString() {//写入一条String数据redisTemplate.opsForValue().set("name", "胡歌");//获取String数据Object name = redisTemplate.opsForValue().get("name");System.out.println("name=" + name);}

执行成功通过,但是redis数据获取name,并不是胡歌,而是Jack,实际上它存进去了,只不过name被序列化了

 

RedisTemplate可以接收任意Object作为值写入Redis,只不过写入前会把Object序列化为字节形式,默认采用JDK序列化,得到结果如下: 

缺点:可读性差、内存占用较大 

解决方法:定义RedisConfig类

package com.huhu.redis.config;import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;@Configuration
public class RedisConfig {@Beanpublic RedisTemplate<String,Object> redisTemplate(RedisConnectionFactory connectionFactory){//创建RedisTemplate对象RedisTemplate<String, Object> template = new RedisTemplate<>();//设置连接工厂template.setConnectionFactory(connectionFactory);//创建JSON序列化工具GenericJackson2JsonRedisSerializer jsonRedisSerializer = new GenericJackson2JsonRedisSerializer();//设置Key的序列化template.setKeySerializer(RedisSerializer.string());template.setHashKeySerializer(RedisSerializer.string());//设置Value的序列化template.setValueSerializer(jsonRedisSerializer);template.setHashValueSerializer(jsonRedisSerializer);//返回return template;}
}
package com.huhu;import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.core.RedisTemplate;@SpringBootTest
class RedisDemoApplicationTests {@Autowiredprivate RedisTemplate redisTemplate;@Testvoid testString() {//写入一条String数据redisTemplate.opsForValue().set("name", "胡歌");//获取String数据Object name = redisTemplate.opsForValue().get("name");System.out.println("name=" + name);}}

运行报错原因:没有导入Jackson依赖

<!--Jackson依赖--><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId></dependency>

导入依赖后运行成功,并且之前name的值Jack已经被替代了

StringRedisTemplate 

Java序列化就是指把Java对象转换为字节序列的过程 Java反序列化就是指把字节序列恢复为Java对象的过程。

为了在反序列化时知道对象的类型,JSON序列化器会将类的class类型写入json结果中,存入Redis,会带来额外的内存开销 

Spring默认提供了一个StringRedisTemplate类,它的key和value的序列化方式默认就是string方式 

@Autowiredprivate StringRedisTemplate stringRedisTemplate;@Testvoid testString() {//写入一条String数据stringRedisTemplate.opsForValue().set("name", "胡歌");//获取String数据Object name = stringRedisTemplate.opsForValue().get("name");System.out.println("name=" + name);}

 

手动序列化和手动反序列化

private static final ObjectMapper mapper=new ObjectMapper();@Testvoid testSaveUser() throws JsonProcessingException {//创建对象User user=new User("胡歌",21);//手动序列化String json = mapper.writeValueAsString(user);//写入数据stringRedisTemplate.opsForValue().set("user:200",json);//获取数据String jsonUser = stringRedisTemplate.opsForValue().get("user:200");//手动反序列化User user1 = mapper.readValue(jsonUser, User.class);System.out.println("use1r="+user1);}

RedisTemplate操作hash类型(注意方法)

@Testvoid testHash(){stringRedisTemplate.opsForHash().put("user:400","name","虎哥");stringRedisTemplate.opsForHash().put("user:400","age","21");Map<Object, Object> entries = stringRedisTemplate.opsForHash().entries("user:400");System.out.println("entries="+entries);}


http://chatgpt.dhexx.cn/article/9yCms4XO.shtml

相关文章

【Redis】客户端RedisClient

0. 目录 1. 下载2. 运行 RedisClient3.1. 链接服务器 1. 下载 官网下载&#xff1a;https://github.com/caoxinyu/RedisClient 因为我已经安装了jdk或者jre&#xff0c;所以我只用jar包版本。 我用迅雷下载&#xff0c;比较快。当然你可以用我下载好的。 百度云盘&#xff1a;…

redis:客户端管理

机制 redis提供了一些操作客户端的命令&#xff0c;比如查询所有已连接到服务端的客户端数量&#xff0c;控制客户端的连接状态&#xff08;关闭或者挂起&#xff09;等。通过客户命令我们可以轻松实现对客户端的管理、控制。 redis服务器通过监听TCP端口的方式来接收客户端连…

windows下redis可视化客户端

Redis是一个超精简的基于内存的键值对数据库(key-value)&#xff0c;一般对并发有一定要求的应用都用其储存session&#xff0c;乃至整个数据库。 redis的可视化客户端目前较流行的有三个&#xff1a;Redis Client ; Redis Desktop Manager ; Redis Studio. Redis Desktop Ma…

Redis(四) - Redis的Java客户端

文章目录 一、Redis的Java客户端二、Jedis客户端1. 快速入门&#xff08;1&#xff09;引入依赖&#xff08;2&#xff09;创建jedis对象&#xff0c;建立连接&#xff08;3&#xff09;测试&#xff0c;方法名与Redis命令一致&#xff08;4&#xff09;释放资源 2. Jedis连接池…

Redis可视化客户端汇总

因为 Redis 官方只提供了命令行版的 Redis 客户端 redis-cli&#xff0c;以至于我们在使用的时候会比较麻烦&#xff0c;通常要输入一堆命令&#xff0c;而且命令行版的客户端看起来也不够直观&#xff0c;基于以上两个原因我们需要找一个可视化的 Redis 客户端&#xff0c;下面…

redis客户端连接工具RedisDesktop安装

redis客户端连接工具RedisDesktop安装手册: RedisDesktop官方下载地址&#xff1a; https://redisdesktop.com/download 但是需要付费 这里提供一个可以免费下载的地址&#xff1a;https://pan.baidu.com/s/1ExBlD79pfypnqAeP1sXybg 下载后解压如下&#xff1a; 安装此文件&…

Redis客户端 - RedisSerializer

原文首更地址&#xff0c;阅读效果更佳&#xff01; Redis客户端 - RedisSerializer | CoderMast编程桅杆https://www.codermast.com/database/redis/redistemplate-redis-serializer.html 前景回顾 在上一篇中&#xff0c;我们实现了一个简单的案例&#xff0c;操作一个 St…

Redis(11)----Redis客户端

1&#xff0c;前言 Redis服务器是典型的一对多服务器&#xff1a;一个服务器可以与多个客户端建立网络连接&#xff0c;每个客户端可以向服务器发送命令请求&#xff0c;而服务器则接收并处理客户端发送的命令请求&#xff0c;并向客户端返回命令回复 通过使用由I/O多路复用技…

redis-客户端

redis-客户端 1、客户端属性 redis> CLIENT listaddr127.0.0.1:53428 fd6 name age1242 idle0 ... addr127.0.0.1:53469 fd7 name age4 idle4 ...typedef struct redisClient {// ...int fd;robj *name;int flags;sds querybuf;robj **argv;int argc;struct redisCommand …

Mac上好用的redis客户端推荐

推荐mac一个开源免费、好用的redis客户端&#xff1a;QuickRedis 它支持直连、哨兵、集群模式&#xff0c;并且UI是可以的&#xff0c;并且支持树形展示,同时支持json格式展示&#xff0c; 最基本的命令行模式也支持&#xff0c;总体来说界面简洁、功能完善&#xff0c;值得推…

Redis管理客户端,兼容Windows、Mac、Linux

真正的大师,永远都怀着一颗学徒的心&#xff01; 一、项目简介 Redis管理客户端&#xff0c;兼容Windows、Mac、Linux 二、实现功能 支持自定义文本视图 支持哨兵支持 Hash List Set Zset搜索支持 支持自动更新 支持SSH 通道支持 支持精确搜索 单链接支持 支持Redis&g…

用Redis客户端工具连接Redis

进入redis安装目录 vi redis.conf1.关闭默认的只允许本地登录 2.关掉保护模式 3.requirepass注释去掉&#xff0c;修改密码 4. 开启redis后台运行 5.安装redis客户端连接工具 6.确保 Linux 防火墙已经关闭&#xff0c;再连接redis systemctl stop firewalld.service syste…

【Redis入门篇】| Redis的Java客户端

目录 一&#xff1a; Redis的Java客户端 1. Jedis快速入门 2. Jedis连接池 3. SpringDataRedis快速入门 4. RedisSerializer配置 5. StringRedisTemplate 图书推荐 一&#xff1a; Redis的Java客户端 在Redis官网中提供了各种语言的客户端&#xff0c;地址&#xff1a;…

redis客户端

1、redis-cli redis自己给我们提供的一个命令行客户端 2、Java客户端-Jedis 是一个Redis的java客户端&#xff08;Java for Redis&#xff09;&#xff0c;老牌的、稳定、封装少的客户端 导包 <!-- https://mvnrepository.com/artifact/redis.clients/jedis --><d…

Redis可视化客户端

Redis是一个超精简的基于内存的键值对数据库(key-value)&#xff0c;一般对并发有一定要求的应用都用其储存session&#xff0c;乃至整个数据库。 redis的可视化客户端目前较流行的有三个&#xff1a;Redis Client ; Redis Desktop Manager ; Redis Studio. Redis Desktop Ma…

【Redis学习笔记(九)】之 Redis客户端详解

文章目录 本文章由公号【开发小鸽】发布&#xff01;欢迎关注&#xff01;&#xff01;&#xff01;一&#xff0e; 客户端&#xff08;一&#xff09; 概述&#xff08;二&#xff09; 客户端属性1. 套接字描述符2. 名字3. 标志4. 输入缓冲区5. 命令与命令参数6. 命令的实现函…

[Redis]Redis客户端

文章目录 1. Redis 客户端2. Redis 命令行客户端2.1 redis-cli 的使用2.1.1 进入 redis-cli 交互控制台方式一2.1.1 进入 redis-cli 交互控制台方式二 3. Redis 图形化桌面客户端3.1 Redis 图形化桌面客户端下载3.2 Redis 图形化桌面客户端安装3.3 Redis 图形化桌面客户端连接 …

Redis 基础 -- Redis可视化客户端(Redis Desktop Manager)

文章目录 1. Redis可视化客户端&#xff08;Redis Desktop Manager&#xff09;1.1 下载Redis Desktop Manager1.2 安装 Redis Desktop Manager1.3 连接Redis服务器1.4 Redis Desktop Manager 基础操作教学1.4.1 删除数据1.4.2 添加数据1.4.3 查看数据&#xff08;点击即可&…

几款连接redis的客户端(GUI客户端),下面记录了我使用的几款

几款连接redis的客户端(GUI客户端)&#xff0c;下面记录了我使用的几款 一、Redis 客户端 1、命令行工具 命令行 (建议使用&#xff0c;简单) 比如windows的cmd和Linux、Mac的Terminal&#xff0c;虽然最简单好用。 必须保证有 redis-cli 命令(windows 是 redis-cli.exe)&…

windows下Nginx启动失败(常见的两个错误以及解决方案)

问题 windows 10 下启动nginx&#xff0c;闪屏而过&#xff0c;访问localhost显示无法访问。 尝试解决 cmd下使用命令&#xff1a;netstat -an | find "0.0.0.0:80"&#xff0c;可以发现80端口已经被占用。 使用命令&#xff1a;netstat -ano 可以发现占用80端口的…