一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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

服務器之家 - 編程語言 - Java教程 - springboot logback如何從apollo配置中心讀取變量

springboot logback如何從apollo配置中心讀取變量

2021-12-09 13:04LMD菜鳥先飛 Java教程

這篇文章主要介紹了springboot logback如何從apollo配置中心讀取變量的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

 

springboot logback 從apollo配置中心讀取變量

 

1、在apollo配置中心添加

logback-config.properties配置文件

springboot logback如何從apollo配置中心讀取變量

 

2、項目的application.yml配置文件配置如下

主要是eagerLoad.enabled: true這個配置

app:
  id: SX-sale-app-soa
apollo:
  bootstrap:
    enabled: true
    #將Apollo配置加載提到初始化日志系統之前
    eagerLoad:
      enabled: true
    namespaces: application.yml,logback-config

 

3、在logback.xml配置springProperty標簽

設置好標簽名稱和配置中心變量名稱的,使用的時候${name}引入該變量

<?xml version="1.0" encoding="UTF-8"?>
<!-- 日志級別從低到高分為TRACE < DEBUG < INFO < WARN < ERROR < FATAL,如果設置為WARN,則低于WARN的信息都不會輸出 -->
<!-- scan:當此屬性設置為true時,配置文件如果發生改變,將會被重新加載,默認值為true -->
<!-- scanPeriod:設置監測配置文件是否有修改的時間間隔,如果沒有給出時間單位,默認單位是毫秒。當scan為true時,此屬性生效。默認的時間間隔為1分鐘。 -->
<!-- debug:當此屬性設置為true時,將打印出logback內部日志信息,實時查看logback運行狀態。默認值為false。 -->
<configuration  scan="true" scanPeriod="10 seconds">
 
	<!-- 讀取apollo配置中心設置的變量 -->
	<springProperty scope="context" name="logstash.host" source="logstash.host"></springProperty>
	<springProperty scope="context" name="logstash.port" source="logstash.port"></springProperty>
	<springProperty scope="context" name="log.path" source="log.path"></springProperty>
	
	<appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
        <remoteHost>${logstash.host}</remoteHost>
        <port>${logstash.port}</port>
        <!-- encoder必須配置,有多種可選 -->
        <encoder charset="UTF-8" class="net.logstash.logback.encoder.LogstashEncoder" >
            <!-- "appname":"yang_test" 的作用是指定創建索引的名字時用,并且在生成的文檔中會多了這個字段  -->
            <customFields>{"appname":"server-user"}</customFields>
        </encoder>
    </appender>

這個是后啟動日志中會報如下錯誤:

20:26:50,683 |-ERROR in ch.qos.logback.core.joran.spi.Interpreter@120:31 - no applicable action for [springProfile], current ElementPath is [[configuration][springProfile]]
20:26:50,683 |-ERROR in ch.qos.logback.core.joran.spi.Interpreter@121:58 - no applicable action for [logger], current ElementPath is [[configuration][springProfile][logger]]
20:26:50,683 |-ERROR in ch.qos.logback.core.joran.spi.Interpreter@132:42 - no applicable action for [appender-ref], current ElementPath is [[configuration][springProfile][logger][appender-ref]]

這是因為日志文件的名稱是logback.xml的話,logback會在SpringCloud和apollo配置加載之前加載日志配置,這時日志文件中的springProfile的配置是無效的。所以根據官方文檔說明,需要將logback.xml改為logback-spring.xml,然后報錯就沒有了。

注:雖然logback.xml文件名啟動時會報錯,但是不影響實際效果,猜測是因為上邊第二步中的配置會在后邊再次加載logback日志,所以logback依然會產生效果,但是對于有代碼潔癖的人來說,沒有任何報錯和異常才是最舒服的。

 

SpringBoot Logback無法獲取配置中心屬性

最近在做項目中,需要把項目中的日志信息通過RabbitMQ將規定格式的消息發送到消息隊列中,然后ELK系統通過消息隊列拿日志并且保存起來,在日志的配置文件(logback-spring.xml)中我們需要加入RabbitMQ的配置信息,我們的RabbitMQ信息存在Nacos的配置中心,就出現項目啟動無法獲取到RabbitMQ的配置,導致出錯

 

如何解決

問題原因

在springboot官網 https://docs.spring.io/spring-boot/docs/2.0.4.RELEASE/reference/htmlsingle/

中對LogBack的描述中我們可以知道,項目啟動時,logback.xml或者logback-spring.xml加載早于applicaton.yml,所以我們在logback.xml中配置的RabbitMQ屬性無法獲取到

springboot logback如何從apollo配置中心讀取變量

springboot logback如何從apollo配置中心讀取變量

springboot logback如何從apollo配置中心讀取變量

<property name="rabbitmq_host" source="spring.rabbitmq.host"/>
<property name="rabbitmq_vhost" source="spring.rabbitmq.virtual-host"/>
<property name="rabbitmq_username" source="spring.rabbitmq.username"/>
<property name="rabbitmq_password" source="spring.rabbitmq.password"/>

source指定的是application.yml配置文件的key

 

解決方案

將logback.xml或者logback-spring.xml文件自定義名稱,并在配置中心中指定該文件,這樣SpringBoot就不會在獲取配置中心配置之前加載日志配置了

配置中心的配置

#RabbitMQ配置
spring:
   rabbitmq:
     host: 127.0.0.1
     virtual-host: test
     username: admin
     password: 123
logging:
  config: classpath:logback-test.xml

日志配置

