Spring Cloud
Spring Cloud是一系列框架的有序集合。它利用Spring Boot的開發(fā)便利性巧妙地簡化了分布式系統(tǒng)基礎(chǔ)設(shè)施的開發(fā)雇初,如服務(wù)發(fā)現(xiàn)注冊饮怯、配置中心烦租、消息總線、負(fù)載均衡综液、斷路器、數(shù)據(jù)監(jiān)控等儒飒,都可以用Spring Boot的開發(fā)風(fēng)格做到一鍵啟動(dòng)和部署谬莹。
Spring Cloud就是這些微服務(wù)的大管家,自然需要很多小弟來幫忙桩了。主要的小弟有:Spring Cloud Config附帽、Spring Cloud Netflix(Eureka、Hystrix井誉、Zuul蕉扮、Archaius…)、Spring Cloud Bus送悔、Spring Cloud for Cloud Foundry慢显、Spring Cloud Cluster、Spring Cloud Consul欠啤、Spring Cloud Security荚藻、Spring Cloud Sleuth、Spring Cloud Data Flow洁段、Spring Cloud Stream应狱、Spring Cloud Task、Spring Cloud Zookeeper祠丝、Spring Cloud Connectors疾呻、Spring Cloud Starters除嘹、Spring Cloud CLI.
和Spring boot 是什么關(guān)系
Spring boot 是 Spring 的一套快速配置腳手架,可以基于spring boot 快速開發(fā)單個(gè)微服務(wù)岸蜗,Spring Cloud是一個(gè)基于Spring Boot實(shí)現(xiàn)的云應(yīng)用開發(fā)工具尉咕;
spring -> spring booot > spring cloud 這樣的關(guān)系。
Spring Cloud Config
俗稱的配置中心璃岳,配置管理工具包年缎,讓你可以把配置放到遠(yuǎn)程服務(wù)器,集中化管理集群配置铃慷,目前支持本地存儲单芜、Git以及Subversion。就是以后大家武器犁柜、槍火什么的東西都集中放到一起洲鸠,別隨便自己帶,方便以后統(tǒng)一管理馋缅、升級裝備扒腕。
手腳架
git@git.oschina.net:2449149803/spring-cloud-netflix-example.git
SpringCloudConfig提供基于以下3個(gè)維度的配置管理:
- 應(yīng)用
這個(gè)比較好理解,每個(gè)配置都是屬于某一個(gè)應(yīng)用的
- 環(huán)境
每個(gè)配置都是區(qū)分環(huán)境的萤悴,如dev, test, prod等
- 版本
這個(gè)可能是一般的配置中心所缺乏的袜匿,就是對同一份配置的不同版本管理
Spring Cloud Config提供版本的支持,也就是說對于一個(gè)應(yīng)用的不同部署實(shí)例稚疹,可以從服務(wù)端獲取到不同版本的配置居灯,這對于一些特殊場景如:灰度發(fā)布,A/B測試等提供了很好的支持内狗。
- application:應(yīng)用名
- profile:環(huán)境
- label:版本
{application}/{profile}[/{label}]
{application}-{profile}.yml
{label}/{application}-{profile}.yml
{application}-{profile}.properties
{label}/{application}-{profile}.properties
springBoot 快速構(gòu)建 config server
@SpringBootApplication
@EnableConfigServer
public class ConfigServerApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigServerApplication.class, args);
}
}
yml 配置
spring:
profiles:
active: native
application:
name: config-server
rabbitmq:
host: localhost
cloud:
config:
server:
native:
search-locations: classpath:/
git:
uri: https://git.oschina.net/2449149803/gittest.git
- RSA 驗(yàn)證
spring:
cloud:
config:
server:
git:
uri: git@gitserver.com:team/repo1.git
ignoreLocalSshSettings: true
hostKey: someHostKey
hostKeyAlgorithm: ssh-rsa
privateKey: |
-----BEGIN RSA PRIVATE KEY-----
MIIEpgIBAAKCAQEAx4UbaDzY5xjW6hc9jwN0mX33XpTDVW9WqHp5AKaRbtAC3DqX
-----END RSA PRIVATE KEY-----
SpringCloudConfig Client
spring.cloud.config.uri=http://127.0.0.1:${config.port:8888}
spring.cloud.config.name=alan-provider-data-config
spring.cloud.config.profile=${config.profile:dev}
1.特別注意 配置中心的地址一定要放在bootstrap.properties中怪嫌,這個(gè)配置文件是由“根”上下文優(yōu)先加載,可以保證程序啟動(dòng)之初就感知到遠(yuǎn)程配置中心的存在柳沙,并從遠(yuǎn)程獲取配置岩灭,隨后繼續(xù)啟動(dòng)系統(tǒng),這點(diǎn)十分重要赂鲤。
2.而application.properties是由子上下文加載噪径,加載順序低于前者,如果配置中心地址放在這里数初,并且你遠(yuǎn)程配置了一些啟動(dòng)相關(guān)的必要參數(shù)找爱,那么,你的程序很可能由于缺少參數(shù)而啟動(dòng)失敗泡孩。
3.下面這段代碼车摄,最關(guān)鍵的是第一行,第二行如果不配置系統(tǒng)默認(rèn)讀取spring.application.name,第三行如果不配置吮播,系統(tǒng)默認(rèn)default变屁,即:${spring.application.name}.properties
4.我們一般的做法是,在系統(tǒng)啟動(dòng)的時(shí)候意狠,用命令行傳入--spring.cloud.config.profile=dev|prod|test的方式粟关,因?yàn)樵趩?dòng)的時(shí)候,我們是明確知道我要獲取哪套配置的
引用配置的類要加@RefreshScope注解
@RefreshScope
@RestController
@Api
public class AServiceController {
@Value("${name:unknown}")
private String name;
@Autowired
private HystrixWrappedServiceBClient serviceBClient;
@Autowired
DiscoveryClient discoveryClient;
@RequestMapping(value = "/", method = RequestMethod.GET)
public String printServiceA() {
//ServiceInstance serviceInstance = discoveryClient.getLocalServiceInstance();
//return serviceInstance.getServiceId() + " (" + serviceInstance.getHost() + ":" + serviceInstance.getPort() + ")" + "===>name:" + name + "<br/>" + serviceBClient.printServiceB();
return "name = " + name;
}
}
RefreshScope 注解
我們知道Spring原生提供了一些scope环戈,如singleton誊役,prototype,request等谷市。 為了實(shí)現(xiàn)配置更新后,已經(jīng)注入bean的值也能更新的目的击孩,Spring Cloud提供了一個(gè)新的scope - RefreshScope迫悠。
所以,對于那些有注入值的bean巩梢,我們可以把它們標(biāo)記為RefreshScope创泄,這樣當(dāng)運(yùn)行時(shí)發(fā)現(xiàn)有配置更新的時(shí)候,通過調(diào)用RefreshScope.refresh(beanName)或RefreshScope.refreshAll()括蝠,從而下次這些bean被使用時(shí)會被重新初始化鞠抑,進(jìn)而會被重新注入值,所以也就達(dá)到了更新的目的忌警。