欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot整合Apollo配置中心快速使用詳解

 更新時(shí)間:2021年09月22日 11:36:40   作者:程序員小強(qiáng)  
本文主要介紹了SpringBoot整合Apollo配置中心快速使用詳解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

一、簡(jiǎn)介

1.Apollo 是什么?Apollo(阿波羅)是攜程框架部門研發(fā)的分布式配置中心。服務(wù)端基于Spring Boot和Spring Cloud開發(fā)。

2.為什么要使用Apollo?

  • 安全性:配置跟隨源代碼保存在代碼庫(kù)中,容易造成配置泄漏
  • 時(shí)效性:普通方式配置,修改配置,需要重啟服務(wù)才能生效
  • 局限性:無(wú)法支持動(dòng)態(tài)調(diào)整:例如日志開關(guān)、功能開關(guān)

二、使用

1. 測(cè)試項(xiàng)目搭建

注:本文主要介紹SpringBoot 整合 Apollo 實(shí)現(xiàn)動(dòng)態(tài)配置

1.1 添加Maven依賴

<dependency>
  <groupId>com.ctrip.framework.apollo</groupId>
  <artifactId>apollo-client</artifactId>
  <version>1.3.0</version>
</dependency>

1.2 配置文件

# apollo集成
# apollo 配置應(yīng)用的 appid
app.id=springboot-apollo-demo1
# apollo meta-server地址,一般同config-server地址
apollo.meta=http://192.168.0.153:8080
#啟用apollo配置開關(guān)
apollo.bootstrap.enabled=true
apollo.bootstrap.eagerLoad.enabled=true
# apollo 使用配置的命名空間,多個(gè)以逗號(hào)分隔
apollo.bootstrap.namespaces = application

配置說(shuō)明:

  • app.id:在配置中心配置的應(yīng)用身份信息。
  • apollo.bootstrap.enabled:在應(yīng)用啟動(dòng)階段是否向Spring容器注入被托管的properties文件配置信息。
  • apollo.bootstrap.eagerLoad.enabled:將Apollo配置加載提到初始化日志系統(tǒng)之前。
  • apollo.bootstrap.namespaces:配置的命名空間,多個(gè)逗號(hào)分隔,一個(gè)namespace相當(dāng)于一個(gè)配置文件。
  • **apollo.meta:**當(dāng)前環(huán)境服務(wù)配置地址,生產(chǎn)環(huán)境建議至少雙節(jié)點(diǎn),可以填寫多個(gè)逗號(hào)分隔,使用一個(gè)單獨(dú)的域,如 http://config.xxx.com(由nginx等軟件負(fù)載平衡器支持),而不是多個(gè)IP地址,因?yàn)榉?wù)器可能會(huì)擴(kuò)展或縮小。

圖示說(shuō)明:

在這里插入圖片描述

1.3 添加啟動(dòng)類

@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class, DataSourceTransactionManagerAutoConfiguration.class})
public class SpringbootApolloApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringbootApolloApplication.class, args);
    }
}

1.4 添加配置開關(guān)類

基于@Value注解配置

@Component
public class ValueStyleProperty {

    @Value("${apollo.value.demoKey1}")
    private String demoKey1;


    @Value("${apollo.value.demoKey2}")
    private String demoKey2;
    //省略 get/set 方法
}

1.5 添加測(cè)試controller

/**
 * value注解方式,獲取屬性
 *
 * @author mengqiang
 */
@RestController
@RequestMapping("/value-style")
public class ValuePropertyController {

    @Autowired
    private ValueStyleProperty keyProperty;

    @Value("${server.port}")
    private String port;

    @Value("${apollo.bootstrap.namespaces:'application'}")
    private String namespaces;

    @GetMapping("/get")
    public Map<String, Object> getProperty() {
        Map<String, Object> map = new LinkedHashMap<>();
        map.put("port", port);
        map.put("namespaces", namespaces);
        map.put("demoKey1", keyProperty.getDemoKey1());
        map.put("demoKey2", keyProperty.getDemoKey2());
        return map;
    }
}

2. Apollo配置中心的配置

2.1 創(chuàng)建項(xiàng)目

在這里插入圖片描述

2.2 填寫配置信息

在這里插入圖片描述

配置說(shuō)明:

  • 部門:選擇應(yīng)用所在的部門。(可自定義部門)
  • 應(yīng)用AppId:用來(lái)標(biāo)識(shí)應(yīng)用身份的唯一id,格式為string,需與application.properties中配置的app.id一致。
  • 應(yīng)用名稱:應(yīng)用名,僅用于界面展示。
  • 應(yīng)用負(fù)責(zé)人:選擇的人默認(rèn)會(huì)成為該項(xiàng)目的管理員,具備項(xiàng)目權(quán)限管理、集群創(chuàng)建、Namespace創(chuàng)建等權(quán)限。

