修改redis配置,设置密码

parent f0f0c7be
package com.cc.common.util;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class TestRedis {
public static void main(String[] args) throws Exception {
@SuppressWarnings("resource")
ApplicationContext context=new ClassPathXmlApplicationContext("classpath:spring/applicationContext-jedis.xml");
redisUtil redisUtil=(redisUtil) context.getBean("redisUtil");
//=====================testString======================
//redisUtil.set("name", "常超");
//redisUtil.set("age", 24);
//redisUtil.set("address", "山西");
//System.out.println(redisUtil.set("address", "河北邯郸", 50));
//redisUtil.set("22222", "常超");
System.out.println(redisUtil.get("15:CODE_AJDLB:05000000:05000100:抢劫案:05000100 | 抢劫案"));
//redisUtil.set("age", 1000);
//Object object = redisUtil.get("user2");
//System.out.println(object);
//redisUtil.del("address");
//redisUtil.set("class", 15);
//long incr = redisUtil.incr("a", 1);
//System.out.println(incr);
//Thread.sleep(5000);
/*Map<String,Object> map=new HashMap<>();
map.put("name", "王赛超");
map.put("age", 24);
map.put("address", "河北邯郸666");
redisUtil.hmset("15532002725", map,1000);*/
//redisUtil.del("15532002725");
//redisUtil.hset("15532002725","address","河北邯郸",1000);
//redisUtil.hdel("15532002725", "name");
//System.out.println(redisUtil.sSetAndTime("15532002727",1000,"haha"));
//System.out.println(redisUtil.sGet("15532002727"));
//System.out.println(redisUtil.sHasKey("15532002727","name"));
/* System.out.println(redisUtil.lRemove("15532002728",1,2));
System.out.println(redisUtil.lGet("15532002728",0,-1));
System.out.println(redisUtil.lGetListSize("15532002728"));
System.out.println(redisUtil.lGetIndex("15532002728",1));*/
//System.out.println(redisUtil.getExpire("15532002725"));
//System.out.println(redisUtil.hget("15532002725","name"));
//System.out.println(redisUtil.hmget("15532002725"));
}
}
class User{
private String name;
private Integer age;
private String address;
private Double classz;
private Float classz2;
public User() {
super();
}
public User(String name, Integer age, String address, Double classz,
Float classz2) {
super();
this.name = name;
this.age = age;
this.address = address;
this.classz = classz;
this.classz2 = classz2;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public Double getClassz() {
return classz;
}
public void setClassz(Double classz) {
this.classz = classz;
}
public Float getClassz2() {
return classz2;
}
public void setClassz2(Float classz2) {
this.classz2 = classz2;
}
}
\ No newline at end of file
......@@ -8,5 +8,5 @@ public interface RedisService {
XzxtRestResult ReadRedisRest(String key);
XzxtRestResult DelRedisRest(String key);
XzxtRestResult keysRedisRest(String key);
XzxtRestResult hvalsRedisRest(String hkey);
/*XzxtRestResult hvalsRedisRest(String hkey);*/
}
......@@ -2,7 +2,9 @@ package com.cc.service.imp;
import com.cc.common.pojo.XzxtRestResult;
import com.cc.common.util.ExceptionUtil;
import com.cc.common.util.redisUtil;
import com.cc.dao.JedisClient;
import com.cc.pojo.SysDictitem;
import com.cc.service.RedisService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
......@@ -18,7 +20,7 @@ import java.util.Set;
public class RedisServiceImpl implements RedisService {
@Autowired
private JedisClient jedisClient;
private redisUtil redisUtil;
/**
* 返回状态码:201:成功存入
* 返回状态码:202:成功读取
......@@ -29,7 +31,7 @@ public class RedisServiceImpl implements RedisService {
@Override
public XzxtRestResult SaveRedisRest(String key, String value) {
try {
jedisClient.set(key,value);
redisUtil.set(key, value);
} catch (Exception e) {
e.printStackTrace();
return XzxtRestResult.build(500, ExceptionUtil.getStackTrace(e));
......@@ -40,7 +42,7 @@ public class RedisServiceImpl implements RedisService {
public XzxtRestResult ReadRedisRest( String key) {
String result="";
try {
result=jedisClient.get(key);
result= redisUtil.get(key);
} catch (Exception e) {
e.printStackTrace();
return XzxtRestResult.build(500, ExceptionUtil.getStackTrace(e));
......@@ -50,9 +52,8 @@ public class RedisServiceImpl implements RedisService {
@Override
public XzxtRestResult DelRedisRest( String key) {
long result=0;
try {
result=jedisClient.del(key);
redisUtil.del(key);
} catch (Exception e) {
e.printStackTrace();
return XzxtRestResult.build(500, ExceptionUtil.getStackTrace(e));
......@@ -64,24 +65,24 @@ public class RedisServiceImpl implements RedisService {
public XzxtRestResult keysRedisRest(String key) {
Set<String> result=new HashSet<>();
try {
result=jedisClient.keys(key);
result=redisUtil.keys(key);
} catch (Exception e) {
e.printStackTrace();
return XzxtRestResult.build(500, ExceptionUtil.getStackTrace(e));
}
return XzxtRestResult.build(204,"获取指定key",result);
}
@Override
/*@Override
public XzxtRestResult hvalsRedisRest(String hkey) {
List<String> result=new ArrayList<>();
try {
result=jedisClient.hvals(hkey);
result=redisUtil.hvals(hkey);
} catch (Exception e) {
e.printStackTrace();
return XzxtRestResult.build(500, ExceptionUtil.getStackTrace(e));
}
return XzxtRestResult.build(205,"获取指定key的value",result);
}
}*/
}
......@@ -3,6 +3,43 @@ jdbc.url=jdbc:oracle:thin:@192.168.193.1:1521:XZXT
jdbc.username=XZXT
jdbc.password=XZXT
redis.host=127.0.0.1
#ip地址
redis.hostName=127.0.0.1
#端口号
redis.port=6379
redis.pass=
#如果有密码
redis.password=123
#客户端超时时间单位是毫秒 默认是2000
redis.timeout=10000
#最大空闲数
redis.maxIdle=300
#连接池的最大数据库连接数。设为0表示无限制,如果是jedis 2.4以后用redis.maxTotal
#redis.maxActive=600
#控制一个pool可分配多少个jedis实例,用来替换上面的redis.maxActive,如果是jedis 2.4以后用该属性
redis.maxTotal=1000
#最大建立连接等待时间。如果超过此时间将接到异常。设为-1表示无限制。
redis.maxWaitMillis=1000
#连接的最小空闲时间 默认1800000毫秒(30分钟)
redis.minEvictableIdleTimeMillis=300000
#每次释放连接的最大数目,默认3
redis.numTestsPerEvictionRun=1024
#逐出扫描的时间间隔(毫秒) 如果为负数,则不运行逐出线程, 默认-1
redis.timeBetweenEvictionRunsMillis=30000
#是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个
redis.testOnBorrow=true
#在空闲时检查有效性, 默认false
redis.testWhileIdle=true
#redis.sentinel.host1=172.20.1.230
#redis.sentinel.port1=26379
#redis.sentinel.host2=172.20.1.231
#redis.sentinel.port2=26379
#redis.sentinel.host3=172.20.1.232
#redis.sentinel.port3=26379
\ No newline at end of file
......@@ -7,70 +7,96 @@
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd">
<!-- 连接池配置 -->
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<!-- 最大连接数 -->
<property name="maxTotal" value="30" />
<!-- 最大空闲连接数 -->
<property name="maxIdle" value="10" />
<!-- 每次释放连接的最大数目 -->
<property name="numTestsPerEvictionRun" value="1024" />
<!-- 释放连接的扫描间隔(毫秒) -->
<property name="timeBetweenEvictionRunsMillis" value="30000" />
<!-- 连接最小空闲时间 -->
<property name="minEvictableIdleTimeMillis" value="1800000" />
<!-- 连接空闲多久后释放, 当空闲时间>该值 且 空闲连接>最大空闲连接数 时直接释放 -->
<property name="softMinEvictableIdleTimeMillis" value="10000" />
<!-- 获取连接时的最大等待毫秒数,小于零:阻塞不确定的时间,默认-1 -->
<property name="maxWaitMillis" value="1500" />
<!-- 在获取连接的时候检查有效性, 默认false -->
<property name="testOnBorrow" value="true" />
<!-- 在空闲时检查有效性, 默认false -->
<property name="testWhileIdle" value="true" />
<!-- 连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true -->
<property name="blockWhenExhausted" value="false" />
</bean>
<!-- 加载配置文件 -->
<context:property-placeholder location="classpath:resource/*.properties" />
<!-- jedis客户端单机版 -->
<bean id="redisClient" class="redis.clients.jedis.JedisPool">
<constructor-arg name="host" value="${redis.host}"></constructor-arg>
<constructor-arg name="port" value="${redis.port}"></constructor-arg>
<constructor-arg name="poolConfig" ref="jedisPoolConfig"></constructor-arg>
<!-- redis连接池配置-->
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig" >
<!--最大空闲数-->
<property name="maxIdle" value="${redis.maxIdle}" />
<!--连接池的最大数据库连接数 -->
<property name="maxTotal" value="${redis.maxTotal}" />
<!--最大建立连接等待时间-->
<property name="maxWaitMillis" value="${redis.maxWaitMillis}" />
<!--逐出连接的最小空闲时间 默认1800000毫秒(30分钟)-->
<property name="minEvictableIdleTimeMillis" value="${redis.minEvictableIdleTimeMillis}" />
<!--每次逐出检查时 逐出的最大数目 如果为负数就是 : 1/abs(n), 默认3-->
<property name="numTestsPerEvictionRun" value="${redis.numTestsPerEvictionRun}" />
<!--逐出扫描的时间间隔(毫秒) 如果为负数,则不运行逐出线程, 默认-1-->
<property name="timeBetweenEvictionRunsMillis" value="${redis.timeBetweenEvictionRunsMillis}" />
<!--是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个-->
<property name="testOnBorrow" value="${redis.testOnBorrow}" />
<!--在空闲时检查有效性, 默认false -->
<property name="testWhileIdle" value="${redis.testWhileIdle}" />
</bean >
<!-- redis集群配置 哨兵模式 -->
<!-- <bean id="sentinelConfiguration" class="org.springframework.data.redis.connection.RedisSentinelConfiguration">
<property name="master">
<bean class="org.springframework.data.redis.connection.RedisNode">
这个值要和Sentinel中指定的master的值一致,不然启动时找不到Sentinel会报错的
<property name="name" value="mymaster"></property>
</bean>
</property>
记住了,这里是指定Sentinel的IP和端口,不是Master和Slave的
<property name="sentinels">
<set>
<bean class="org.springframework.data.redis.connection.RedisNode">
<constructor-arg name="host" value="${redis.sentinel.host1}"></constructor-arg>
<constructor-arg name="port" value="${redis.sentinel.port1}"></constructor-arg>
</bean>
<bean class="org.springframework.data.redis.connection.RedisNode">
<constructor-arg name="host" value="${redis.sentinel.host2}"></constructor-arg>
<constructor-arg name="port" value="${redis.sentinel.port2}"></constructor-arg>
</bean>
<bean class="org.springframework.data.redis.connection.RedisNode">
<constructor-arg name="host" value="${redis.sentinel.host3}"></constructor-arg>
<constructor-arg name="port" value="${redis.sentinel.port3}"></constructor-arg>
</bean>
</set>
</property>
</bean>
<bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
<constructor-arg name="sentinelConfig" ref="sentinelConfiguration"></constructor-arg>
<constructor-arg name="poolConfig" ref="jedisPoolConfig"></constructor-arg>
</bean> -->
<!--redis连接工厂 -->
<bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" destroy-method="destroy">
<property name="poolConfig" ref="jedisPoolConfig"></property>
<!--IP地址 -->
<property name="hostName" value="${redis.hostName}"></property>
<!--端口号 -->
<property name="port" value="${redis.port}"></property>
<!--如果Redis设置有密码 -->
<property name="password" value="${redis.password}" />
<!--客户端超时时间单位是毫秒 -->
<property name="timeout" value="${redis.timeout}"></property>
</bean>
<bean id="jedisClient" class="com.cc.dao.imp.JedisClientSingle"/>
<!-- jedis集群版配置 -->
<!--<bean id="redisClient" class="redis.clients.jedis.JedisCluster">
<constructor-arg name="nodes">
<set>
<bean class="redis.clients.jedis.HostAndPort">
<constructor-arg name="host" value="192.168.193.128"></constructor-arg>
<constructor-arg name="port" value="7001"></constructor-arg>
</bean>
<bean class="redis.clients.jedis.HostAndPort">
<constructor-arg name="host" value="192.168.193.128"></constructor-arg>
<constructor-arg name="port" value="7002"></constructor-arg>
</bean>
<bean class="redis.clients.jedis.HostAndPort">
<constructor-arg name="host" value="192.168.193.128"></constructor-arg>
<constructor-arg name="port" value="7003"></constructor-arg>
</bean>
<bean class="redis.clients.jedis.HostAndPort">
<constructor-arg name="host" value="192.168.193.128"></constructor-arg>
<constructor-arg name="port" value="7004"></constructor-arg>
</bean>
<bean class="redis.clients.jedis.HostAndPort">
<constructor-arg name="host" value="192.168.193.128"></constructor-arg>
<constructor-arg name="port" value="7005"></constructor-arg>
</bean>
<bean class="redis.clients.jedis.HostAndPort">
<constructor-arg name="host" value="192.168.193.128"></constructor-arg>
<constructor-arg name="port" value="7006"></constructor-arg>
</bean>
</set>
</constructor-arg>
<constructor-arg name="poolConfig" ref="jedisPoolConfig"></constructor-arg>
<!--redis操作模版,使用该对象可以操作redis -->
<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate" >
<property name="connectionFactory" ref="jedisConnectionFactory" />
<!--如果不配置Serializer,那么存储的时候缺省使用String,如果用User类型存储,那么会提示错误User can't cast to String!! -->
<property name="keySerializer" >
<bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
</property>
<property name="valueSerializer" >
<bean class="org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer" />
</property>
<property name="hashKeySerializer">
<bean class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
</property>
<property name="hashValueSerializer">
<bean class="org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer"/>
</property>
<!--开启事务 -->
<property name="enableTransactionSupport" value="true"></property>
</bean >
<!--自定义redis工具类,在需要缓存的地方注入此类 -->
<bean id="redisUtil" class="com.cc.common.util.redisUtil">
<property name="redisTemplate" ref="redisTemplate" />
</bean>
<bean id="jedisClientCluster" class="com.taotao.rest.dao.impl.JedisClientCluster"></bean>-->
</beans>
\ No newline at end of file
......@@ -14,4 +14,11 @@
<property name="prefix" value="/WEB-INF/jsp/" />
<property name="suffix" value=".jsp" />
</bean>
<bean id="appProperty" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<array>
<value>classpath:resource/*.properties</value>
</array>
</property>
</bean>
</beans>
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment