當前位置:
                    首頁 >
                            前端技术
>                            javascript
>内容正文                
                        
                    javascript
Redis(四):Spring + JedisCluster操作Redis(集群)
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                Redis(四):Spring + JedisCluster操作Redis(集群)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.                        
                                1.maven依賴:
<dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.7.3</version> </dependency>2.增加spring 配置
<!-- ==========================JedisCluster配置=========================== --> <bean name="genericObjectPoolConfig" class="org.apache.commons.pool2.impl.GenericObjectPoolConfig"> <property name="maxWaitMillis" value="-1"></property> <property name="maxTotal" value="1000"></property> <property name="minIdle" value="8"></property> <property name="maxIdle" value="100"></property> </bean> <bean id="jedisCluster" class="com.atguigu.crud.util.JedisClusterFactory"> <property name="addressConfig"> <value>classpath:redis-nodes.properties</value> </property> <!-- 屬性文件里 key的前綴 --> <property name="addressKeyPrefix" value="address" /> <property name="timeout" value="300000" /> <property name="maxRedirections" value="6" /> <property name="genericObjectPoolConfig" ref="genericObjectPoolConfig" /> </bean>3.增加connect-redis.properties 配置文件
這里配置了6個節點
address1=192.168.221.128:7000 address2=192.168.221.128:7001 address3=192.168.221.128:7002 address4=192.168.221.129:7003 address5=192.168.221.129:7004 address6=192.168.221.129:70054.增加java類
import java.util.HashSet; import java.util.Properties; import java.util.Set; import java.util.regex.Pattern; import org.apache.commons.pool2.impl.GenericObjectPoolConfig; import org.springframework.beans.factory.FactoryBean; import org.springframework.beans.factory.InitializingBean; import org.springframework.core.io.Resource; import redis.clients.jedis.HostAndPort; import redis.clients.jedis.JedisCluster; public class JedisClusterFactory implements FactoryBean<JedisCluster>, InitializingBean { private Resource addressConfig; private String addressKeyPrefix ; private JedisCluster jedisCluster; private Integer timeout; private Integer maxRedirections; private GenericObjectPoolConfig genericObjectPoolConfig; private Pattern p = Pattern.compile("^.+[:]\\d{1,5}\\s*$"); @Override public JedisCluster getObject() throws Exception { return jedisCluster; } @Override public Class<? extends JedisCluster> getObjectType() { return (this.jedisCluster != null ? this.jedisCluster.getClass() : JedisCluster.class); } @Override public boolean isSingleton() { return true; } private Set<HostAndPort> parseHostAndPort() throws Exception { try { Properties prop = new Properties(); prop.load(this.addressConfig.getInputStream()); Set<HostAndPort> haps = new HashSet<HostAndPort>(); for (Object key : prop.keySet()) { if (!((String) key).startsWith(addressKeyPrefix)) { continue; } String val = (String) prop.get(key); Boolean isIpPort = p.matcher(val).matches(); if (!isIpPort) { throw new IllegalArgumentException("ip 或 port 不合法"); } String[] ipAndPort = val.split(":"); HostAndPort hap = new HostAndPort(ipAndPort[0], Integer.parseInt(ipAndPort[1])); haps.add(hap); } return haps; } catch (IllegalArgumentException ex) { throw ex; } catch (Exception ex) { throw new Exception("解析 jedis 配置文件失敗", ex); } } @Override public void afterPropertiesSet() throws Exception { Set<HostAndPort> haps = this.parseHostAndPort(); jedisCluster = new JedisCluster(haps, timeout, maxRedirections,genericObjectPoolConfig); } public void setAddressConfig(Resource addressConfig) { this.addressConfig = addressConfig; } public void setTimeout(int timeout) { this.timeout = timeout; } public void setMaxRedirections(int maxRedirections) { this.maxRedirections = maxRedirections; } public void setAddressKeyPrefix(String addressKeyPrefix) { this.addressKeyPrefix = addressKeyPrefix; } public void setGenericObjectPoolConfig(GenericObjectPoolConfig genericObjectPoolConfig) { this.genericObjectPoolConfig = genericObjectPoolConfig; } }5.到此配置完成
使用時,直接注入即可, 如下所示:
@Autowired JedisCluster jedisCluster;轉載于:https://www.cnblogs.com/yifanSJ/p/9105958.html
總結
以上是生活随笔為你收集整理的Redis(四):Spring + JedisCluster操作Redis(集群)的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 行业大数据爬虫练习
- 下一篇: 微信开发 getUserInfo:fai