項(xiàng)目配置主頁(yè)截圖

在這里插入圖片描述

2.3 添加配置

2.3.1 表格形式單個(gè)添加

注:不能批量操作

在這里插入圖片描述

在這里插入圖片描述

2.3.2 文本形式批量添加

注:可實(shí)現(xiàn)批量操作

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

2.4 發(fā)布配置

注:配置只有發(fā)布后才會(huì)生效

在這里插入圖片描述

點(diǎn)擊發(fā)布按鈕

在這里插入圖片描述

2.5 多環(huán)境同步配置

注意事項(xiàng):

通過(guò)同步配置功能,可以使多個(gè)環(huán)境、集群間的配置保持一致需要注意的是,同步完之后需要發(fā)布后才會(huì)對(duì)應(yīng)用生效

點(diǎn)擊同步配置

在這里插入圖片描述

選擇需要同步的配置,以及目標(biāo)環(huán)境

在這里插入圖片描述

點(diǎn)擊同步

在這里插入圖片描述

目標(biāo)環(huán)境查看

在這里插入圖片描述

3. 項(xiàng)目啟動(dòng)與測(cè)試

3.1 初始啟動(dòng)讀取測(cè)試

在這里插入圖片描述

3.2 自動(dòng)更新屬性測(cè)試

在這里插入圖片描述

發(fā)布后控制臺(tái)變化

在這里插入圖片描述

測(cè)試輸出值變化

在這里插入圖片描述

4.常見(jiàn)整合問(wèn)題

4.1@ConfigurationProperties注解整合Apollo不生效問(wèn)題

示例配置類

/**
 * 公共開關(guān),key值 屬性配置
 *
 * @author mengqiang
 */
@Component
@ConfigurationProperties(prefix = "apollo.first.config")
public class ConfigFirstProperty {

    /**
     * 測(cè)試數(shù)字
     */
    private Integer oneNumber;

    /**
     * 測(cè)試字符串
     */
    private String oneStr;

    /**
     * 啟用標(biāo)記
     */
    private Boolean oneEnableFlag;

    /**
     * 稅率 默認(rèn) 0.03
     */
    private BigDecimal oneTaxRate = new BigDecimal("0.03");
   //省略 get/set 方法

}

解決方案
添加監(jiān)聽配置

import com.ctrip.framework.apollo.model.ConfigChange;
import com.ctrip.framework.apollo.model.ConfigChangeEvent;
import com.ctrip.framework.apollo.spring.annotation.ApolloConfigChangeListener;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;
import org.springframework.cloud.context.environment.EnvironmentChangeEvent;

/**
 * Apollo 配置監(jiān)聽
 */
@Configuration
public class ApolloConfigListener implements ApplicationContextAware {

    /**
     * 日志
     */
    private static final Logger LOGGER = LoggerFactory.getLogger(ApolloConfigListener.class);

    private ApplicationContext applicationContext;

   /**
     * 配置監(jiān)聽
     * ApolloConfigChangeListener > value 屬性默認(rèn) 命名空間 "application"
     *
     * 示例: @ApolloConfigChangeListener(value = {"application", "test_space"})
     */
    @ApolloConfigChangeListener
    private void onChange(ConfigChangeEvent changeEvent) {
        LOGGER.info("【Apollo-config-change】start");
        for (String key : changeEvent.changedKeys()) {
            ConfigChange change = changeEvent.getChange(key);
            LOGGER.info("key={} , propertyName={} , oldValue={} , newValue={} ", key, change.getPropertyName(), change.getOldValue(), change.getNewValue());
        }
        // 更新相應(yīng)的bean的屬性值,主要是存在@ConfigurationProperties注解的bean
        this.applicationContext.publishEvent(new EnvironmentChangeEvent(changeEvent.changedKeys()));

        LOGGER.info("【Apollo-config-change】end");
    }

    @Override
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        this.applicationContext = applicationContext;
    }
}

4.2日志級(jí)別未更新問(wèn)題

示例配置

logging.level.com.example=info

解決方案-日志監(jiān)聽器

import com.ctrip.framework.apollo.model.ConfigChange;
import com.ctrip.framework.apollo.model.ConfigChangeEvent;
import com.ctrip.framework.apollo.spring.annotation.ApolloConfigChangeListener;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.logging.LogLevel;
import org.springframework.boot.logging.LoggingSystem;
import org.springframework.context.annotation.Configuration;
import javax.annotation.Resource;

/**
 * Apollo 日志-配置監(jiān)聽
 */
@Configuration
public class LoggerConfigListener {

    private static final Logger LOGGER = LoggerFactory.getLogger(LoggerConfigListener.class);
    private static final String LOGGER_TAG = "logging.level.";

    @Resource
    private LoggingSystem loggingSystem;

    /**
     * 監(jiān)聽 日志配置的變化
     */
    @ApolloConfigChangeListener(interestedKeyPrefixes = LOGGER_TAG)
    private void onChangeLogger(ConfigChangeEvent changeEvent) {
        LOGGER.info("【Apollo-logger-config-change】>> start");
        refreshLoggingLevel(changeEvent);
        LOGGER.info("【Apollo-logger-config-change】>> end");
    }

    /**
     * 刷新日志級(jí)別
     */
    private void refreshLoggingLevel(ConfigChangeEvent changeEvent) {
        if (null == loggingSystem) {
            return;
        }
        for (String key : changeEvent.changedKeys()) {
            ConfigChange change = changeEvent.getChange(key);
            if (!StringUtils.containsIgnoreCase(key, LOGGER_TAG)) {
                continue;
            }
            LOGGER.info("【Apollo-logger-config-change】>> key={} , propertyName={} , oldValue={} , newValue={} ",
                    key, change.getPropertyName(), change.getOldValue(), change.getNewValue());
            String newLevel = change.getNewValue();
            LogLevel level = LogLevel.valueOf(newLevel.toUpperCase());
            loggingSystem.setLogLevel(key.replace(LOGGER_TAG, ""), level);
            LOGGER.info("【Apollo-logger-config-change】>> {} -> {}", key, newLevel);
        }
    }
}

4.3日志+配置類自動(dòng)刷新整合監(jiān)聽

注:由于 4.1與4.2監(jiān)聽有重合,所以最好放在一起處理

import com.ctrip.framework.apollo.model.ConfigChange;
import com.ctrip.framework.apollo.model.ConfigChangeEvent;
import com.ctrip.framework.apollo.spring.annotation.ApolloConfigChangeListener;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.BeansException;
import org.springframework.boot.logging.LogLevel;
import org.springframework.boot.logging.LoggingSystem;
import org.springframework.cloud.context.environment.EnvironmentChangeEvent;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.context.annotation.Configuration;
import javax.annotation.Resource;

/**
 * Apollo 配置監(jiān)聽
 */
@Configuration
public class ApolloConfigListener implements ApplicationContextAware {
    /**
     * 日志
     */
    private static final Logger LOGGER = LoggerFactory.getLogger(ApolloConfigListener.class);
    /**
     * 日志配置常量
     */
    private static final String LOGGER_TAG = "logging.level.";

    @Resource
    private LoggingSystem loggingSystem;

    private ApplicationContext applicationContext;

    @Override
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        this.applicationContext = applicationContext;
    }


    /**
     * 配置監(jiān)聽
     * ApolloConfigChangeListener > value 屬性默認(rèn) 命名空間 "application"
     */
    @ApolloConfigChangeListener
    private void onChangeConfig(ConfigChangeEvent changeEvent) {
        LOGGER.info("【Apollo-config-change】>> start");
        for (String key : changeEvent.changedKeys()) {
            ConfigChange change = changeEvent.getChange(key);
            LOGGER.info("【Apollo-config-change】>> key={} , propertyName={} , oldValue={} , newValue={} ",
                    key, change.getPropertyName(), change.getOldValue(), change.getNewValue());
            //是否為日志配置
            if (StringUtils.containsIgnoreCase(key, LOGGER_TAG)) {
                //日志配置刷新
                changeLoggingLevel(key, change);
                continue;
            }
            // 更新相應(yīng)的bean的屬性值,主要是存在@ConfigurationProperties注解的bean
            this.applicationContext.publishEvent(new EnvironmentChangeEvent(changeEvent.changedKeys()));
        }
        LOGGER.info("【Apollo-config-change】>> end");
    }

    /**
     * 刷新日志級(jí)別
     */
    private void changeLoggingLevel(String key, ConfigChange change) {
        if (null == loggingSystem) {
            return;
        }
        String newLevel = change.getNewValue();
        LogLevel level = LogLevel.valueOf(newLevel.toUpperCase());
        loggingSystem.setLogLevel(key.replace(LOGGER_TAG, ""), level);
        LOGGER.info("【Apollo-logger-config-change】>> {} -> {}", key, newLevel);
    }
}

4.4 其它問(wèn)題

4.4.1配置文件與配置中心同時(shí)存在配置,啟用的是那一份
apollo 配置開關(guān)開啟情況下,配置中心配置會(huì)覆蓋本地配置
注:配置開關(guān) apollo.bootstrap.enabled=true

4.4.2 配置中心掛掉會(huì)影響已發(fā)布的項(xiàng)目嗎?
項(xiàng)目啟動(dòng)后配置會(huì)存在緩存中,配置中心掛掉,已發(fā)布的項(xiàng)目不影響

