javamail 超时_如何正确设置JavaMail超时设置

I am using JavaMail to connect to a POP3 server.

Further, I set the following properties, so that JavaMail won't wait to long if an email server doesn't respond:

props.setProperty("mail.pop3.connectionpooltimeout", "3000");

props.setProperty("mail.pop3.connectiontimeout", "3000");

props.setProperty("mail.pop3.timeout", "3000");

However, in some cases the timeout works properly but sometimes JavaMail freezes for minutes(!) with the following debug message:

DEBUG POP3: connecting to host "pop3.yahoo.com", port 110, isSSL false

Changing ports or protocols (SSL, TLS..) has no effect. I assume that the host simply doesn't exist.

For example, if I poll pop3.yahoo.com instead of pop.mail.yahoo.com (which would be the right host name), I have to wait very long til a timeout exception occurs.

After several minutes, I get the following exception and the application continues to run:

java.net.ConnectException: Operation timed out

pop3.yahoo.com seems to exist but won't respond:

localhost:~ me$ ping pop3.yahoo.com

PING pop3.yahoo.com (206.190.46.10): 56 data bytes

Request timeout for icmp_seq 0

Request timeout for icmp_seq 1

Request timeout for icmp_seq 2

Request timeout for icmp_seq 3

^C

You might be asking why I use pop3.yahoo.com instead of pop.mail.yahoo.com.

Well, I simply wanted to test what happens if the user of my application inserts a wrong host name.

I believe that this issue is related to this report http://www.opensubscriber.com/message/javamail-interest@java.sun.com/180946.html where the poster claims that the problem occurs if the email server closes the connection. JavaMail then seems to wait very long (don't know why).

Since the issue wasn't resolved in the link I posted: Does somebody know how to fix or at least debug this?

Any help would be really appreciated!

解决方案

I found the reason for the problem. It was a bug in my code. Javamail respects the timeout setting fine.

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值