/* * eGov suite of products aim to improve the internal efficiency,transparency, * accountability and the service delivery of the government organizations. * * Copyright (C) <2015> eGovernments Foundation * * The updated version of eGov suite of products as by eGovernments Foundation * is available at http://www.egovernments.org * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see http://www.gnu.org/licenses/ or * http://www.gnu.org/licenses/gpl.html . * * In addition to the terms of the GPL license to be adhered to in using this * program, the following additional terms are to be complied with: * * 1) All versions of this program, verbatim or modified must carry this * Legal Notice. * * 2) Any misrepresentation of the origin of the material is prohibited. It * is required that all modified versions of this material be marked in * reasonable ways as different from the original version. * * 3) This license does not grant any rights to any user of the program * with regards to rights under trademark law for use of the trade names * or trademarks of eGovernments Foundation. * * In case of any queries, you can reach eGovernments Foundation at contact@egovernments.org. */ package org.egov.infra.config.redis; import org.egov.infra.config.properties.ApplicationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Conditional; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Profile; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.connection.RedisSentinelConfiguration; import org.springframework.data.redis.connection.jedis.JedisConnectionFactory; import org.springframework.data.redis.core.RedisTemplate; import redis.clients.jedis.JedisPoolConfig; @Configuration @Profile("production") public class RedisServerConfiguration { @Bean @Conditional(RedisServerConfigCondition.class) public EmbeddedRedisServer redisServer() { return new EmbeddedRedisServer(); } @Bean public JedisConnectionFactory redisConnectionFactory(final ApplicationProperties applicationProperties) { if (applicationProperties.sentinelEnabled() && !applicationProperties.usingEmbeddedRedis()) { RedisSentinelConfiguration sentinelConfig = new RedisSentinelConfiguration(); sentinelConfig.master(applicationProperties.sentinelMasterName()); for (String host : applicationProperties.sentinelHosts()) { String [] hostConfig = host.split(":"); sentinelConfig.sentinel(hostConfig[0].trim(),Integer.valueOf(hostConfig[1].trim())); } return new JedisConnectionFactory(sentinelConfig, redisPoolConfig()); } else { final JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory(redisPoolConfig()); jedisConnectionFactory.setHostName(applicationProperties.redisHost()); jedisConnectionFactory.setPort(applicationProperties.redisPort()); return jedisConnectionFactory; } } @Bean public JedisPoolConfig redisPoolConfig() { final JedisPoolConfig jedisPoolConfig = new JedisPoolConfig(); jedisPoolConfig.setTestOnBorrow(true); jedisPoolConfig.setMinEvictableIdleTimeMillis(60000); jedisPoolConfig.setSoftMinEvictableIdleTimeMillis(1800000); jedisPoolConfig.setNumTestsPerEvictionRun(-1); jedisPoolConfig.setTestOnReturn(false); jedisPoolConfig.setTestWhileIdle(true); jedisPoolConfig.setTimeBetweenEvictionRunsMillis(30000); return jedisPoolConfig; } @Bean(name = "redisTemplate") public RedisTemplate<Object, Object> redisTemplate(final RedisConnectionFactory cf) { final RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<>(); redisTemplate.setConnectionFactory(cf); return redisTemplate; } }