144 lines
5.0 KiB
Java
144 lines
5.0 KiB
Java
/*
|
|
* Copyright 2014-2016 the original author or authors.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package sample;
|
|
|
|
import java.util.Collections;
|
|
import java.util.Properties;
|
|
import java.util.concurrent.CountDownLatch;
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
import org.apache.geode.cache.Region;
|
|
import org.apache.geode.management.membership.ClientMembership;
|
|
import org.apache.geode.management.membership.ClientMembershipEvent;
|
|
import org.apache.geode.management.membership.ClientMembershipListenerAdapter;
|
|
|
|
import org.springframework.beans.BeansException;
|
|
import org.springframework.beans.factory.annotation.Value;
|
|
import org.springframework.beans.factory.config.BeanPostProcessor;
|
|
import org.springframework.context.annotation.Bean;
|
|
import org.springframework.context.support.PropertySourcesPlaceholderConfigurer;
|
|
import org.springframework.data.gemfire.client.ClientCacheFactoryBean;
|
|
import org.springframework.data.gemfire.support.ConnectionEndpoint;
|
|
import org.springframework.session.data.gemfire.config.annotation.web.http.EnableGemFireHttpSession;
|
|
import org.springframework.util.Assert;
|
|
|
|
// tag::class[]
|
|
@EnableGemFireHttpSession(maxInactiveIntervalInSeconds = 30, poolName = "DEFAULT") // <1>
|
|
public class ClientConfig {
|
|
|
|
static final long DEFAULT_TIMEOUT = TimeUnit.SECONDS.toMillis(60);
|
|
|
|
static final CountDownLatch LATCH = new CountDownLatch(1);
|
|
|
|
static final String DEFAULT_GEMFIRE_LOG_LEVEL = "config";
|
|
static final String PROXY_HOST = "dummy.example.com";
|
|
static final String PROXY_PORT = "3128";
|
|
|
|
@Bean
|
|
static PropertySourcesPlaceholderConfigurer propertyPlaceholderConfigurer() {
|
|
return new PropertySourcesPlaceholderConfigurer();
|
|
}
|
|
|
|
Properties gemfireProperties() { // <2>
|
|
Properties gemfireProperties = new Properties();
|
|
gemfireProperties.setProperty("name", applicationName());
|
|
// gemfireProperties.setProperty("log-file", "gemfire-client.log");
|
|
gemfireProperties.setProperty("log-level", logLevel());
|
|
return gemfireProperties;
|
|
}
|
|
|
|
String applicationName() {
|
|
return "samples:httpsession-gemfire-clientserver:".concat(getClass().getSimpleName());
|
|
}
|
|
|
|
String logLevel() {
|
|
return System.getProperty("sample.httpsession.gemfire.log-level", DEFAULT_GEMFIRE_LOG_LEVEL);
|
|
}
|
|
|
|
@Bean
|
|
ClientCacheFactoryBean gemfireCache(
|
|
@Value("${spring.session.data.gemfire.host:" + ServerConfig.SERVER_HOST + "}") String host,
|
|
@Value("${spring.session.data.gemfire.port:" + ServerConfig.SERVER_PORT + "}") int port) { // <3>
|
|
|
|
ClientCacheFactoryBean clientCacheFactory = new ClientCacheFactoryBean();
|
|
|
|
clientCacheFactory.setClose(true);
|
|
clientCacheFactory.setProperties(gemfireProperties());
|
|
|
|
// GemFire Pool settings <4>
|
|
clientCacheFactory.setKeepAlive(false);
|
|
clientCacheFactory.setPingInterval(TimeUnit.SECONDS.toMillis(5));
|
|
clientCacheFactory.setReadTimeout(intValue(TimeUnit.SECONDS.toMillis(15)));
|
|
clientCacheFactory.setRetryAttempts(1);
|
|
clientCacheFactory.setSubscriptionEnabled(true);
|
|
clientCacheFactory.setThreadLocalConnections(false);
|
|
clientCacheFactory.setServers(Collections.singletonList(newConnectionEndpoint(host, port)));
|
|
|
|
registerClientMembershipListener(); // <5>
|
|
|
|
return clientCacheFactory;
|
|
}
|
|
|
|
int intValue(Number number) {
|
|
return number.intValue();
|
|
}
|
|
|
|
ConnectionEndpoint newConnectionEndpoint(String host, int port) {
|
|
return new ConnectionEndpoint(host, port);
|
|
}
|
|
|
|
void registerClientMembershipListener() {
|
|
ClientMembership.registerClientMembershipListener(
|
|
new ClientMembershipListenerAdapter() {
|
|
@Override
|
|
public void memberJoined(ClientMembershipEvent event) {
|
|
LATCH.countDown();
|
|
}
|
|
});
|
|
}
|
|
|
|
@Bean
|
|
BeanPostProcessor gemfireCacheServerReadyBeanPostProcessor(
|
|
@Value("${spring.session.data.gemfire.host:" + ServerConfig.SERVER_HOST + "}") final String host,
|
|
@Value("${spring.session.data.gemfire.port:" + ServerConfig.SERVER_PORT + "}") final int port) { // <5>
|
|
|
|
return new BeanPostProcessor() {
|
|
|
|
public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
|
|
if (bean instanceof Region) {
|
|
try {
|
|
boolean didNotTimeout = LATCH.await(DEFAULT_TIMEOUT, TimeUnit.MILLISECONDS);
|
|
|
|
Assert.state(didNotTimeout, String.format(
|
|
"GemFire Cache Server failed to start on host [%s] and port [%d]", host, port));
|
|
}
|
|
catch (InterruptedException e) {
|
|
Thread.currentThread().interrupt();
|
|
}
|
|
}
|
|
|
|
return bean;
|
|
}
|
|
|
|
public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
|
|
return bean;
|
|
}
|
|
};
|
|
}
|
|
// end::class[]
|
|
}
|