java 收 特定日期邮件_java – Logback SMTPAppender在特定时间只发送一封电子邮件,但有所有例外...

一个简单的解决方案是将这些错误记录到文件中,并在服务器/计算机上安装一个脚本,该脚本每天读取一次文件并发送电子邮件.

如果你想使用一个appender,在我看来你需要自己动手,因为我认为标准的SMTPAppender不能让你每天发送一次电子邮件:

>扩展SMTPAppender

>覆盖SMTPAppenderBase中的sendBuffer方法,以便它只是将日志消息添加到集合中

>将ScheduledExecutorService添加到每天运行一次sendEmail方法的appender

> sendEmail方法将同步此线程以确保线程安全,检查集合是否为空,发送包含所有错误的电子邮件并清除集合

基本实现可能看起来像下面的类(我没有测试过它 – 我使用的是Java 8语法,但如果需要,可以用匿名类替换它).请注意,我只保留导致异常的事件,您可能还希望在sendBuffer方法中保留CyclicBuffer的内容和/或在sendEmail方法中的错误之间添加一些错误分隔符.这可能会变得非常复杂,需要根据您的要求进行微调.

public class ScheduledSMTPAppender extends SMTPAppender {

private final ThreadFactory tf = r -> {

Thread t = new Thread(r, "ScheduledSMTPAppender Thread");

t.setDaemon(true); //make daemon or it will prevent your program to exit

return t;

};

private final ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1, tf);

private final List events = new ArrayList<> ();

private int maxMessages = 10;

public ScheduledSMTPAppender() { super(); }

public ScheduledSMTPAppender(EventEvaluator eventEvaluator) { super(eventEvaluator); }

@Override public void start() {

super.start();

scheduler.scheduleAtFixedRate(this::sendEmail, 1, 1, TimeUnit.DAYS);

}

@Override protected void sendBuffer(CyclicBuffer cb, ILoggingEvent lastEventObject) {

events.add(lastEventObject);

if (events.size() > maxMessages) sendEmail();

}

//needs to be synchronized for thread safety

private synchronized void sendEmail() {

try {

if (events.isEmpty()) return;

ILoggingEvent lastEvent = events.get(events.size() - 1);

events.remove(events.size() - 1);

CyclicBuffer cb;

if (events.isEmpty()) {

cb = new CyclicBuffer<>(1);

} else {

cb = new CyclicBuffer<>(events.size());

for (ILoggingEvent e : events) cb.add(e);

}

super.sendBuffer(cb, lastEvent);

events.clear();

} catch (Exception e) {

//Important to have a catch all here or the scheduled task will die

addError("Error occurred while sending e-mail notification.", e);

}

}

//this allows to make "maxMessages" a parameter of your appender

public int getMaxMessages() { return maxMessages; }

public void setMaxMessages(int maxMessages) { this.maxMessages = maxMessages; }

}

您的logback配置文件如下所示:

SERVER

PORT

false

SENDER

RECIPIENT

SUBJECT

10

%d{HH:mm:ss.SSS} %-55(%X{user} %level [%thread] %logger{20}) - %msg%n

更进一步,您可以添加参数,例如发送日期的时间,每天的电子邮件数量等.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值