001/* 002 * Copyright (c) 2022-2023, Mybatis-Flex (fuhai999@gmail.com). 003 * <p> 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * <p> 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * <p> 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016package com.mybatisflex.core.audit; 017 018import java.util.concurrent.Executors; 019import java.util.concurrent.ScheduledExecutorService; 020import java.util.concurrent.TimeUnit; 021 022/** 023 * 默认的审计消息收集器,其收集消息后,定时通过消息发送器{@link MessageReporter}把消息发送过去 024 */ 025public class ScheduledMessageCollector extends AbstractMessageCollector { 026 027 private final ScheduledExecutorService scheduler; 028 029 public ScheduledMessageCollector() { 030 this(10, new ConsoleMessageReporter()); 031 } 032 033 034 public ScheduledMessageCollector(long period, MessageReporter messageSender) { 035 super(messageSender); 036 this.scheduler = Executors.newSingleThreadScheduledExecutor(runnable -> { 037 Thread thread = new Thread(runnable, "ScheduledMessageCollector"); 038 thread.setDaemon(true); 039 return thread; 040 }); 041 this.scheduler.scheduleAtFixedRate(this::doSendMessages, period, period, TimeUnit.SECONDS); 042 } 043 044 public void release() { 045 doSendMessages(); //clear the messages 046 scheduler.shutdown(); 047 } 048 049}