4.4.3 是否支持更新端口配置
支持更新端口配置,但是必需要重啟生效,同時(shí)也需要考慮服務(wù)器的端口占用問(wèn)題。

附錄

Apollo官方文檔相關(guān)

官方源碼地址:https://github.com/ctripcorp/apollo
官方演示環(huán)境(Demo):

106.54.227.205
賬號(hào)/密碼:apollo/admin

快速搭建本地測(cè)試環(huán)境
分布式部署指南(生產(chǎn)環(huán)境建議使用)

到此這篇關(guān)于SpringBoot整合Apollo配置中心快速使用詳解的文章就介紹到這了,更多相關(guān)SpringBoot整合Apollo配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java設(shè)計(jì)優(yōu)化之代理模式

    java設(shè)計(jì)優(yōu)化之代理模式

    這篇文章主要為大家詳細(xì)介紹了java設(shè)計(jì)優(yōu)化中的代理模式,感興趣的朋友可以參考一下
    2016-03-03
  • 解決swaggerUI頁(yè)面沒(méi)有顯示Controller方法的坑

    解決swaggerUI頁(yè)面沒(méi)有顯示Controller方法的坑

    這篇文章主要介紹了解決swaggerUI頁(yè)面沒(méi)有顯示Controller方法的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • SpringBoot接口或方法進(jìn)行失敗重試的實(shí)現(xiàn)方式

    SpringBoot接口或方法進(jìn)行失敗重試的實(shí)現(xiàn)方式

    為了防止網(wǎng)絡(luò)抖動(dòng),影響我們核心接口或方法的成功率,通常我們會(huì)對(duì)核心方法進(jìn)行失敗重試,如果我們自己通過(guò)for循環(huán)實(shí)現(xiàn),會(huì)使代碼顯得比較臃腫,所以本文給大家介紹了SpringBoot接口或方法進(jìn)行失敗重試的實(shí)現(xiàn)方式,需要的朋友可以參考下
    2024-07-07
  • Servlet虛擬路徑映射配置詳解

    Servlet虛擬路徑映射配置詳解

    這篇文章主要介紹了Servlet虛擬路徑映射配置詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • Java多線程 兩階段終止模式Two-Phase Termination Patter

    Java多線程 兩階段終止模式Two-Phase Termination Patter

    這篇文章主要介紹了Java多線程 兩階段終止模式Two-Phase Termination Patter,該模式有兩個(gè)角色,分別是Terminator,終止者,負(fù)責(zé)接收終止請(qǐng)求,執(zhí)行終止處理,處理完成后再終止自己。TerminationRequester終止請(qǐng)求發(fā)出者,用來(lái)向Terminator發(fā)出終止請(qǐng)求,需要的朋友可以參考一下
    2021-10-10
  • Spring boot 無(wú)法注入service問(wèn)題

    Spring boot 無(wú)法注入service問(wèn)題

    這篇文章主要介紹了Spring boot 無(wú)法注入service問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Java裝飾者模式的深入了解

    Java裝飾者模式的深入了解

    這篇文章主要為大家介紹了Java裝飾者模式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-01-01
  • Java快速實(shí)現(xiàn)圖書管理基本功能

    Java快速實(shí)現(xiàn)圖書管理基本功能

    隨著網(wǎng)絡(luò)技術(shù)的高速發(fā)展,計(jì)算機(jī)應(yīng)用的普及,利用計(jì)算機(jī)對(duì)圖書館的日常工作進(jìn)行管理勢(shì)在必行,本篇文章涵蓋一個(gè)圖書管理系統(tǒng)的基本功能實(shí)現(xiàn)代碼,大家可以查缺補(bǔ)漏,提升水平
    2022-05-05
  • 聊聊Java 成員變量賦值和構(gòu)造方法誰(shuí)先執(zhí)行的問(wèn)題

    聊聊Java 成員變量賦值和構(gòu)造方法誰(shuí)先執(zhí)行的問(wèn)題

    這篇文章主要介紹了聊聊Java 成員變量賦值和構(gòu)造方法誰(shuí)先執(zhí)行的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-10-10
  • Java線程中的ThreadLocal類解讀

    Java線程中的ThreadLocal類解讀

    這篇文章主要介紹了Java線程中的ThreadLocal類解讀,ThreadLocal是一個(gè)泛型類,作用是實(shí)現(xiàn)線程隔離,ThreadLocal類型的變量,在每個(gè)線程中都會(huì)對(duì)應(yīng)一個(gè)具體對(duì)象,對(duì)象類型需要在聲明ThreadLocal變量時(shí)指定,需要的朋友可以參考下
    2023-11-11

最新評(píng)論