Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
X
xzxt-rest
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
常超
xzxt-rest
Commits
6e20b4c3
Commit
6e20b4c3
authored
Aug 21, 2018
by
chang_chao@founder.com.cn
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
修改redis配置,设置密码
parent
f0f0c7be
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
271 additions
and
75 deletions
+271
-75
src/main/java/com/cc/common/util/TestRedis.java
+122
-0
src/main/java/com/cc/common/util/redisUtil.java
+0
-0
src/main/java/com/cc/service/RedisService.java
+1
-1
src/main/java/com/cc/service/imp/RedisServiceImpl.java
+10
-9
src/main/resources/resource/db.properties
+40
-2
src/main/resources/spring/applicationContext-jedis.xml
+90
-63
src/main/resources/spring/springmvc.xml
+8
-0
No files found.
src/main/java/com/cc/common/util/TestRedis.java
0 → 100644
View file @
6e20b4c3
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
src/main/java/com/cc/common/util/redisUtil.java
0 → 100644
View file @
6e20b4c3
This diff is collapsed.
Click to expand it.
src/main/java/com/cc/service/RedisService.java
View file @
6e20b4c3
...
...
@@ -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);*/
}
src/main/java/com/cc/service/imp/RedisServiceImpl.java
View file @
6e20b4c3
...
...
@@ -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
{
re
sult
=
jedisClient
.
del
(
key
);
re
disUtil
.
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);
}
}
*/
}
src/main/resources/resource/db.properties
View file @
6e20b4c3
...
...
@@ -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
src/main/resources/spring/applicationContext-jedis.xml
View file @
6e20b4c3
...
...
@@ -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
src/main/resources/spring/springmvc.xml
View file @
6e20b4c3
...
...
@@ -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
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment