使用Fork/Join多线程框架实现批量发送短信
message.perproties
message.send.host=http://web.cr6868.com/asmx/smsservice.aspx
message.send.username=***
message.send.password=***
message.send.sign=XX
message.send.type=pt
message.send.template=验证码:{0} 五分钟内有效
message.send.url=${message.send.host}?name=${message.send.username}&pwd=${message.send.password}&stime=&sign=${message.send.sign}&type=${message.captcha.send.type}&extno=&mobile={1}&content={2}
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.Future;
import java.util.concurrent.RecursiveTask;
import javax.annotation.Resource;
import org.apache.commons.lang3.RandomStringUtils;
import org.apache.commons.lang3.time.DateUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
/**
*
* @description: 发送邀请码
* @author: skyler
* @time: 2016年7月11日 下午2:31:06
*/
@Service
public class StaffService implements IStaffService {
private Logger logger = LoggerFactory.getLogger(this.getClass());
@Resource
private IStaffDao staffDao;
@Value("${message.send.url}")
private String msgUrl;
@Value("${message.send.template}")
private String msgTemplate;
@Override
public String sendCodeToStaffs(List<Staff> list) throws InterruptedException, ExecutionException ,Exception {
ForkJoinPool fjp = new ForkJoinPool();
System.out.printf("-----Runtime.getRuntime().availableProcessors():%d\n",Runtime.getRuntime().availableProcessors());
StaffTask task = new StaffTask(0, list.size(), list);
Future future = fjp.submit(task);
fjp.shutdown();
if (task.isCompletedAbnormally()) {
System.out.printf("sendMsg exception : %s\n",task.getException());
//logger.error("sendMsg exception:",task.getException());
}
String result = (String)future.get();
System.out.printf("future.get() result:%s\n",result);
return result;
}
/**
*
* @description: 创建发送邀请码任务
* @author: skyler
* @time: 2016年7月11日 下午2:31:44
*/
class StaffTask extends RecursiveTask<String> {
private static final long serialVersionUID = 1L;
private int first;
private int last;
private List<Staff> stafflist;
public StaffTask() {
}
public S