Commit 987430de by 马黎滨

线程池静态

parent 4b9aee87
...@@ -45,6 +45,10 @@ ...@@ -45,6 +45,10 @@
hot_search_list hot_search_list
#### zookeeper #### zookeeper
zookeeper://192.168.0.203:2182?backup=192.168.0.104:2182,192.168.0.105:2182 zookeeper://192.168.0.203:2182?backup=192.168.0.104:2182,192.168.0.105:2182
#### redis
redis.host = 192.168.0.39
redis.port = 6379
redis.database = 1
......
...@@ -157,7 +157,6 @@ public class ToutiaoHotSearchCrawler { ...@@ -157,7 +157,6 @@ public class ToutiaoHotSearchCrawler {
String url = hotSearchList.getUrl(); String url = hotSearchList.getUrl();
Request request = RequestUtils.wrapGet(url); Request request = RequestUtils.wrapGet(url);
for (int i = 0; i <= 5; i++) { for (int i = 0; i <= 5; i++) {
ZhiWeiTools.sleep(1000L);
try (Response response = httpBoot.syncCall(request, ProxyHolder.NAT_HEAVY_PROXY)) { try (Response response = httpBoot.syncCall(request, ProxyHolder.NAT_HEAVY_PROXY)) {
htmlBody = response.body().string(); htmlBody = response.body().string();
} catch (IOException e1) { } catch (IOException e1) {
...@@ -175,6 +174,7 @@ public class ToutiaoHotSearchCrawler { ...@@ -175,6 +174,7 @@ public class ToutiaoHotSearchCrawler {
return hotSearchList; return hotSearchList;
} }
} }
ZhiWeiTools.sleep(1000L);
} }
} }
return hotSearchList; return hotSearchList;
......
...@@ -2,12 +2,11 @@ package com.zhiwei.searchhotcrawler.timer; ...@@ -2,12 +2,11 @@ package com.zhiwei.searchhotcrawler.timer;
import com.zhiwei.searchhotcrawler.bean.HotSearchList; import com.zhiwei.searchhotcrawler.bean.HotSearchList;
import com.zhiwei.searchhotcrawler.crawler.ToutiaoHotSearchCrawler; import com.zhiwei.searchhotcrawler.crawler.ToutiaoHotSearchCrawler;
import com.zhiwei.searchhotcrawler.util.TipsUtils;
import lombok.extern.log4j.Log4j2; import lombok.extern.log4j.Log4j2;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@Log4j2 @Log4j2
...@@ -38,13 +37,13 @@ public class TouTiaoExecutor extends Thread { ...@@ -38,13 +37,13 @@ public class TouTiaoExecutor extends Thread {
*/ */
public static List<HotSearchList> countTouTiaoReadCount(List<HotSearchList> list){ public static List<HotSearchList> countTouTiaoReadCount(List<HotSearchList> list){
resultList= new ArrayList<>(); resultList= new ArrayList<>();
ExecutorService service = Executors.newFixedThreadPool(list.size()); // ExecutorService service = Executors.newFixedThreadPool(list.size());
for(int i=0; i<list.size(); i++){ for(int i=0; i<list.size(); i++){
service.execute(new TouTiaoExecutor(list.get(i))); TipsUtils.service.execute(new TouTiaoExecutor(list.get(i)));
} }
service.shutdown(); // TipsUtils.service.shutdown();
try { try {
if(!service.awaitTermination(1, TimeUnit.MINUTES)){ if(!TipsUtils.service.awaitTermination(1, TimeUnit.MINUTES)){
log.info("查询今日头条阅读量超时"); log.info("查询今日头条阅读量超时");
} }
} catch (InterruptedException e) { } catch (InterruptedException e) {
......
...@@ -87,7 +87,7 @@ public class GatherTimer { ...@@ -87,7 +87,7 @@ public class GatherTimer {
List<HotSearchList> toutiaoList = ToutiaoHotSearchCrawler.toutiaoHotSearchByPhone(date); List<HotSearchList> toutiaoList = ToutiaoHotSearchCrawler.toutiaoHotSearchByPhone(date);
List<HotSearchList> toutiaoResult = new ArrayList<>(); List<HotSearchList> toutiaoResult = new ArrayList<>();
toutiaoResult = TouTiaoExecutor.countTouTiaoReadCount(toutiaoList); toutiaoResult = TouTiaoExecutor.countTouTiaoReadCount(toutiaoList);
logger.info("{}, 今日头条此轮采集到的数据量为:{}", new Date(), Integer.valueOf(toutiaoResult != null ? toutiaoResult.size() : 0)); logger.info("{}, 今日头条此轮采集到的数据量为:{}", new Date(), toutiaoResult != null ? toutiaoResult.size() : 0);
TipsUtils.addHotList(HotSearchType.今日头条热搜.name(),toutiaoResult); TipsUtils.addHotList(HotSearchType.今日头条热搜.name(),toutiaoResult);
logger.info("今日头条热搜采集结束..."); logger.info("今日头条热搜采集结束...");
} }
......
...@@ -9,6 +9,8 @@ import org.slf4j.Logger; ...@@ -9,6 +9,8 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import java.util.*; import java.util.*;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
/** /**
* 预警发送 * 预警发送
...@@ -23,6 +25,8 @@ public class TipsUtils { ...@@ -23,6 +25,8 @@ public class TipsUtils {
private static Map<String,Date> typeTips = new HashMap<>(); private static Map<String,Date> typeTips = new HashMap<>();
public static ExecutorService service = Executors.newFixedThreadPool(30);
//未采集到数据发送预警信息 //未采集到数据发送预警信息
public static void sendTips(String type, Date time){ public static void sendTips(String type, Date time){
HotSearchListDAO hotSearchListDAO = new HotSearchListDAO(); HotSearchListDAO hotSearchListDAO = new HotSearchListDAO();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment