自訂Appender非常簡單,繼承一下AppenderBase類別即可。
可以看到有個AppenderBase,有個UnsynchronizedAppenderBase,還有個AsyncAppenderBase繼承了UnsynchronizedAppenderBase。從名字就能看出來差別,異步的、普通的、不加鎖的。
我們定義一個MongoDBAppender繼承UnsynchronizedAppenderBase
public class MongoDBAppender extends UnsynchronizedAppenderBase<ILoggingEvent> { @Override protected void append(ILoggingEvent eventObject) { MongoTemplate mongoTemplate = ApplicationContextProvider.getBean(MongoTemplate.class); if (mongoTemplate != null) { final BasicDBObject doc = new BasicDBObject(); doc.append("level", eventObject.getLevel().toString()); doc.append("logger", eventObject.getLoggerName()); doc.append("thread", eventObject.getThreadName()); doc.append("message", eventObject.getFormattedMessage()); mongoTemplate.insert(doc, "log"); } } }
必須要實作一個append方法,這個方法就是logback輸出日誌的地方,日誌都保存在eventObject物件中,我們只需要取得物件裡的值並做自己的處理即可。
我們可以想為,系統的ConsoleAppender就是不停的System.out.print(eventObject.getXXX),FileAppender就是用OutpuptStream輸出到檔案裡。
我們要做的就是把日誌保存到mongo裡,Springboot已經提供了MongoTemplate模板,需要注意日誌輸出是隨著系統啟動就開始的,而剛開始時MongoTemplate還沒有被初始化,是需要等待Spring給MongoTemplate賦值的。所以剛開始時為null,需要等spring初始化完畢,MongoTemplate才有值。
由於這個Appender不歸spring管理,所以我採用單獨取得bean的方式。其中ApplicationContextProvider如下:
@Component public class ApplicationContextProvider implements ApplicationContextAware { private static ApplicationContext context; public static ApplicationContext getApplicationContext() { return context; } @Override public void setApplicationContext(ApplicationContext ac) throws BeansException { context = ac; } public static <T> T getBean(Class<T> tClass) { return context.getBean(tClass); } public static <T> T getBean(String name, Class<T> tClass) { return context.getBean(name, tClass); } }
上面mongo操作日誌入庫的比較簡單,欄位也沒用完,大家可以依照自己希望保存的屬性來設計mongo的結構,然後入庫。
pom.xml
<dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-java-driver</artifactId> <version>3.4.2</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-core</artifactId> <version>1.1.11</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.1.11</version> </dependency>
在Spring-logback.xml使用也很簡單
<?xml version="1.0" encoding="UTF-8"?> <configuration> <include resource="org/springframework/boot/logging/logback/base.xml" /> <appender name="MY_FILE" class="com.example.demo.mongo.MongoDBAppender"> </appender> <!-- 测试环境+开发环境. 多个使用逗号隔开. --> <springProfile name="test,dev"> <logger name="org.springframework.web" level="INFO"> <appender-ref ref="MY_FILE"/> </logger> <logger name="com.example" level="INFO" /> </springProfile> </configuration>
只需指明appender 的class即可。
以上是SpringBoot中logback日誌怎麼保存到mongoDB的詳細內容。更多資訊請關注PHP中文網其他相關文章!