猿问
下载APP

spring cloud 本地配置怎么自动部署?

spring cloud 本地配置怎么自动部署


萧十郎
浏览 181回答 1
1回答

扬帆大鱼

Spring Cloud 习笔记()——入门、特征、配置0 放前面0.1 参考文档0.2 maven配置org.springframework.bootspring-boot-starter-parent1.5.2.RELEASEorg.springframework.cloudspring-cloud-dependenciesDalston.RELEASEpomimportorg.springframework.cloudspring-cloud-starter-configorg.springframework.cloudspring-cloud-starter-eureka0.3 简介Spring Cloud发员提供快速构建布式系统些通用模式(例配置管理服务发现断路器智能路由微代理控制总线性令牌全局锁领导选举布式 群集状态) 布式系统协调引板模式(boiler plate patterns)并且使用Spring Cloud发员快速实现些模式启服务应用程序 任何布式环境工作包括发员自笔记本电脑裸机数据受管平台Cloud FoundryVersion: Brixton.SR71 特征Spring Cloud专注于经典用例扩展机制提供良箱即用布式/版本配置服务注册与发现路由选择服务调用负载均衡熔断机制全局锁领导选举集群状态布式消息2 原云应用程序原云应用程序发种风格鼓励持续交付价值驱领域佳实践Spring Cloud特性基于Spring Boot更由两库实现:Spring Cloud Context and Spring Cloud Commons2.1 Spring Cloud Context: 应用文服务Spring Boot关于使用Spring构建应用硬性规定:通用配置文件固定位置通用管理终端监控任务建立基础Spring Cloud增加些额外特性2.1.1 引导应用程序文Spring Cloud创建bootstrap文主应用程序父文应配置文件拥高优先级并且默认能本配置文件覆盖应文件名bootstrap.yml或bootstrap.properties通设置spring.cloud.bootstrap.enabled=false禁止bootstrap进程2.1.2 应用文层级结构用SpringApplication或SpringApplicationBuilder创建应用程序文bootstrap文作父文添加进文继承父文属性文配置信息覆盖父文配置信息2.1.3 修改Bootstrap配置文件位置spring.cloud.bootstrap.name(默认bootstrap)或者spring.cloud.bootstrap.location(默认空)2.1.4 覆盖远程配置文件值spring.cloud.config.allowOverride=truespring.cloud.config.overrideNone=truespring.cloud.config.overrideSystemProperties=false2.1.5 定制Bootstrap配置/META-INF/spring.factorieskeyorg.springframework.cloud.bootstrap.BootstrapConfiguration定义Bootstrap启组件主应用程序启前始Bootstrap文创建spring.factories文件组件@Beans类型bean2.1.6 定制Bootstrap属性源关键点:spring.factories、PropertySourceLocator2.1.7 环境改变应用程序通EnvironmentChangedEvent监听应用程序并做响应2.1.8 Refresh ScopeSpringbean@RefreshScope做特殊处理用于刷新bean配置信息注意需要添加依赖org.springframework.boot.spring-boot-starter-actuator目前我@Controller测试功需要自发送POST请求/refresh修改配置文件即2.1.9 加密解密Spring Cloud配置文件值进行加密"Illegal key size"异需要安装JCE2.1.10 服务点除Spring Boot提供服务点Spring Cloud提供些服务点用于管理注意都POST请求/env:更新Environment、重新绑定@ConfigurationProperties跟志级别/refresh重新加载配置文件刷新标记@RefreshScopebean/restart重启应用默认用命周期:/pause、/resume2.2 Spring Cloud Commons:通用抽象服务发现、负载均衡、熔断机制种模式Spring Cloud客户端提供通用抽象层2.2.1 RestTemplate作负载均衡客户端通@Bean跟@LoadBalanced指定RestTemplate注意URI需要使用虚拟域名(服务名能用域名):@Configurationpublic class MyConfiguration {@LoadBalanced@BeanRestTemplate restTemplate() {return new RestTemplate();}}public class MyClass {@Autowiredprivate RestTemplate restTemplate;public String doOtherStuff() {String results = restTemplate.getForObject("", String.class);return results;}}2.2.2 RestTemplate象注意@Primary注解使用@Configurationpublic class MyConfiguration {@LoadBalanced@BeanRestTemplate loadBalanced() {return new RestTemplate();}@Primary@BeanRestTemplate restTemplate() {return new RestTemplate();}}public class MyClass {@Autowiredprivate RestTemplate restTemplate;@Autowired@LoadBalancedprivate RestTemplate loadBalanced;public String doOtherStuff() {return loadBalanced.getForObject("", String.class);}public String doStuff() {return restTemplate.getForObject("", String.class);}}2.2.3 忽略网络接口忽略确定名字服务发现注册支持则表达式配置3 Spring Cloud ConfigSpring Cloud Config提供服务端客户端布式系统扩展配置支持同环境配置(发、测试、产)使用Git做默认配置端支持配置环境打版本标签3.1 快速始通IDE运行或maven运行默认加载property资源策略克隆git仓库(at spring.cloud.config.server.git.uri')HTTP服务资源构:/{application}/{profile}[/{label}]/{application}-{profile}.yml/{label}/{application}-{profile}.yml/{application}-{profile}.properties/{label}/{application}-{profile}.propertiesapplicationSpringApplicationspring.config.name,(般说'application'规Spring Boot应用),profileactiveprofile(或者逗号隔属性列表),label选git标签(默认"master")3.1.1 客户端示例创建Spring Boot应用即添加依赖org.springframework.cloud:spring-cloud-starter-config配置application.properties注意URL配置服务端址spring.cloud.config.uri:3.2 Spring Cloud Config 服务端针系统外配置项(name-value或相同功能YAML内容),该服务器提供基于资源HTTP接口使用@EnableConfigServer注解,该服务器容易嵌入Spring Boot 系统使用该注解该应用系统配置服务器@SpringBootApplication@EnableConfigServerpublic class ConfigApplicion {public static void main(String[] args) throws Exception {SpringApplication.run(ConfigApplicion.class, args);}}3.2.1 资源库环境{application} 应客户端"spring.application.name"属性{profile} 应客户端 "spring.profiles.active"属性(逗号隔列表){label} 应服务端属性,属性能标示组配置文件版本配置库基于文件服务器application.ymlfoo.yml创建Environment象高优先级配置优先转Environment象PropertySource3.2.1.1 Git端默认EnvironmentRepository用Git端进行实现Git端于管理升级物理环境便,审计配置变更便file:前缀本配置库读取数据配置库实现通映射HTTP资源{label}参数作git label(提交id,支名称或tag)git支或tag名称包含斜杠 ("/"),HTTP URLlabel需要使用特殊字符串"(_)"替代(避免与其URL路径相互混淆)使用命令行客户端 curl请谨慎处理URL括号(例:shell请使用引号''转义)Git URI占位符Spring Cloud Config Server支持git库URL包含针{application} {profile}占位符(需要,{label}包含占位符, 要牢记任何情况label指gitlabel)所容易支持应用系统配置库策略或profile配置库策略模式匹配资源库spring:cloud:config:server:git:uri:repos:simple:special:pattern: special*/dev*,*special*/dev*uri:local:pattern: local*uri: file:/home/configsvc/config-repo{application}/{profile}能匹配任何表达式使用spring.cloud.config.server.git.uri应值例于 "simple" 配置库, 匹配模式simple/* (说,论profile匹配application名称simple应用系统)local库匹配所application名称local任何应用系统管profiles(实现覆盖没配置profile匹配规则/*缀自增加任何匹配表达式)Git搜索路径占位符spring.cloud.config.server.git.searchPaths3.2.1.2 版本控制端文件系统使用伴随着版本控制系统作端(git、svn)文件都check out或clone 本文件系统默认些文件放置config-repo-前缀系统临目录Linux譬应该/tmp/config-repo-目录些操作系统routinely clean out放临目录导致预知问题现避免问题通设置spring.cloud.config.server.git.basedir或spring.cloud.config.server.svn.basedir参数值非系统临目录3.2.1.3 文件系统端使用本加载配置文件需要配置:spring.cloud.config.server.native.searchLocations跟spring.profiles.active=native路径配置格式:classpath:/, classpath:/config,file:./, file:./config3.2.1.4 共享配置给所应用基于文件资源库基于文件资源库(i.e. git, svn and native)文件名application*命名资源所客户端都共享( application.properties, application.yml, application-*.properties,etc.)属性覆盖spring.cloud.config.server.overrides添加Map类型name-value实现覆盖例spring:cloud:config:server:overrides:foo: bar使所配置客户端应用程序读取foo=bar自配置参数3.2.2 健康指示器通指示器能够检查已经配置EnvironmentRepository否运行通设置spring.cloud.config.server.health.enabled=false参数禁用健康指示器3.2.3 安全自由选择任何觉合理式保护Config Server(物理网络安全OAuth2 令牌)同使用Spring SecuritySpring Boot 能使做更其用事情使用默认Spring Boot HTTP Basic 安全需要Spring Security 增加classpath(org.springframework.boot.spring-boot-starter-security)默认用户名user应随机密码种情况实际使用并没意义般建议配置密码(通 security.user.password属性进行配置)并密码进行加密3.2.4 加密与解密远程属性包含加密内容({cipher}),些值通HTTP传递客户端前解密使用略3.2.5 密钥管理配置服务使用称(共享)密钥或者非称密钥(RSA密钥)使用略3.2.6 创建测试密钥库3.2.7 使用密钥循环密钥3.2.8 加密属性服务3.3 替换格式服务配置文件加缀".yml"、".yaml"、".properties"3.4 文本解释服务/{name}/{profile}/{label}/{path}3.5 嵌入配置服务器般配置服务运行单独应用面要使用注解@EnableConfigServer即嵌入其应用3.6 推送通知总线添加依赖spring-cloud-config-monitor激Spring Cloud 总线/monitor端点即用webhook激针应用程序能已经变化配置服务端发送RefreshRemoteApplicationEvent3.7 客户端配置3.7.1 配置第引导通spring.cloud.config.uri属性配置Config Server址3.7.2 发现第引导用Netflix则用eureka.client.serviceUrl.defaultZone进行配置3.7.3 配置客户端快速失败些例面能希望没连接配置服务端直接启失败通spring.cloud.config.failFast=true进行配置3.7.4 配置客户端重试添加依赖spring-retry、spring-boot-starter-aop设置spring.cloud.config.failFast=true默认6重试初始补偿间隔1000ms续补偿1.1指数乘数通spring.cloud.config.retry.*配置进行修改3.7.5 定位远程配置资源路径:/{name}/{profile}/{label}"name" = ${spring.application.name}"profile" = ${spring.profiles.active} (actually Environment.getActiveProfiles())"label" = "master"label于滚前版本用3.7.6 安全通spring.cloud.config.password、spring.cloud.config.username进行配置
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Spring Cloud
我要回答