前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringCloud入门系列之配置中心

SpringCloud入门系列之配置中心

作者头像
AI码真香
发布2022-09-13 15:16:57
4770
发布2022-09-13 15:16:57
举报
文章被收录于专栏:AI码真香
Spring Cloud配置中心

目前市场配置中心产品有:

  • Spring Cloud Config
  • 携程 Apollo
  • 阿里巴巴 Nacos

本文主要使用Spring Cloud Config

一、配置中心使用步骤
1.1、pom.xml添加依赖
代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.15.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.codesofun</groupId>
    <artifactId>config-server</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>config-server</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>Greenwich.SR6</spring-cloud.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-config-server</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>
1.2、修改配置

微服务客户端,需要删除原来配置文件application.propertiesapplication.yml。使用bootstrap.propertiesbootstrap.yml 文件进行配置,具体如下:

代码语言:javascript
复制
#环境 book-service-dev.properties
spring.cloud.config.profile=dev
#git 库配置分支
spring.cloud.config.label=master
#配置中心地址
spring.cloud.config.uri=http://localhost:5000
#微服务名称
spring.cloud.config.name=book-service
1.3、配置中心配置
  1. 启动类中添加配置
代码语言:javascript
复制
package com.codesofun.config.server;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;

@SpringBootApplication
//@EnableDiscoveryClient
@EnableEurekaClient
@EnableConfigServer
public class ConfigServerApplication {

    public static void main(String[] args) {
        SpringApplication.run(ConfigServerApplication.class, args);
    }
}

  1. 添加配置
代码语言:javascript
复制
server.port=5000
spring.application.name=config-server
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
#配置代理
spring.cloud.config.server.git.proxy.https.host=
spring.cloud.config.server.git.proxy.https.port=
spring.cloud.config.server.git.proxy.https.username=xxxxx
spring.cloud.config.server.git.proxy.https.password=xxxxxxx
#git uri
spring.cloud.config.server.git.uri=https://gitee.com/xmlvhy/sc-config.git
#连接超时时间
spring.cloud.config.server.git.timeout=6000
spring.cloud.config.server.git.basedir=E:/sc_config/git-pro

#私有仓库用户名
spring.cloud.config.server.git.username=xxx
##私有仓库用户密码
spring.cloud.config.server.git.password=xxxxxxxxx

  1. Spring-Retry 重试机制 Spring-Retry重试模块
代码语言:txt
复制
- 通过加入重试机制,提高应用启动的可靠性
- 重试触发条件1:配置中心无法与仓库正常通信
- 重试触发条件2:微服务无法配置中心正常通信

pom.xml中添加依赖

代码语言:javascript
复制
   <!--重试机制-->
        <dependency>
            <groupId>org.springframework.retry</groupId>
            <artifactId>spring-retry</artifactId>
            <version>1.3.0</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>

application.properties中添加配置

代码语言:javascript
复制
#是否允许快速失败,开启重试机制必须设置为true
spring.cloud.config.fail-fast=true
#初始化时间间隔(毫秒)
spring.cloud.config.retry.initial-interval=5000
#最大尝试次数
spring.cloud.config.retry.max-attempts=4
#最大时间间隔
spring.cloud.config.retry.max-interval=300000
#重试时间间隔倍数,最大不超过最大时间间隔,超过则下一次重试时间间隔为最大时间间隔
spring.cloud.config.retry.multiplier=2

  1. 运行时刷新配置参数(客户端) 修改端口的话,自动刷新无法实现,需要重启客户端服务。 pom.xml添加依赖
代码语言:javascript
复制
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

  1. 动态刷新类上增加@RefreshScope注解(客户端)
代码语言:javascript
复制
 package com.codesofun.bookservice.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @ClassName RefreshController
 * @Description
 * @Author mozhijun
 * @Date 2020/7/14 17:33
 * @Version 1.0
 **/
@RestController
@RefreshScope
public class RefreshController {
    @Value("${custom.title}")
    private String title;

    @GetMapping("/title")
    public String title(){
        return this.title;
    }
}

  1. application.properties添加配置(客户端)
代码语言:javascript
复制
management.endpoints.web.exposure.include=*

  1. 调用刷新POST http://localhost:8001/actuator/refresh
1.4、Config多仓库配置以及高可用

配置让每一个微服务拥有独立仓库。

配置中心修改配置

代码语言:javascript
复制
#git uri
spring.cloud.config.server.git.uri=https://gitee.com/xmlvhy/{application}

客户端中修改配置

代码语言:javascript
复制
#配置微服务名称
#spring.cloud.config.name=book-service
spring.application.name=book-service
#配置中心地址,配置高可用的时候不能指定具体的uri
#spring.cloud.config.uri=http://localhost:5000

详细代码见仓库:https://gitee.com/xmlvhy/springcloud-learn 参考链接:http://www.itlaoqi.com/

代码语言:txt
复制
                                 本文作者: [AI码真香](https://www.xmlvhy.com/about) 
代码语言:txt
复制
                                 本文标题:                                     [SpringCloud入门系列之配置中心](https://www.xmlvhy.com/article/detail/92.html) 
代码语言:txt
复制
                                 本文网址:                                     [https://www.xmlvhy.com/article/92.html](https://www.xmlvhy.com/article/detail/92.html) 
代码语言:txt
复制
                                 版权说明: 自由转载-非商用-非衍生-保持署名                                     [                                         署名-非商业性使用4.0 国际 (CC BY-NC 4.0)                                     ](https://creativecommons.org/licenses/by-nc/4.0/deed.zh) 

类似文章

  1. SpringCloud入门系列之微服务之间的通信
  2. SpringCloud入门系列之服务链路追踪Sleuth&Zipkin
  3. SpringCloud入门系列之Eureka注册中心
  4. SpringCloud入门系列之API网关
  5. Redis 客户端常用命令
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Spring Cloud配置中心
    • 一、配置中心使用步骤
      • 1.1、pom.xml添加依赖
      • 1.2、修改配置
      • 1.3、配置中心配置
      • 1.4、Config多仓库配置以及高可用
相关产品与服务
微服务引擎 TSE
微服务引擎(Tencent Cloud Service Engine)提供开箱即用的云上全场景微服务解决方案。支持开源增强的云原生注册配置中心(Zookeeper、Nacos 和 Apollo),北极星网格(腾讯自研并开源的 PolarisMesh)、云原生 API 网关(Kong)以及微服务应用托管的弹性微服务平台。微服务引擎完全兼容开源版本的使用方式,在功能、可用性和可运维性等多个方面进行增强。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档