基于idea Maven中的redis配置使用详解
作者:wbcra 发布时间:2023-11-29 11:57:28
标签:maven,redis,idea
pom.xml文件需要的内容
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
<version>2.1.0.RELEASE</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
Spring配置文件需要的内容
<!-- spring data redis -->
<bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
<property name="usePool" value="true"></property>
<property name="hostName" value="${redis.host}" />
<property name="port" value="${redis.port}" />
<!-- <property name="password" value=""/> -->
<property name="timeout" value="${redis.timeout}" />
<property name="database" value="${redis.default.db}"></property>
<constructor-arg ref="jedisPoolConfig" />
</bean>
<!-- 连接池参数配置 -->
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxTotal" value="${redis.maxActive}" />
<property name="maxIdle" value="${redis.maxIdle}" />
<property name="maxWaitMillis" value="${redis.maxWait}" />
</bean>
<!-- 配置redis模板,方便存取数据 -->
<!-- <bean id="redisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate">-->
<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
<property name="connectionFactory" ref="jedisConnectionFactory" />
</bean>
在resources中创建application.properties文件
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc\:mysql\://127.0.0.1:3306/mybatis01?useUnicode=true&characterEncoding=UTF-8
jdbc.username=root
jdbc.password=root
#定义初始连接数
jdbc.initialSize=0
#定义最大连接数
jdbc.maxActive=20
#定义最大空闲
jdbc.maxIdle=20
#定义最小空闲
jdbc.minIdle=1
#定义最长等待时间
jdbc.maxWait=60000
dbcp.initialSize=15
dbcp.maxActive=5000
dbcp.maxIdle=0
dbcp.maxWait=900000
dbcp.defaultAutoCommit=true
dbcp.removeAbandoned=true
dbcp.removeAbandonedTimeout=30
dbcp.whenExhaustedAction=1
dbcp.validationQuery=select 1
dbcp.testOnBorrow=fasle
dbcp.testOnReturn=false
#redis的服务器地址
redis.host=127.0.0.1
#redis的服务端口
redis.port=6379
#密码
redis.pass=root
#链接数据库
redis.default.db=0
#客户端超时时间单位是毫秒
redis.timeout=100000
#最大连接数
redis.maxActive=300
#最大空闲数
redis.maxIdle=100
#最大建立连接等待时间
redis.maxWait=1000
#指明是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个
#DBSync.testOnBorrow=true
redis.clientName=requirepass
redis几种类型的测试(String、list、hash、set、sortedset)
package cn.hp;
import org.junit.Test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.stream.Stream;
public class JedisTest {
@Test
public void test1(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.select(1);
jedis.set("username","张三");
System.out.println(jedis.get("username"));
jedis.close();
}
/**
* 存储以时间为限定的数据
*/
@Test
public void test2(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.select(1);
jedis.setex("code",20,"778899");
System.out.println(jedis.get("code"));
jedis.close();
}
/**
*
*/
@Test
public void test3(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.lpush("mylist","b","c","d");
jedis.rpush("mylist","e","f","g");
List<String> jlist = jedis.lrange("mylist",0,-1);
for (String j:jlist){
System.out.println(j);
}
jedis.close();
}
/**
* 操作set集合
*/
@Test
public void test4(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.sadd("myset","zs","ls","ww","zl");
Set<String> set=jedis.smembers("myset");
for (String s:set){
System.out.println(s);
}
jedis.close();
}
/**
* 操作hash 哈希类型
*/
@Test
public void test5(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.hset("myhash","userName","zs");
jedis.hset("myhash","pass","123456");
Map<String ,String>map = jedis.hgetAll("myhash");
Set<String> keys = map.keySet();
for (String k:keys){
String value = map.get(k);
System.out.println("k"+k+"value:"+value);
}
jedis.close();
}
/**
* 排序
*/
@Test
public void test6(){
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.zadd("mysort",90,"zs");
jedis.zadd("mysort",80,"ls");
jedis.zadd("mysort",70,"ww");
Set<String> set=jedis.zrange("mysort",0,-1);
for (String s:set){
System.out.println(s);
}
jedis.close();
}
/**
* jedis 连接池使用
*/
@Test
public void test7(){
JedisPoolConfig config=new JedisPoolConfig();//创建一个配置对象
config.setMaxTotal(50);
config.setMaxIdle(10);
JedisPool jedisPool = new JedisPool(config, "127.0.0.1", 6379);//获取连接池
//从连接池拿到一个jedis连接
Jedis jedis = jedisPool.getResource();
jedis.set("aabb","123");
jedis.close();//归还连接
}
}
来源:https://blog.csdn.net/wbcra/article/details/118911783
0
投稿
猜你喜欢
- mapper文件使用in("str1","str2")mybatis的xxxMapper.xml文件
- 一、简单介绍翻看Spring的源码时,发现@Bean注解的源码上标注了Since: 3.0,也就是说,@Bean注解是Spring从3.0版
- Environment的中文意思是环境,它表示整个spring应用运行时的环境信息,它包含两个关键因素profilespropertiesp
- 本文实例讲述了Android TextView中文字通过SpannableString设置属性的方法。分享给大家供大家参考,具体如下:在An
- 导入redis的jar包<!-- redis --> <dependency>  
- 前段时间写了一篇基于mybatis实现的多数据源博客。感觉不是很好,这次打算加入git,来搭建一个基于Mybatis-Plus的多数据源项目
- 1.最近的项目中,有一个Activity用到Fragment+ViewPager,其中一个fragment中实现了视频播放的功能,包含有Su
- 目录环境准备1.数据库操作1.1获取所有数据库1.2获取指定库的所有集合名1.3.删除数据库2.文档操作2.1插入文档2.2查询文档2.3分
- 前言环境: flutter sdk v1.7.8+hotfix.3@stable对应 flutter engine: 54ad777f这里关
- 前面我们完成了与商品类别相关的业务逻辑,接下来我们开始做具体商品部分。1. 数据库建表并映射Model首先我们在数据库中新建一张表,然后使用
- 简单工厂简单工厂模式是属于创建型模式,是工厂模式的一种。简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例。定义了一个创建对象的类,由
- 简介备忘录设计模式(Memento Design Pattern)也叫作快照(Snapshot)模式,主要用于实现防丢失、撤销、恢复等功能。
- 部署到webapps目录启动本文使用的Spring版本为Spring6,SpringBoot版本为3,JDK为17,可能会和之前有细微不同,
- java沙箱环境测试支付宝支付接口?准备工作,登陆支付宝开放平台,进入沙箱环境开放平台链接:https://developers.alipa
- 在笔试编程过程中,关于数据的读取如果迷迷糊糊,那后来的编程即使想法很对,实现很好,也是徒劳,于是在这里认真总结了Java Scanner 类
- spring-boot-devtools是一个为开发者服务的一个模块,其中最重要的功能就是自动应用代码更改到最新的App上面去。原理是在发现
- 要想实现android手机通过扫描名片,得到名片信息,可以使用脉可寻提供的第三方SDK,即Maketion ScanCard SDK,脉可寻
- 在客户机和服务器之间建立单一的双向连接,这就意味着客户只需要发送一个请求到服务端,那么服务端则会进行处理,处理好后则将其返回给客户端,客户端
- 类与对象:类是抽象的数据类型,对象是抽象的数据类型的具体化。使用new 关键字创建对象,默认初始化为null一个项目只存在一个main方法,
- 一、写在前面数据结构中的队列应该是比较熟悉的了,就是先进先出,因为有序故得名队列,就如同排队嘛,在对尾插入新的节点,在对首删除节点.jdk集