logback-test.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">
    <!-- 日志存放路徑 -->
   <property name="log.path" value="./target/logs/system-service" />
    <!-- 參數 -->
    <property name="app_name" source="spring.application.name"/>
    <property name="app_instance_id" source="rabbitmq.instance"/>
    <property name="rabbitmq_host" source="spring.rabbitmq.host"/>
    <property name="rabbitmq_vhost" source="spring.rabbitmq.virtual-host"/>
    <property name="rabbitmq_username" source="spring.rabbitmq.username"/>
    <property name="rabbitmq_password" source="spring.rabbitmq.password"/>
   <!-- 日志輸出格式 -->
   <property name="log.pattern"
              value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - [%method,%line] - %msg%n" />:ss} %-5level ${springAppName:-} %thread %logger %msg%n"/>
    <!-- 控制臺輸出 -->
   <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
      <encoder>
         <pattern>${log.pattern}</pattern>
            <charset>UTF-8</charset>
      </encoder>
   </appender>
    <!-- 系統日志輸出 -->
   <appender name="FIFE" class="ch.qos.logback.core.rolling.RollingFileAppender">
       <file>${log.path}/${app_name}.log</file>
        <!-- 循環政策:基于時間創建日志文件 -->
      <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 日志文件名格式 -->
         <fileNamePattern>${log.path}/${app_name}.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
         <!-- 日志最大的歷史 60天 -->
         <maxHistory>10</maxHistory>
            <maxFileSize>10MB</maxFileSize>
      </rollingPolicy>
        <append>true</append>
      <encoder>
         <pattern>${log.pattern}</pattern>
            <charset>UTF-8</charset>
      </encoder>
      <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 過濾的級別 -->
            <level>INFO</level>
            <!-- 匹配時的操作:接收(記錄) -->
            <onMatch>ACCEPT</onMatch>
            <!-- 不匹配時的操作:拒絕(不記錄) -->
            <onMismatch>DENY</onMismatch>
        </filter>
   </appender>
    <!-- 日志發送到消息隊列RabbitMQ,接入ELK -->
    <appender name="RabbitMQ" class="org.springframework.amqp.rabbit.logback.AmqpAppender">
        <!-- 純文本,不是格式化的JSON -->
        <layout>
            <pattern>
                {
                    "appName":"${app_name}",
                    "appInstance":"${app_instance_id}",
                    "date":"%d{yyyy-MM-dd HH:mm:ss.SSS}",
                    "thread":"[%thread]",
                    "level":"%-5level",
                    "logger":"%logger{36}",
                    "msg":"%msg"
                }
            </pattern>
        </layout>
        <host>${rabbitmq_host}</host>
        <port>5672</port>
        <username>${rabbitmq_username}</username>
        <password>${rabbitmq_password}</password>
        <virtualHost>${rabbitmq_vhost}</virtualHost>
        <declareExchange>false</declareExchange>
        <exchangeType>direct</exchangeType>
        <exchangeName>logs.direct</exchangeName>
        <routingKeyPattern>logback</routingKeyPattern>
        <generateId>true</generateId>
        <durable>false</durable>
        <charset>UTF-8</charset>
        <deliveryModel>NON_PERSISTENT</deliveryModel>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>info</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>
   <!--系統操作日志-->
    <root level="INFO">
        <appender-ref ref="CONSOLE" />
        <appender-ref ref="FILE" />
        <appender-ref ref="RabbitMQ" />
    </root>
</configuration>

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/u011390452/article/details/96433501

延伸 · 閱讀

精彩推薦
  • Java教程Java8中Stream使用的一個注意事項

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

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

    阿杜7482021-02-04
  • Java教程升級IDEA后Lombok不能使用的解決方法

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

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

    程序猿DD9332021-10-08
  • Java教程20個非常實用的Java程序代碼片段

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

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

    lijiao5352020-04-06
  • Java教程小米推送Java代碼

    小米推送Java代碼

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

    富貴穩中求8032021-07-12
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

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

    littleschemer13532021-05-16
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

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

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

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

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

    spcoder14552021-10-18
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

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

    大行者10067412021-08-30
主站蜘蛛池模板: 亚洲精品第二页 | 精品免费久久久久久成人影院 | 我和寂寞孕妇的性事 | 97香蕉超级碰碰碰久久兔费 | 欧美日韩综合网在线观看 | 午夜福利理论片高清在线 | 国产精品怡红院在线观看 | 四虎精品在线视频 | 四色6677最新永久网站 | yy111111免费观看 | 2020最新版的ab片 | 日本老妇人乱视频 | 午夜香蕉 | 青青草成人在线 | 国产精品九九久久一区hh | 啊啊啊好大好爽视频 | 日韩精品亚洲专区在线影视 | 天天操天天射天天色 | 久久综合香蕉久久久久久久 | 国产日日操 | 韩国久久 | 亚洲天堂视频在线播放 | 26uuu成人人网图片 | 男人的视频网站 | 日韩香蕉网 | 日韩 国产 欧美 精品 在线 | 亚洲国产精品一在线观看 | 三年片韩国在线观看 | 亚洲一区二区三区在线播放 | 青青网在线视频 | 成人性爱视频在线观看 | 欧美成人aa久久狼窝动画 | 九九精品影院 | 97福利社 | 91视在线国内在线播放酒店 | 亚洲成年男人的天堂网 | 97就去干 | 欧美大奶艳星 | 色综合视频在线观看 | 国内精品久久久久久野外 | 国产一级片免费视频 |