Skip to content

Commit

Permalink
Merge pull request apolloconfig#672 from nobodyiam/refresh-scope-demo-2
Browse files Browse the repository at this point in the history
add more refresh scope sample
  • Loading branch information
nobodyiam authored Jul 25, 2017
2 parents 7b41718 + d34c91f commit 84053f7
Show file tree
Hide file tree
Showing 7 changed files with 84 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -25,4 +25,9 @@ void initialize() {
public void setBatch(int batch) {
this.batch = batch;
}

@Override
public String toString() {
return String.format("[NormalBean] timeout: %d, batch: %d", timeout, batch);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import com.ctrip.framework.apollo.spring.annotation.EnableApolloConfig;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

Expand All @@ -13,7 +14,8 @@
@Configuration
@EnableApolloConfig(value = "application", order = 10)
public class AppConfig {
@Bean
@Bean("normalBean")
@RefreshScope
public NormalBean normalBean(@Value("${batch:100}") int batch) {
NormalBean bean = new NormalBean();
bean.setBatch(batch);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

import com.ctrip.framework.apollo.Config;
import com.ctrip.framework.apollo.ConfigChangeListener;
import com.ctrip.framework.apollo.demo.spring.common.bean.NormalBean;
import com.ctrip.framework.apollo.demo.spring.common.bean.RefreshScopeBean;
import com.ctrip.framework.apollo.model.ConfigChangeEvent;
import com.ctrip.framework.apollo.spring.annotation.ApolloConfig;
Expand Down Expand Up @@ -32,21 +33,26 @@ public class ApolloRefreshConfig implements ConfigChangeListener {
private RefreshScope refreshScope;

@Autowired
@Qualifier("refreshScopeBean")
private RefreshScopeBean refreshScopeBean;

@Autowired
private NormalBean normalBean;

@PostConstruct
private void init() {
logger.info(refreshScopeBean.toString());
config.addChangeListener(this);
anotherConfig.addChangeListener(this);
}

@Override
public void onChange(ConfigChangeEvent changeEvent) {
//could also call refreshScope.refreshAll();
logger.info("refreshScopeBean before refresh {}", refreshScopeBean.toString());
//could also call refreshScope.refreshAll();
refreshScope.refresh("refreshScopeBean");
logger.info("refreshScopeBean after refresh {}", refreshScopeBean.toString());
logger.info("normalBean with refresh scope before refresh {}", normalBean.toString());
refreshScope.refresh("normalBean");
logger.info("normalBean with refresh scope after refresh {}", normalBean.toString());
}
}
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
package com.ctrip.framework.apollo.demo.spring.javaConfigDemo.config;

import com.ctrip.framework.apollo.demo.spring.common.refresh.ApolloRefreshConfig;

import org.springframework.cloud.autoconfigure.RefreshAutoConfiguration;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;

Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
package com.ctrip.framework.apollo.demo.spring.springBootDemo.config;

import com.ctrip.framework.apollo.ConfigChangeListener;
import com.ctrip.framework.apollo.model.ConfigChangeEvent;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.stereotype.Component;

import javax.annotation.PostConstruct;
Expand All @@ -11,7 +15,8 @@
* @author Jason Song([email protected])
*/
@ConfigurationProperties(prefix = "redis.cache")
@Component
@Component("sampleRedisConfig")
@RefreshScope
public class SampleRedisConfig {
private static final Logger logger = LoggerFactory.getLogger(SampleRedisConfig.class);

Expand All @@ -36,4 +41,10 @@ public void setClusterNodes(String clusterNodes) {
public void setCommandTimeout(int commandTimeout) {
this.commandTimeout = commandTimeout;
}

@Override
public String toString() {
return String.format("[SampleRedisConfig] expireSeconds: %d, clusterNodes: %s, commandTimeout: %d",
expireSeconds, clusterNodes, commandTimeout);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
package com.ctrip.framework.apollo.demo.spring.springBootDemo.refresh;

import com.ctrip.framework.apollo.Config;
import com.ctrip.framework.apollo.ConfigChangeListener;
import com.ctrip.framework.apollo.demo.spring.common.refresh.ApolloRefreshConfig;
import com.ctrip.framework.apollo.demo.spring.springBootDemo.config.SampleRedisConfig;
import com.ctrip.framework.apollo.model.ConfigChangeEvent;
import com.ctrip.framework.apollo.spring.annotation.ApolloConfig;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.context.scope.refresh.RefreshScope;
import org.springframework.stereotype.Component;

import javax.annotation.PostConstruct;

/**
* @author Jason Song([email protected])
*/
@Component
public class SpringBootApolloRefreshConfig implements ConfigChangeListener {
private static final Logger logger = LoggerFactory.getLogger(SpringBootApolloRefreshConfig.class);

@Autowired
private ApolloRefreshConfig apolloRefreshConfig;

@Autowired
private SampleRedisConfig sampleRedisConfig;

@ApolloConfig
private Config config;

@Autowired
private RefreshScope refreshScope;

@PostConstruct
private void init() {
config.addChangeListener(this);
}

@Override
public void onChange(ConfigChangeEvent changeEvent) {
logger.info("sampleRedisConfig before refresh {}", sampleRedisConfig.toString());
refreshScope.refresh("sampleRedisConfig");
logger.info("sampleRedisConfig after refresh {}", sampleRedisConfig.toString());
}
}
6 changes: 5 additions & 1 deletion apollo-demo/src/main/resources/spring.xml
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,18 @@
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:apollo="http://www.ctrip.com/schema/apollo"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.ctrip.com/schema/apollo http://www.ctrip.com/schema/apollo.xsd">
<apollo:config order="10"/>
<apollo:config namespaces="FX.apollo" order="11"/>

<bean class="com.ctrip.framework.apollo.demo.spring.common.bean.NormalBean">
<bean name="normalBean" id="normalBean" class="com.ctrip.framework.apollo.demo.spring.common.bean.NormalBean"
scope="refresh">
<aop:scoped-proxy proxy-target-class="true"/>
<property name="batch" value="${batch:100}"/>
</bean>

Expand Down

0 comments on commit 84053f7

Please sign in to comment.