GuozhongCrawler系列教程 (2) CrawTaskBuilder具体解释
GuozhongCrawler是分层架构。要高速学习CrawlTask独立的配置多少要了解框架的源码。所以CrawTaskBuilder提供要更加扁平且易于理解的的方式创建CrawTask
方法具体资料
useThread
public CrawTaskBuilder useThread(int threadNum)
设置CrawlTask下载处理Request的线程数量- 參数:
threadNum
-- 返回:
- CrawTaskBuilder
usePipeline
public CrawTaskBuilder usePipeline(java.lang.Class<? extends Pipeline> pipelineCls)
设置实现好的Pipeline类Class- 參数:
pipelineCls
- 持久化处理类- 返回:
- CrawTaskBuilder
usePageRetryCount
public CrawTaskBuilder usePageRetryCount(int retryCount)
假设因为网络问题。请求url时可能会出现失败的情况。那么你设置最大又一次请求的次数默认又一次请求1次- 參数:
retryCount
-- 返回:
- CrawTaskBuilder
usePageEncoding
public CrawTaskBuilder usePageEncoding(PageRequest.PageEncoding defaultEncoding)
一般抓取某个站点会有统一的编码,假设你不想每次都调用PageRequest.setPageEncoding的话,那么你能够设置一个默认的编码- 返回:
injectStartUrl
public CrawTaskBuilder injectStartUrl(java.lang.String url,
java.lang.Class<? extends PageProcessor> processorCls,
java.util.Map<java.lang.String,java.lang.Object> contextAttribute,
PageRequest.PageEncoding pageEncoding)加入种子URL设置附加參数和页面编码格式 每一个injectStartUrl方法注入的种子URL会用一个单独的StatContext包装。假设StatContext在抓取过程中不会产生较多新的跟进Request 那么推荐你使用useDynamicEntrance设置入口URL将会更加提升效率- 參数:
url
-contextAttribute
-PageEncoding
-- 返回:
injectStartUrl
public CrawTaskBuilder injectStartUrl(java.lang.String url,
java.lang.Class<? extends PageProcessor> processorCls,
java.util.Map<java.lang.String,java.lang.Object> contextAttribute)加入种子URL并设置附加參数 每一个injectStartUrl方法注入的种子URL会用一个单独的StatContext包装。假设StatContext在抓取过程中不会产生较多新的跟进Request 那么推荐你使用useDynamicEntrance设置入口URL将会更加提升效率- 參数:
url
-contextAttribute
-- 返回:
injectStartUrl
public CrawTaskBuilder injectStartUrl(java.lang.String url,
java.lang.Class<? extends PageProcessor> processorCls)加入种子URL。并指定PageProcessor。 每一个injectStartUrl方法注入的种子URL会用一个单独的StatContext包装。假设StatContext在抓取过程中不会产生较多新的跟进Request 那么推荐你使用useDynamicEntrance设置入口URL将会更加提升效率- 參数:
url
-- 返回:
useDynamicEntrance
public CrawTaskBuilder useDynamicEntrance(java.lang.Class<? extends DynamicEntrance> dynamicEntranceCls)
假设你想在单个StartContext中直接初始化跟进URL,或者让爬虫分批注入种子的话。那么DynamicEntrance提供了这种接口
- 參数:
dynamicEntranceCls
- DynamicEntrance的继承实现类- 返回:
useQueuePriorityRequest
public CrawTaskBuilder useQueuePriorityRequest()
使用优先级队列。在一些抓取分页较多情景下推荐使用QueuePriorityRequest。由于 它能非常好的保证优先级高的Request优先被处理。从而防止队列金字塔式的膨胀- 返回:
useQueueDelayedPriorityRequest
public CrawTaskBuilder useQueueDelayedPriorityRequest(int delayInMilliseconds)
使用延迟优先级队列。和QueuePriorityRequest类似。但QueueDelayedPriorityRequest额外提供了延迟抓取的功能 在一些由于请求频率过快而被封的站点上推荐使用QueueDelayedPriorityRequest- 參数:
delayInMilliseconds
- 每次取Request距离上次时间延迟delayInMilliseconds毫秒- 返回:
useTaskLifeListener
public CrawTaskBuilder useTaskLifeListener(TaskLifeListener listener)
设置监听器,监听爬虫的CrawlTask的onStart 和 onFinish。在此你能够发送邮件或者其它方式来知晓爬虫的运行情况- 參数:
listener
-- 返回:
useCookie
public CrawTaskBuilder useCookie(java.util.Set<Cookie> cookies)
设置Cookie,当Driver创建时设置cookies。在须要登录情况下你能够将登录好的Cookies注入downloader
- 參数:
listener
-- 返回:
addChromeDriverLifeListener
public void addChromeDriverLifeListener(ChromeDriverLifeListener chromeDriverLifeListener)
当你使用ChromeDownloader作为下载器时能够设置ChromeDriverLifeListener- 參数:
listener
-
addWebDriverLifeListener
public void addWebDriverLifeListener(WebDriverLifeListener webDriverLifeListener)
当你使用WebDriverDownloader作为下载器时能够设置ChromeDriverLifeListener- 參数:
listener
-
addHttpClientLifeListener
public void addHttpClientLifeListener(HttpClientLifeListener httpClientLifeListener)
当你使用默认的DefaultPageDownloader作为下载器时能够设置HttpClientLifeListener- 參数:
listener
-
useProxyIpPool
public CrawTaskBuilder useProxyIpPool(java.lang.Class<? extends ProxyIpPool> proxyIpPoolCls,
int initSize,
long pastTime,
int max_use_count)使用代理IP切换机制时设置一个ProxyIpPool的实现类就可以。在封IP站点下推荐使用收费版代理IP效果更佳
- 參数:
proxyIpPoolCls
-initSize
- 每次代理IP缓冲池IP不足时载入IP的个数,推荐使用公式initSize=thread*5pastTime
- 每一个IP自身的过期时间,当代理IP过期时间到的时候会被清除。这个值依据代理IP的质量决定max_use_count
- 每一个代理IP最多使用的次数。推荐使用公式max_use_count=(目标站点连续请求才被封的次数)减去 2到3- 返回:
useProxyIpPoolInstance
public CrawTaskBuilder useProxyIpPoolInstance(ProxyIpPool proxyIpPool)
当然你也能够自己构造一个实例设置ProxyIpPool- 參数:
proxyIpPool
-- 返回:
- 抛出:
java.lang.SecurityException
java.lang.NoSuchMethodException
useTimer
public final CrawTaskBuilder useTimer(int hour,
long period,
int endHour)使用定时循环启动,使用24小时制- 參数:
hour
- 从几点開始启动,假设当前时间小于改时间则等待到改时间启动period
- 每次抓取时间间隔 单位毫秒endHour
- 到几点结束- 返回:
useDownloadFileThread
public CrawTaskBuilder useDownloadFileThread(int thread)
设置同一时候下载文件的线程数 ,默认3个线程- 參数:
thread
-- 返回:
- CrawTaskBuilder
useDownloadFileDelayTime
public CrawTaskBuilder useDownloadFileDelayTime(int millisecond)
文件下载延迟,默认300ms- 參数:
millisecond
-- 返回:
build
public CrawlTask build()
配置完毕。就可以创建CrawlTask- 返回:
- CrawlTask
GuozhongCrawler系列教程 (2) CrawTaskBuilder具体解释的更多相关文章
- GuozhongCrawler系列教程 (1) 三大PageDownloader
GuozhongCrawler QQ群 202568714 教程源代码下载地址:http://pan.baidu.com/s/1pJBmerL GuozhongCrawler内置三大PageDown ...
- GuozhongCrawler系列教程 (4) StartContext具体解释
StartContext是注入时全部seed的上下文信息假设爬虫在抓取过程其中须要共享一些变量.那么可使用StartContext作为容器. 构造器具体资料 StartContext public S ...
- GuozhongCrawler系列教程 (5) TransactionRequest具体解释
为了实现和维护并发抓取的属性信息提供线程安全的事务请求.TransactionRequest是一个抽象类自己不能设置Processor,却须要实现 TransactionCallBack接口.Tran ...
- Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求
上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...
- C#微信公众号开发系列教程二(新手接入指南)
http://www.cnblogs.com/zskbll/p/4093954.html 此系列前面已经更新了两篇博文了,都是微信开发的前期准备工作,现在切入正题,本篇讲解新手接入的步骤与方法,大神可 ...
- 【ASP.NET Identity系列教程(一)】ASP.NET Identity入门
注:本文是[ASP.NET Identity系列教程]的第一篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...
- 【ASP.NET Identity系列教程(二)】运用ASP.NET Identity
注:本文是[ASP.NET Identity系列教程]的第二篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...
- 【ASP.NET Identity系列教程(三)】Identity高级技术
注:本文是[ASP.NET Identity系列教程]的第三篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...
- 随笔分类 - 无废话ExtJs系列教程
随笔分类 - 无废话ExtJs系列教程 摘自:http://www.cnblogs.com/iamlilinfeng/category/385121.html ExtJs 入门教程 摘要: extjs ...
随机推荐
- Codeforces Round #442 A Alex and broken contest【字符串/常量数组/string类】
A. Alex and broken contest time limit per test 2 seconds memory limit per test 256 megabytes input s ...
- log4j笔记:升级2.X版本的日志滚动问题
因为slf4j依赖的log4j在流量大的时候总遇到多线程引起的死锁问题,升级到log4j2.x版本.原来的log4j.properties配置文件已经不被log4j2支持了,需要改写为log4j2.x ...
- Floyd-弗洛伊德算法
今天,研究一下谁都能看懂的弗洛伊德算法. 首先,弗洛伊德算法是一种利用动态规划的思想寻找给定的加权图中多源点之间最短路径的算法. 这个算法需要一个用到一个二维数组啊a[][],而a[i][j]表示的就 ...
- 【动态规划】Gym - 100507G - The Debut Album
一般思路的dp是用f(i,j,0)表示前i位最后有j个1的方案数,用f(i,j,1)表示前j位最后有j个2的方案数,j都是大于等于1的,然后比较容易转移. 但这题卡内存,就只能用f(i,j)表示前i位 ...
- 【博弈论】【SG函数】bzoj1777 [Usaco2010 Hol]rocks 石头木头
仅有距根节点为奇数距离的节点的石子被移走对答案有贡献,∵即使偶数的石子被移走,迟早会被再移到奇数,而奇数被移走后,不一定能够在移到偶数(到根了). 最多移L个:石子数模(L+1),比较显然,也可以自己 ...
- 【数论】【组合数】【快速幂】【乘法逆元】洛谷 P2265 路边的水沟
从左上角到右下角,共经过n+m个节点,从其中选择n各节点向右(或者m各节点向下),所以答案就是C(n+m,n)或者C(n+m,m),组合数暴力算即可,但是要取模,所以用了乘法逆元. #include& ...
- [CF930E]/[CF944G]Coins Exhibition
[CF930E]/[CF944G]Coins Exhibition 题目地址: CF930E/CF944G 博客地址: [CF930E]/[CF944G]Coins Exhibition - skyl ...
- Bootstrap-table使用footerFormatter做统计列
写在前面: 在做表格的时候,难免会碰到做统计的时候.由于在项目中涉及到做统计的功能比较简单,之后也就没有过多的去研究更复杂的,这里简单记录下. 这次就直接先上图:一个简单的例子 看到效果图还是很好的, ...
- 获取OS X中App Store更新后的安装包(如XCode)
如果宿舍有好几个人需要更新一些大的软件,如XCode,会占用很大的带宽. 为了节省带宽,我们可以在1台电脑上更新完后,获取存放在系统暂存区的更新的安装包,然后通过局域网或Airdrop的方式轻松分 ...
- 13、mha高可用架构搭建
各节点架构: 192.168.1.20(mysql5.5) master主库 192.168.1.21(mysql5.5) slave1,目标:主库宕可提升为主库 192.168.1.22(mysql ...