您的位置:首页 > 编程语言 > Java开发

Java邮件发送阻塞线程

2017-03-31 00:00 916 查看

Java邮件发送阻塞线程

标签(空格分隔): 邮件 阻塞 线程

[TOC]

1. 背景与问题描述

线上的一个定时后台,每10分钟处理一次。后台具有排它性,出现告警数据时会发送邮件。发送邮件使用JavaEE5的jar包。后台在早上9点51分钟的时候,发送告警邮件时阻塞线程,一直卡在发送的地方,不能正常结束。导致后续的执行无法继续进行。数据积压发现问题。

2. 问题排查和重现

之前遇到过类似的一个问题,HTTP请求时使用默认的超时时间设置,导致线程阻塞,和这个问题的表象非常像。
于是乎,去看邮件发送的代码,果然没有设置超时时间。为了复现问题,做了以下两种情况的测试:

阻止JAVA线程的网络连接,调用发送邮件的方法:
此时线程一直处于等待状态,5分钟后,恢复网络连接,发送邮件的线程依然阻塞。

阻止JAVA线程的网络连接,设置连接超时时间和读取超时时间,调用发送邮件的方法:
此时线程到超时时间,会自动抛出异常,线程结束。

3. 解决方案

直接上代码:

props.put("mail.smtp.connectiontimeout", "10000");
props.put("mail.smtp.timeout", "10000");

把上述两句代码,加到发送邮件代码里面,问题即可解决。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  邮件 阻塞 线程