abfetch
使用批量异步抓取接口抓取网络资源到七牛存储空间。
批量异步 fetch 分两步:
- 发起异步 fetch 请求,请求成功并不意味着 fetch 成功,需要
步骤 2
来检测是否真的 fetch 成功。 - 通过查询文件是否存在于指定的七牛存储空间中来检测 fetch 是否成功;你可以使用长选项
--disable-check-fetch-result
跳过此步骤。
参考文档:异步抓取 (async fetch)
qshell abfetch [-i <URLList>][-b <CallbackBody>][-T <CallbackHost>][-a <CallbackUrl>][-e <FailureList>][-t <DownloadHostHeader>][--file-type <FileType>][-s <SuccessList>][-c <ThreadCount>] <Bucket>
可以在命令行输入如下命令获取帮助文档:
// 简单描述
$ qshell abfetch -h
// 详细文档(此文档)
$ qshell abfetch --doc
无
- Bucket:空间名,可以为公开空间或私有空间。 【必选】
- -i/--input-file:要抓取的资源列表, 一行一个资源,每一行多个元素时使用 \t (tab 键)分割;如果没有通过该选项指定该文件参数, 从标准输入读取内容。每行具体格式如下:(【可选】)
- [FileUrl]
- [FileUrl]\t[FileSize]
- [FileUrl]\t[FileSize]\t[Key], // eg:https://qiniu.com/a.png\t1024\ta.png
注:FileSize 单位:B;如果不指定 key 则从 url 中获取最后一个 path 信息作为 key;eg:https://qiniu.com/a.png\t1024\ta.png key 为:ta.png
- -b/--callback-body:回调的 http Body。 【可选】
- -T/--callback-host:回调时的 HOST 头。 【可选】
- -a/--callback-url:回调的请求地址。 【可选】
- --file-type:抓取的资源存储在七牛存储空间的类型,0:普通存储 1:低频存储 2:归档存储 3:深度归档 4:归档直读存储, 默认为: 0。 【可选】
- -c/--thread-count:指定抓取时使用的线程数目,默认:20。 【可选】
- --overwrite:是否覆盖空间已有文件,默认为
false
。 【可选】 - -s/--success-list:指定一个文件的路径,如果资源抓取成功,则将资源信息写入此文件;默认不导出。 【可选】
- -e/--failure-list:指定一个文件的路径,如果资源抓取失败,则将资源信息写入此文件;默认不导出。 【可选】
- --disable-check-fetch-result:不检测异步 fetch 是否成功;检测方式是查询目标 bucket 是否存在 fetch 的文件;默认检测。【可选】
- --enable-record:记录任务执行状态,当下次执行命令时会跳过已执行的任务。 【可选】
- --record-redo-while-error:依赖于 --enable-record;命令重新执行时,命令中所有任务会从头到尾重新执行;每个任务执行前会根据记录先查看当前任务是否已经执行,如果任务已执行且失败,则再执行一次;默认为 false,当任务执行失败则跳过不再重新执行。 【可选】
详细的选项介绍,请参考:异步抓取 (async fetch)
假如我有3个资源要抓取,地址分别为: http://test.com/test1.txt http://test.com/test2.txt http://test.com/test3.txt
需要抓取这三个资源保存在七牛存储空间"test"中
在当前目录下创建名为"urls.txt"的文件, 文件内容为
http://test.com/test1.txt
http://test.com/test2.txt
http://test.com/test3.txt
每行一个地址,因为未指定 key,所以 key 默认为 url 中最后一个 path 信息,分别为:test1.txt、test2.txt、test3.txt。
使用如下的命令就可以抓取资源到存储名为 "test" 空间中
$ qshell abfetch -i urls.txt test
但是这样我们不知道哪些成功了,哪些抓取失败了,可以使用选项 -e 导出失败资源列表到文件 "failure.txt" 中:
$ qshell abfetch -i urls.txt -e failure.txt test
如果要提高请求的并发量, 可以使用选项 -c 指定提交的线程数, 下面的命令指定线程数为 100:
$ qshell abfetch -i urls.txt -e failure.txt -c 100 test
线程数只能决定向后台服务器提交抓取请求的快慢,提交的抓取请求会到服务器处理队列中,如果队列中有很多要抓取的资源,抓取速度不一定会提高,所以适当设置线程数。
异步接口暂时没办法判断是否抓取成功,当异步接口返回的数据 wait 小于 0 时,程序会用 stat 接口去存储获取文件的信息,如果可以获取到,说明抓取成功了;如果 wait 小于 0, 且在一定时间内(由文件大小决定,文件越大等待时间越长)重试多次 stat 都失败,那么认为抓取失败。
比如要抓取的资源地址为: http://test.com/test1.txt http://test.com/test2.txt http://test.com/test3.txt
test1.txt 大小为400字节 test2.txt 大小为300340字节 test3.txt 大小为22039字节
假如把这些信息保存在"fetch_input.txt"文件中, 文件内容格式为: http://test.com/test1.txt 400 http://test.com/test2.txt 300340 http://test.com/test3.txt 22039
程序会根据文件大小估算异步抓取的时间,时间到后,会访问异步结果获得处理结果。如果没有指定文件大小,默认会有轮训时间。