今天在开发新项目-B的时候,需要将之前做的项目-A中发邮件的功能迁移过来,由于发邮件的工作我做过封装,无非就几个类和配置项,但是最近听同事说,A项目中的发邮件功能有时候会堵塞执行,由于是同步的,造成后面的流程处理被阻塞。同事对改发邮件进行了超时处理,但是效果不是很明显。
我今天在把项目-A中的发邮件功能迁移,突然想到了Spring的@Async注解可以异步执行发邮件,于是经过两步配置就解决了问题。有的同学可能会想到使用多线程也能完成该事情。其实@Async的执行也是程序动态创建了代理类启动新的线程来处理,还是线程。
关于该注解网上的文章很多,没必要过多解释,只是说下我们平时尽量充分利用Spring给我们带来的便利。
1、src/main/resources/applicationContext.xml
<!-- 支持异步方法执行 -->
<task:annotation-driven />
2、
public interface ISendMsgService {
public void sendEmail(String subject, String htmlMsg, String jobId, String jobSatus,AlarmLevel alarmLevel);
public void sendSms(String content,String jobId,String jobSatus);
}
public class SendMsgServiceImpl implements ISendMsgService {
private String orgId = "***********"; //可配置
public void sendEmail(String subject, String htmlMsg,String jobId,String jobSatus,AlarmLevel alarmLevel) {
pushEmailMsgHandle(newSubject, htmlMsg, orgId);
}
public void sendSms(String content,String jobId,String jobSatus) {
pushSmsMsgHandle(content, orgId);
}
@Async
private void pushEmailMsgHandle(String subject, String htmlMsg, String orgId) {
}
@Async
private void pushSmsMsgHandle(String content, String orgId){
}
}
public enum AlarmLevel {
非常重要,
重要,
错误,
通知,
系统异常;
}
3、
src/main/resources/smarty.properties
debug=true
encoding=UTF-8
template.path=
left.delimiter={
right.delimiter=}
package.function=org.lilystudio.smarty4j.statement.wscl
4、
src/main/webapp/templates/Transfer_tpl.html 模板
5、
public class SmartyTemplateUtil {
private static final Logger logger = Logger.getLogger(SmartyTemplateUtil.class);
private static final Engine smartyEngine = SmartyEngine.getSmartyEngine();
public static String getHtml(String templeteName, Context context) {
try {
ByteArrayOutputStream out = new ByteArrayOutputStream();
smartyEngine.getTemplate(templeteName).merge(context, out);
return out.toString("UTF-8");
} catch (Exception e) {
logger.error("SmartyEngineFactory.getHtml()", e);
}
return null;
}
private static class SmartyEngine {
protected static Engine getSmartyEngine() {
String path = Thread.currentThread().getContextClassLoader().getResource("").getPath();
logger.info("Thread.currentThread().getContextClassLoader().getResource(\"\").getPath() : 【" + path + "】");
path = new String(path.substring(0, path.indexOf("WEB-INF") - 1)) + File.separator + "templates" + File.separator;
logger.info("HTML模板根目录: 【" + path +"】");
Map<String, String> config = new HashMap<String, String>();
config.put("template.path", path);
config.put("encoding", "UTF-8");
return new Engine(config);
}
}
}