aria2命令
Dec 23, 2015 · 3 minute read · Commentslinuxsoftware
目录
#aria2
title: aria2 使用说明
title: aria2,aria2c,wget,linux,下载
info: aria2是一款轻量型命令行下载工具,它提供了对多协议和多源地址的支持,目前支持的协议包括HTTP(S), FTP, BitTorrent (DHT, PEX, MSE/PE), and Metalink。
aria2可以从多个源地址,并使用多种协议进行下载,并尝试将下载带宽利用率最大化。它可以同时从HTTP(S)/FTP 和 BitTorrent下载一份数据,并且将其上传到bt集群中。通过Metalink的分块检查,aria2可以在下载过程中自动的进行数据校验。
虽然现在有诸如wget和curl等其他类似产品,但aria2具有两个独特的功能:
- aria2可以从多个源下载文件(HTTP(S)/FTP/BitTorrent),
- aria2可以并发的进行多个源地址的下载。这样用户将不必等待单个文件的下载完成,而且aria2会尽可能快的下载。
除aria2外,也有一些其他可以进行分片下载的工具,它们往往按照线程数分割文件,并行下载,换言之,它们不会对未完成的部分进行自适应性重新分片,当整个流程工作正常时,这个策略是可以的,但一旦存在一个线程运行非常慢,这样整个进程就需要等待该线程的执行。而aria2可以很好的处理这个情况,它可以将文件分割成1M大小的分片,当某个线程运行特别缓慢时,aria2可以使用更快的线程来替换。总之,根据作者的说法,aria2是非常智能和可靠的。
和最初的aria工具具有一个GTK+界面不同,aria2只提供了命令行接口,从而使得对资源的要求更小。通常它的物理内存消耗为4M(HTTP/FTP)到9M(BitTorrent),当进行bt下载且速度为2.8M/s时的cpu消耗约为6%。
基本使用
当源地址存在诸如&
或*
等其他shell特殊字符时,请使用单引号或者双引号将uri包含起来。
在aria2的1.10.0版中,aria2对每台主机默认使用1个连接和20MB的分块大小,所以不论在-s参数中指定任何值,他都对一台主机只会建立一个连接,需要注意的一点是这个限制是针对单个主机的,当指定了多台主机时,它会对每台主机建立一个连接。如果要使用1.9.x版中的行为,则要使用-x16 -k1M。另见man页面的 –max-connection-per-server
和 –min-split-size
。
_aria2默认会在开始下载前预先分配文件空间以避免可能的文件碎片_,但这会在部分PC上带来50%-90%的cpu消耗。当使用环境为比较新的文件系统,例如ext4,btrfs,xfs或者NTFS时,作者推荐使用–file-allocation=falloc
,这种方式会在瞬间完成大文件(数G)的空间分配并且不会带来额外的性能下降。
如果你既没有使用cutting-edge文件系统,也没有使用linux,并且很在意系统性能,那么可以使用–file-allocation=none来关闭文件的预分配。
如果你忘记了这些参数的全名或者含义,把-h放在选项或者词的前面,比如aria2c -hcrypt,这样aria2就会搜索crypt相关的选项并把他的帮助打印出来,如果aria2发现使用了-h,它会在打印出帮助信息后停止运行。
基本用法
下载一个文件
aria2c http://host/image.iso
在1.10.0版中,aria2对每个host使用一个连接,你可以使用–max-connection-per-server
或 -x
来修改
使用两个连接从一个源下载文件
aria2c -x2 http://host/image.iso
Ctrl+c
可以中止当前的下载,在同样的目录运行同样的命令可以继续原来的下载,你设置可以修改uri
,如果他们指向的是同一个文件的话。
使用两个连接下载文件:
aria2c -s2 http://host/image.iso http://mirror1/image.iso http://mirror2/image.iso
注:如果命令中uri的数量多于-s的值,如本例所示,aria2将会首先使用前两个uri,将第3个uri作为候补,如果前两个有一个下载失败,就会启用第3个
从http或ftp服务器下载:
aria2c http://host1/file.zip ftp://host2/file.zip
从任意源进行并行下载:
aria2c -Z http://host/file1 file2.torrent file3.metalink
如果仅仅指定本地磁盘上的torrent文件或者metalink,是不需要-Z选项的,如:
aria2c file1.torrent file2.torrent
从文件中读取目的文件,并行下载
aria2c -ifiles.txt -j5
注:-j参数指定了并发下载的数量,在输入文件中可以包含torrent文件和metelink
注:输入文件中支持添加参数,详见后续的“输入文件”章节
退出时保存出错/未完成的下载, 使用session
aria2c -ifiles.txt --save-session=out.txt
当ctrl+c或者aria2自己退出时,所有的错误,未完成的下载信息会保存到out.txt中,但通过aria2.addTorrent 和 aria2.addMetalink XML-RPC方式增加的下载不会保存。
后续可以使用该文件继续未完成的下载:
aria2c -i out.txt
Metalink相关下载示例
从远程metalink下载文件:
aria2c http://host/file.metalink
从远程metalink下载文件,但在内存中处理metalink:
aria2c --follow-metalink=mem http://host/file.metalink
通过本地metalink下载:
aria2c -t10 --lowest-speed-limit=4000 file.metalink
使用5个server下载
aria2c -C5 file.metalink
注:当使用metalink时,-s参数不再起作用,需要使用-C选项
通过多个本地metalink文件进行下载:
aria2c file1.metalink file2.metalink
打印metalink的内容
aria2c -S file.metalink
通过序号下载指定文件
aria2c --select-file=1-4,8 -Mfile.metalink
注:可以通过-S选择来打印metalink文件的内容
指定用户偏好从本地metalink下载文件
aria2c --metalink-location=JP,US --metalink-version=1.1 --metalink-language=en-US file.metali
BitTorrent相关下载
通过远程BitTorrent文件下载
aria2c http://site/file.torrent
通过远程BitTorrent文件下载,但在内存中处理
aria2c --follow-torrent=mem http://site/file.torrent
通过本地torrent文件下载:
aria2c -u40K /path/to/file.torrent
注:-u, –max-upload-limit用来指定最大上传速度
可以同时处理多个torrent文件:
aria2c /path/to/file1.torrent /path/to/file2.torrent
通过BitTorrent Magnet URI下载:
aria2c "magnet:?xt=urn:btih:248D0A1CD08284299DE78D5C1ED359BB46717D8C&dn=aria2"
注:需要将magnet的地址用单引号或者双引号引起来,因为里面包含’&‘字符。当使用magnet时,强烈建议打开dht选项,–enable-dht 将metadata保存成.torrent文件
aria2c --bt-save-metadata "magnet:?xt=urn:btih:248D0A1CD08284299DE78D5C1ED359BB46717D8C&dn=aria2"
这个命令会将metadata信息保存在248d0a1cd08284299de78d5c1ed359bb46717d8c.torrent文件中
自动调整peer节点数量
当所有节点的整体下载速度低于某个值时,aria2可以临时增加节点数量来获取更快的下载速率
aria2c --bt-request-peer-speed-limit=200K file.torrent
开启DHT
aria2c --enable-dht http://site/file.torrent
注:在1.7.2版本后,dht选项是被默认打开的。当aria2只处理http/ftp下载时,不会打开dht选项。当第一个torrent开始下载时,aria2进行DHT功能的初始化,然后一直运行到aria2退出。
开启ipv6的DHT
aria2c --enable-dht6 --dht-listen-port=6881 --dht-listen-addr6=YOUR_GLOBAL_UNICAST_IPV6_ADDR --enable-async-dns6
注:如果aria2在build时没有使用c-ares,则不需要–enable-async-dns6。aria2在ipv4和ipv6的dht中共享一些端口
增加和删除tracker URI:
下面这个例子将从file.torrent中移除所有的tracker的uri,然后使用”http://tracker1/announce” 和 “http://tracker2/announce”
aria2c --bt-exclude-tracker="*" --bt-tracker="http://tracker1/announce,http://tracker2/announce" file.torrent
加密
在默认情况下,aria2可以接收加密/非加密的连接,并且会首先尝试加密握手,如果失败才会去使用传统的BitTorrent握手 下面这个例子中,aria2将只通过加密的握手接受与建立连接。
aria2c --bt-require-crypto=true http://site/file.torrent
存在两种加密方式,头加密和全连接加密。如果两种都可以被peer提供,aria2将默认使用头加密方式。如果要使用全连接加密,可以使用:
aria2c --bt-min-crypto-level=arc4 http://site/file.torrent
打印torrent文件内容
aria2c -S file.torrent
通过序号选择指定文件下载:
aria2c --select-file=1-4,8 -Tfile.torrent
注:index信息可以通过-S来获得
修改监听端口
aria2c --listen-port=6881-6883 file.torrent
注:请确保指定端口可以进行tcp的上行和下行通信
指定aria2完成下载后的停止条件
aria2c --seed-time=120 --seed-ratio=1.0 file.torrent
注:本例中,aria2会在下载完成后120分钟,或seed ratio达到1.0时退出程序
设置上传速度
aria2c --max-upload-limit=100K file.torrent
Seeding已经下载完成的文件
可以使用-V选择来播种下载完成的文件,它会首先对文件进行分片的hash校验
Seeding already downloaded file
如果可以确定下载文件的正确性,可以使用–bt-seed-unverified选项来跳过文件的校验环节
aria2c --bt-seed-unverified -d/path/to/dir file.torrent
还可以同时播种多个torrent文件
aria2c --bt-seed-unverified -d/path/to/dir file1.torrent file2.torrent
通过index指定文件名
为了指定bt下载的文件名称,需要使用-S选线来查看torrent文件中的index信息,例如:
idx|path/length
===+======================
1|dist/base-2.6.18.iso
|99.9MiB
---+----------------------
2|dist/driver-2.6.18.iso
|169.0MiB
---+----------------------
下面的命令可以将dist/base-2.6.18.iso 保存为 /tmp/mydir/base.iso,同时将dist/driver-2.6.18.iso 保存成 /tmp/dir/driver.iso
aria2c --dir=/tmp --index-out=1=mydir/base.iso --index-out=2=dir/driver.iso file.torrent
注:当对http uri中的torrent文件使用–index-out是不成功,它只对本地的torrent文件有效。aria2也不会去记忆–index-out选项内容,在每次的继续下载或播种时都需要手工指明,而且如果没有该选项,它也不会给用户任何提醒,所以需要注意。
为进行文件预览进行分片优先下载
优先下载torrent中所有文件的前1MB
aria2c --bt-prioritize-piece=head file.torrent
##使用代理服务器
为所有协议(HTTP(S)/FTP)设定代理服务器
aria2c --all-proxy='http://proxy:8080' http://host/file
注:–all-proxy选项可以被特定的协议选项覆盖,如–http-proxy, –https-proxy 和 –ftp-proxy
设置http代理
aria2c --http-proxy='http://proxy:8080' http://host/file
使用需要认证的代理
aria2c --http-proxy='http://proxy:8080' --http-proxy-user='username' --http-proxy-passwd='password' http://host/file
aria2c --http-proxy='http://username:password@proxy:8080' http://host/file
注:username and password 需要进行%转码,如过username是’myid@domain’,则转码后的结果为:’myid%40domain’。
高级的http特性:
导入cookie
导入Mozilla/Firefox(1.x/2.x) 和 Netscape格式的cookie
aria2c --load-cookies=cookies.txt http://host/file
导入Firefox3格式的cookie
aria2c --load-cookies=cookies.sqlite http://host/file
被浏览器或其他程序继续下载
aria2c -c -s2 http://host/partiallydownloadedfile.zip
其他高级特性
下载速度限制
aria2c --max-download-limit=100K http://host/file
使用-V修复受损的下载
aria2c -V file.metalink
注:这个选项只适用于BitTorrent或者带有校验的metalink
当下载速度下于某个特定值时放弃下载
aria2c --lowest-speed-limit=10K file.metalink
URI的参数化支持
可以使用大括号来表达一组列表
aria2c -P http://{host1,host2,host3}/file.iso
可以使用[]来表示一个数字序列
aria2c -Z -P http://host/image[000-100].png
注:当所有的URI指向不同的文件时,需要使用-Z选项
甚至可以指定步长
aria2c -Z -P http://host/image[A-Z:2].png
时间戳
保留源文件时间戳
aria2c -R http://host/file.iso
下载完成后执行特定命令
aria2c --on-download-complete=COMMAND http://example.org/file.iso
另见:–on-download-error
, –on-download-start
和 –on-download-stop
,或者执行aria2c -h#hook
写入/dev/null
aria2c -d /dev -o null --allow-overwrite=true http://example.org/file
–allow-overwrite=true
是为了避免aria2重命名已有的/dev/null
输入文件
输入文件中可以包括一系列的URI地址,也可以针对同一个资源设置多个URI:不同的URI写在一行并使用tab分割。
输入文件的每一行都被当作aria2的命令行参数,因此可以受到-Z和-P选项影响
另外,选项也可以在每行URI的后面设置,更详尽的描述可以在man page的输入文件部分得到。这种选择的含义与命令行选项的含义一致,不过只适用在他们跟随的那个URI上。
如下,一个uri文件名为uri.txt,其内容如下:
http://server/file.iso http://mirror/file.iso
dir=/iso_images
out=file.img
http://foo/bar
如果aria2使用 -i uri.txt -d /tmp
,
那么file.iso就会被保存为/iso_images/file.img,
它的下载源为http://server/file.iso 和 http://mirror/file.iso ;
而bar文件则是从http://foo/bar 下载并且保存为 /tmp/bar
*[uri]: 远程或者本地文件地址