激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - SpringBoot整合Apollo配置中心快速使用詳解

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

2022-01-11 13:57程序員小強 Java教程

本文主要介紹了SpringBoot整合Apollo配置中心快速使用詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下

 

一、簡介

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

2.為什么要使用Apollo?

  • 安全性:配置跟隨源代碼保存在代碼庫中,容易造成配置泄漏
  • 時效性:普通方式配置,修改配置,需要重啟服務才能生效
  • 局限性:無法支持動態調整:例如日志開關、功能開關

 

二、使用

 

1. 測試項目搭建

注:本文主要介紹SpringBoot 整合 Apollo 實現動態配置

1.1 添加Maven依賴

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

1.2 配置文件

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

配置說明:

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

圖示說明:

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

1.3 添加啟動類

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

1.4 添加配置開關類

基于@Value注解配置

@Component
public class ValueStyleProperty {

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


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

1.5 添加測試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 創建項目

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

2.2 填寫配置信息

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

配置說明:

  • 部門:選擇應用所在的部門。(可自定義部門)
  • 應用AppId:用來標識應用身份的唯一id,格式為string,需與application.properties中配置的app.id一致。
  • 應用名稱:應用名,僅用于界面展示。
  • 應用負責人:選擇的人默認會成為該項目的管理員,具備項目權限管理、集群創建、Namespace創建等權限。

項目配置主頁截圖

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

2.3 添加配置

2.3.1 表格形式單個添加

注:不能批量操作

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

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

2.3.2 文本形式批量添加

注:可實現批量操作

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

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

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

2.4 發布配置

注:配置只有發布后才會生效

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

點擊發布按鈕

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

2.5 多環境同步配置

注意事項:

通過同步配置功能,可以使多個環境、集群間的配置保持一致需要注意的是,同步完之后需要發布后才會對應用生效

點擊同步配置

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

選擇需要同步的配置,以及目標環境

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

點擊同步

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

目標環境查看

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

 

3. 項目啟動與測試

3.1 初始啟動讀取測試

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

3.2 自動更新屬性測試

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

發布后控制臺變化

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

測試輸出值變化

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

 

4.常見整合問題

4.1@ConfigurationProperties注解整合Apollo不生效問題

示例配置類

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

    /**
     * 測試數字
     */
    private Integer oneNumber;

    /**
     * 測試字符串
     */
    private String oneStr;

    /**
     * 啟用標記
     */
    private Boolean oneEnableFlag;

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

}

解決方案
添加監聽配置

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 配置監聽
 */
@Configuration
public class ApolloConfigListener implements ApplicationContextAware {

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

    private ApplicationContext applicationContext;

   /**
     * 配置監聽
     * ApolloConfigChangeListener > value 屬性默認 命名空間 "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());
        }
        // 更新相應的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日志級別未更新問題

示例配置

logging.level.com.example=info

解決方案-日志監聽器

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 日志-配置監聽
 */
@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;

    /**
     * 監聽 日志配置的變化
     */
    @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");
    }

    /**
     * 刷新日志級別
     */
    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日志+配置類自動刷新整合監聽

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

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 配置監聽
 */
@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;
    }


    /**
     * 配置監聽
     * ApolloConfigChangeListener > value 屬性默認 命名空間 "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;
            }
            // 更新相應的bean的屬性值,主要是存在@ConfigurationProperties注解的bean
            this.applicationContext.publishEvent(new EnvironmentChangeEvent(changeEvent.changedKeys()));
        }
        LOGGER.info("【Apollo-config-change】>> end");
    }

    /**
     * 刷新日志級別
     */
    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 其它問題

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

4.4.2 配置中心掛掉會影響已發布的項目嗎?
項目啟動后配置會存在緩存中,配置中心掛掉,已發布的項目不影響

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

 

附錄

Apollo官方文檔相關

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

106.54.227.205
賬號/密碼:apollo/admin

快速搭建本地測試環境
分布式部署指南(生產環境建議使用)

到此這篇關于SpringBoot整合Apollo配置中心快速使用詳解的文章就介紹到這了,更多相關SpringBoot整合Apollo配置內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://xqiangme.blog.csdn.net/article/details/90551224

延伸 · 閱讀

精彩推薦
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
主站蜘蛛池模板: 福利一区二区三区视频在线观看 | 九九黄色 | 久久蜜桃精品一区二区三区综合网 | 中文字幕在线永久 | 国产日韩在线观看一区 | 蜜桃视频在线播放 | 日韩美香港a一级毛片免费 欧美一级淫片007 | 毛片免| 精品国产一区二区三区久久久狼牙 | 得得啪在线视频 | 亚洲电影免费观看国语版 | 港台三级在线观看 | 国产毛片自拍 | chinesexxxx刘婷hd 黄色片网站在线免费观看 国产免费高清在线 | 国产三级三级三级三级 | 美女露100%无遮挡 | 亚洲精品无码不卡在线播放he | 国产xxxx免费 | 九九热免费观看 | 日本一级黄色毛片 | 黄色大片在线免费观看 | 欧美激情综合在线 | 一区二区三区视频播放 | 久久欧美亚洲另类专区91大神 | 亚洲精品在线观看免费 | 一边吃奶一边摸下娇喘 | 一级在线免费观看视频 | 中国3xxxx| 欧日韩在线视频 | 亚洲精品com | chinesexxxx刘婷hd| 国产精品成人一区二区三区电影毛片 | 亚洲成人入口 | 高清国产午夜精品久久久久久 | 亚洲精品成人18久久久久 | 一区二区三区日本在线观看 | 欧美性猛交xxx乱大交3蜜桃 | 最新中文字幕在线视频 | 国产午夜免费福利 | 日本精品久久久一区二区三区 | 黄色网址免费播放 |