Difference between revisions of "Mirrors"
(add related) |
m (→Choosing a local mirror: Spelling correction and minor formatting.) |
||
(33 intermediate revisions by 21 users not shown) | |||
Line 1: | Line 1: | ||
− | [[Category:About Arch]] [[Category:Package management]] | + | [[Category:About Arch]] |
+ | [[Category:Package management]] | ||
+ | [[ar:Mirrors]] | ||
[[es:Mirrors]] | [[es:Mirrors]] | ||
[[fr:Miroirs]] | [[fr:Miroirs]] | ||
[[it:Mirrors]] | [[it:Mirrors]] | ||
+ | [[ja:Mirrors]] | ||
[[zh-CN:Mirrors]] | [[zh-CN:Mirrors]] | ||
{{Article summary start|Summary}} | {{Article summary start|Summary}} | ||
Line 17: | Line 20: | ||
To enable mirrors, open {{ic|/etc/pacman.d/mirrorlist}} and locate your geographic region. Uncomment mirrors you would like to use. | To enable mirrors, open {{ic|/etc/pacman.d/mirrorlist}} and locate your geographic region. Uncomment mirrors you would like to use. | ||
− | {{Note | ftp.archlinux.org is [ | + | {{Note | ftp.archlinux.org is [https://www.archlinux.org/news/throttling-ftparchlinuxorg-rsyncarchlinuxorg/ throttled at 50KB/s].}} |
+ | Example: | ||
# Any | # Any | ||
Line 39: | Line 43: | ||
{{Note|If mirrors have been stated directly in {{ic|pacman.conf}}, remember to use the same mirror for all repositories. Otherwise packages that are incompatible to each other may be installed, like linux from ''[core]'' and an older kernel module from ''[extra]''.}} | {{Note|If mirrors have been stated directly in {{ic|pacman.conf}}, remember to use the same mirror for all repositories. Otherwise packages that are incompatible to each other may be installed, like linux from ''[core]'' and an older kernel module from ''[extra]''.}} | ||
+ | |||
+ | === Force pacman to refresh the package lists === | ||
+ | After creating/editing {{ic|/etc/pacman.d/mirrorlist}}, (manually or by using {{Ic|rankmirrors}}) issue the following command: | ||
+ | # pacman -Syy | ||
+ | |||
+ | {{Tip|Passing two {{Ic|--refresh}} or {{Ic|-y}} flags forces pacman to refresh all package lists even if they are considered to be up to date. Issuing {{Ic|pacman -Syy}} ''whenever changing to a new mirror'' is good practice and will avoid possible issues.}} | ||
==Mirror status== | ==Mirror status== | ||
− | Check the status of the Arch mirrors and how updated they are by visiting http://www.archlinux.de/?page=MirrorStatus or | + | Check the status of the Arch mirrors and how updated they are by visiting http://www.archlinux.de/?page=MirrorStatus or https://www.archlinux.org/mirrors/status/. |
− | You can generate an up to date mirrorlist [ | + | You can generate an up to date mirrorlist [https://www.archlinux.org/mirrorlist/ here], automate the process with a [[#Script to automate use of Pacman Mirrorlist Generator|script]], or install [[Reflector]], a utility that generates a mirrorlist using Mirrorcheck's list; you can also manually check how up-to-date a mirror is by: |
#picking a server and browsing to "extra/os/"; | #picking a server and browsing to "extra/os/"; | ||
− | #accessing | + | #accessing https://www.archlinux.org/ in another browser tab or window; and |
#comparing the last-modified date of the {{ic|i686}} directory on the mirror to the ''[extra]'' date on the homepage, in the ''Package Repositories'' box to the right. | #comparing the last-modified date of the {{ic|i686}} directory on the mirror to the ''[extra]'' date on the homepage, in the ''Package Repositories'' box to the right. | ||
==Sorting mirrors== | ==Sorting mirrors== | ||
− | If not using reflector, which has the ability to sort mirrors by both how updated they are and their speed, follow this demonstration of manual mirror sorting. | + | When downloading packages pacman uses the mirrors in the order they are in {{ic|/etc/pacman.d/mirrorlist}}. If not using reflector, which has the ability to sort mirrors by both how updated they are and their speed, follow this demonstration of manual mirror sorting. |
+ | |||
+ | {{Note|This does not apply to [[Improve_Pacman_Performance#Using_powerpill-light | powerpill-light]], which connects to many servers simultaneously to increase the overall download speed. The speed of individual connections becomes less relevant, and powerpill-light can be configured to require minimum speeds per connection.}} | ||
===List by speed=== | ===List by speed=== | ||
+ | |||
Take full advantage of using the fastest local mirror, which can be determined via the included Bash script, {{ic|/usr/bin/rankmirrors}}. | Take full advantage of using the fastest local mirror, which can be determined via the included Bash script, {{ic|/usr/bin/rankmirrors}}. | ||
Line 66: | Line 79: | ||
Run {{Ic|rankmirrors -h}} for a list of all the available options. | Run {{Ic|rankmirrors -h}} for a list of all the available options. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
===Combined listing by speed and status=== | ===Combined listing by speed and status=== | ||
Line 80: | Line 87: | ||
When having mirror issues the above should be repeated. Or repeat once in a while even if not having mirror problems, to keep {{ic|/etc/pacman.d/mirrorlist}} up to date. | When having mirror issues the above should be repeated. Or repeat once in a while even if not having mirror problems, to keep {{ic|/etc/pacman.d/mirrorlist}} up to date. | ||
− | === Script to | + | === Script to download from Mirrorlist Generator === |
− | + | The following shell script can be used to create a mirror list based on the rankings produced by the [https://www.archlinux.org/mirrorlist/ Pacman Mirrorlist Generator] (the country variable will need to be changed if not living in the United States). It can be downloaded by invoking: {{ic|<nowiki>curl http://pastebin.ca/raw/2404700 -o pacmrr</nowiki>}}, ([http://pastebin.ca/2404700 view script]). | |
− | + | ===Using Reflector=== | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | Alternatively, you can use [[Reflector]] to automatically retrieve the latest mirrorlist from the [https://www.archlinux.org/mirrors/status/ MirrorStatus] page, filter the most up-to-date mirrors, sort them by speed and overwrite the file {{ic|/etc/pacman.d/mirrorlist}}. | |
− | + | === Choosing a local mirror === | |
− | + | The simple way is to edit mirrorlist file by placing a local mirror at the top of the list. pacman will then use this mirror for preference. | |
− | + | Alternatively {{ic|/etc/pacman.conf}} can be edited by placing a local mirror before the line sourcing the mirrorlist file, i.e. where it says "add your preferred servers here". It is safer if you use the same server for each repository. | |
− | { | ||
− | |||
− | { | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
==Official mirrors== | ==Official mirrors== | ||
Line 116: | Line 108: | ||
Be sure to uncomment a preferred mirror as described above, then: | Be sure to uncomment a preferred mirror as described above, then: | ||
# pacman -Syy | # pacman -Syy | ||
− | # pacman - | + | # pacman -S --force pacman-mirrorlist |
If you want your mirror to be added to the official list, file a feature request. In the meantime, add it to the [[#Unofficial mirrors]] list at the end of this page. | If you want your mirror to be added to the official list, file a feature request. In the meantime, add it to the [[#Unofficial mirrors]] list at the end of this page. | ||
Line 124: | Line 116: | ||
{{Note|You can also use the values {{Ic|auto}} and {{Ic|i686}} for the {{ic|Architecture}} variable.}} | {{Note|You can also use the values {{Ic|auto}} and {{Ic|i686}} for the {{ic|Architecture}} variable.}} | ||
+ | |||
+ | ===IPv6-ready mirrors=== | ||
+ | |||
+ | The [https://www.archlinux.org/mirrorlist/?country=all&protocol=http&ip_version=6 pacman mirror list generator] can also be used to find a list of current IPv6 mirrors. | ||
==Unofficial mirrors== | ==Unofficial mirrors== | ||
Line 129: | Line 125: | ||
===Global=== | ===Global=== | ||
− | * http://sourceforge.net/projects/archlinux/files/ - ''Does not have | + | * http://sourceforge.net/projects/archlinux/files/ - ''ISO files only; Does not have any releases since 2006. Use it only if for getting older ISOs.'' |
===TOR Network=== | ===TOR Network=== | ||
Line 154: | Line 150: | ||
'''Cernet''' | '''Cernet''' | ||
+ | *http://mirrors.zju.edu.cn/archlinux/ - "Zhejian University" | ||
*http://ftp.sjtu.edu.cn/archlinux/ - ''Shanghai Jiaotong University'' | *http://ftp.sjtu.edu.cn/archlinux/ - ''Shanghai Jiaotong University'' | ||
*ftp://ftp.sjtu.edu.cn/archlinux/ | *ftp://ftp.sjtu.edu.cn/archlinux/ | ||
Line 174: | Line 171: | ||
*ftp://ftp.u-tx.net/archlinux/ | *ftp://ftp.u-tx.net/archlinux/ | ||
*http://mirror.michael-eckert.net/archlinux/ | *http://mirror.michael-eckert.net/archlinux/ | ||
+ | *http://linux.rz.rub.de/archlinux/ | ||
===Indonesia=== | ===Indonesia=== | ||
Line 184: | Line 182: | ||
*http://mirror.neolabs.kz/archlinux/ | *http://mirror.neolabs.kz/archlinux/ | ||
*http://mirror-kt.neolabs.kz/archlinux/ | *http://mirror-kt.neolabs.kz/archlinux/ | ||
− | |||
− | |||
− | |||
===Malaysia=== | ===Malaysia=== | ||
Line 202: | Line 197: | ||
===Russia=== | ===Russia=== | ||
*http://hatred.homelinux.net/archlinux/ - ''Vladivostok, without iso, with <sub>[http://hatred.homelinux.net/wiki/proekty:3spy:start 3SPY]</sub> project repos and [http://hatred.homelinux.net/archlinux/mingw32/os/i686 '''mingw32'''] repo'' | *http://hatred.homelinux.net/archlinux/ - ''Vladivostok, without iso, with <sub>[http://hatred.homelinux.net/wiki/proekty:3spy:start 3SPY]</sub> project repos and [http://hatred.homelinux.net/archlinux/mingw32/os/i686 '''mingw32'''] repo'' | ||
+ | *http://mirrors.krasinfo.ru/archlinux/ - ''Krasnoyarsk, Classica-Service Ltd'' | ||
===South Africa=== | ===South Africa=== | ||
Line 212: | Line 208: | ||
*http://ftp.wa.co.za/pub/archlinux/ - ''Web Africa Networks'' | *http://ftp.wa.co.za/pub/archlinux/ - ''Web Africa Networks'' | ||
*ftp://ftp.wa.co.za/pub/archlinux/ | *ftp://ftp.wa.co.za/pub/archlinux/ | ||
− | *http://archlinux.mirror.ac.za - '' | + | *http://archlinux.mirror.ac.za - ''TENET - Tertiary Education and Research Network of South Africa'' |
*ftp://archlinux.mirror.ac.za | *ftp://archlinux.mirror.ac.za | ||
Line 219: | Line 215: | ||
* http://mirror.pointysoftware.net/archlinux/ | * http://mirror.pointysoftware.net/archlinux/ | ||
− | == | + | ===Hyperboria=== |
− | *http:// | + | * http://[fc7b:5f90:01f8:2b33:7c3e:f94b:00f3:0bed]/archlinux/ |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
==Troubleshooting== | ==Troubleshooting== |
Revision as of 07:49, 18 August 2013
zh-CN:Mirrors Template:Article summary start Template:Article summary text Template:Article summary heading Template:Article summary wiki Template:Article summary wiki Template:Article summary wiki Template:Article summary end
This page is a guide to selecting and configuring your mirrors, and a listing of current available mirrors.
Contents
Enabling a specific mirror
To enable mirrors, open /etc/pacman.d/mirrorlist
and locate your geographic region. Uncomment mirrors you would like to use.
Example:
# Any # Server = ftp://mirrors.kernel.org/archlinux/$repo/os/$arch Server = http://mirrors.kernel.org/archlinux/$repo/os/$arch
See #Mirror status and #List by speed for tools that help choosing mirrors.
It is also possible to specify mirrors in /etc/pacman.conf
. For the [core] repository, the default setup is:
[core] Include = /etc/pacman.d/mirrorlist
To use the HostEurope mirror as a default mirror, add it before the Include
line:
[core] Server = ftp://ftp.hosteurope.de/mirror/ftp.archlinux.org/core/os/$arch Include = /etc/pacman.d/mirrorlist
pacman will now try to connect to this mirror first. Proceed to do the same for [testing], [extra], and [community], if applicable.
pacman.conf
, remember to use the same mirror for all repositories. Otherwise packages that are incompatible to each other may be installed, like linux from [core] and an older kernel module from [extra].Force pacman to refresh the package lists
After creating/editing /etc/pacman.d/mirrorlist
, (manually or by using rankmirrors
) issue the following command:
# pacman -Syy
--refresh
or -y
flags forces pacman to refresh all package lists even if they are considered to be up to date. Issuing pacman -Syy
whenever changing to a new mirror is good practice and will avoid possible issues.Mirror status
Check the status of the Arch mirrors and how updated they are by visiting http://www.archlinux.de/?page=MirrorStatus or https://www.archlinux.org/mirrors/status/.
You can generate an up to date mirrorlist here, automate the process with a script, or install Reflector, a utility that generates a mirrorlist using Mirrorcheck's list; you can also manually check how up-to-date a mirror is by:
- picking a server and browsing to "extra/os/";
- accessing https://www.archlinux.org/ in another browser tab or window; and
- comparing the last-modified date of the
i686
directory on the mirror to the [extra] date on the homepage, in the Package Repositories box to the right.
Sorting mirrors
When downloading packages pacman uses the mirrors in the order they are in /etc/pacman.d/mirrorlist
. If not using reflector, which has the ability to sort mirrors by both how updated they are and their speed, follow this demonstration of manual mirror sorting.
List by speed
Take full advantage of using the fastest local mirror, which can be determined via the included Bash script, /usr/bin/rankmirrors
.
Back up the existing /etc/pacman.d/mirrorlist
:
# cp /etc/pacman.d/mirrorlist /etc/pacman.d/mirrorlist.backup
Edit /etc/pacman.d/mirrorlist.backup
and uncomment mirrors for testing with rankmirrors
.
Optionally run the following sed
line to uncomment every mirror:
# sed '/^#\S/ s|#||' -i /etc/pacman.d/mirrorlist.backup
Finally, rank the mirrors. Operand -n 6
means only output the 6 fastest mirrors:
# rankmirrors -n 6 /etc/pacman.d/mirrorlist.backup > /etc/pacman.d/mirrorlist
Run rankmirrors -h
for a list of all the available options.
Combined listing by speed and status
It is not a good idea to just use the fastest mirrors, since the fastest mirrors might be out of date. The preferred way would be to use #List by speed, then sorting those 6 fastest mirrors by their #Mirror status.
Simply visit either one or both #Mirror status links and sort them by the ones that are more up to date. Move the more up to date mirrors to the top of /etc/pacman.d/mirrorlist
and if the mirrors are way out of date simply do not use those; repeat the process leaving out the outdated mirrors. So this ends up with a total of 6 mirrors that are sorted by speed and status, leaving out outdated mirrors.
When having mirror issues the above should be repeated. Or repeat once in a while even if not having mirror problems, to keep /etc/pacman.d/mirrorlist
up to date.
Script to download from Mirrorlist Generator
The following shell script can be used to create a mirror list based on the rankings produced by the Pacman Mirrorlist Generator (the country variable will need to be changed if not living in the United States). It can be downloaded by invoking: curl http://pastebin.ca/raw/2404700 -o pacmrr
, (view script).
Using Reflector
Alternatively, you can use Reflector to automatically retrieve the latest mirrorlist from the MirrorStatus page, filter the most up-to-date mirrors, sort them by speed and overwrite the file /etc/pacman.d/mirrorlist
.
Choosing a local mirror
The simple way is to edit mirrorlist file by placing a local mirror at the top of the list. pacman will then use this mirror for preference.
Alternatively /etc/pacman.conf
can be edited by placing a local mirror before the line sourcing the mirrorlist file, i.e. where it says "add your preferred servers here". It is safer if you use the same server for each repository.
Official mirrors
The official Arch Linux mirror list is available from the pacman-mirrorlist package. To get an even more up-to-date list of mirrors, use the Pacman Mirror List Generator page on the main site.
In the unlikely scenario that you are without any configured mirrors and pacman-mirrorlist
is not installed, run the following command:
# wget -O /etc/pacman.d/mirrorlist https://www.archlinux.org/mirrorlist/all/
Be sure to uncomment a preferred mirror as described above, then:
# pacman -Syy # pacman -S --force pacman-mirrorlist
If you want your mirror to be added to the official list, file a feature request. In the meantime, add it to the #Unofficial mirrors list at the end of this page.
If you get an error stating that the $arch
variable is used but not defined, add the following to your /etc/pacman.conf
:
Architecture = x86_64
auto
and i686
for the Architecture
variable.IPv6-ready mirrors
The pacman mirror list generator can also be used to find a list of current IPv6 mirrors.
Unofficial mirrors
These mirrors are not listed in /etc/pacman.d/mirrorlist
.
Global
- http://sourceforge.net/projects/archlinux/files/ - ISO files only; Does not have any releases since 2006. Use it only if for getting older ISOs.
TOR Network
Singapore
Bulgaria
Viet Nam
FPT TELECOM
China
CHINA TELECOM
CHINA UNICOM
Cernet
- http://mirrors.zju.edu.cn/archlinux/ - "Zhejian University"
- http://ftp.sjtu.edu.cn/archlinux/ - Shanghai Jiaotong University
- ftp://ftp.sjtu.edu.cn/archlinux/
- http://mirrors.ustc.edu.cn/archlinux/ - University of Science and Technology of China
- ftp://mirrors.ustc.edu.cn/archlinux/
- http://mirrors.tuna.tsinghua.edu.cn/archlinux/ - Tsinghua University
- http://mirrors.4.tuna.tsinghua.edu.cn/archlinux/ (ipv4 only)
- http://mirrors.6.tuna.tsinghua.edu.cn/archlinux/ (ipv6 only)
- http://mirror.lzu.edu.cn/archlinux/ - Lanzhou University
France
- http://delta.archlinux.fr/ - With Delta package support. Needs xdelta3 package from extra to run.
- http://mirror.soa1.org/archlinux
- ftp://mirror:mirror@mirror.soa1.org/archlinux
Germany
- http://ftp.uni-erlangen.de/mirrors/archlinux/
- ftp://ftp.uni-erlangen.de/mirrors/archlinux/
- http://ftp.u-tx.net/archlinux/
- ftp://ftp.u-tx.net/archlinux/
- http://mirror.michael-eckert.net/archlinux/
- http://linux.rz.rub.de/archlinux/
Indonesia
- http://mirror.kavalinux.com/archlinux/ - only from Indonesia
- http://kambing.ui.ac.id/archlinux/
- http://repo.ukdw.ac.id/archlinux/
Kazakhstan
Malaysia
New Zealand
Poland
- ftp://ftp.icm.edu.pl/pub/Linux/dist/archlinux/ - ICM UW
- http://ftp.icm.edu.pl/pub/Linux/dist/archlinux/ - ICM UW
- rsync://ftp.icm.edu.pl/pub/Linux/dist/archlinux/ - ICM UW
Russia
- http://hatred.homelinux.net/archlinux/ - Vladivostok, without iso, with 3SPY project repos and mingw32 repo
- http://mirrors.krasinfo.ru/archlinux/ - Krasnoyarsk, Classica-Service Ltd
South Africa
- http://ftp.sun.ac.za/ftp/pub/mirrors/archlinux/ - Stellenbosch University
- ftp://ftp.sun.ac.za/pub/mirrors/archlinux/
- http://ftp.leg.uct.ac.za/pub/linux/arch/ - University of Cape Town
- ftp://ftp.leg.uct.ac.za/pub/linux/arch/
- http://mirror.ufs.ac.za/archlinux/ - University of the Free State
- ftp://mirror.ufs.ac.za/os/linux/distros/archlinux/
- http://ftp.wa.co.za/pub/archlinux/ - Web Africa Networks
- ftp://ftp.wa.co.za/pub/archlinux/
- http://archlinux.mirror.ac.za - TENET - Tertiary Education and Research Network of South Africa
- ftp://archlinux.mirror.ac.za
United States
- http://archlinux.linuxfreedom.com - Contains numerous ISO images but does not contain the ISO dated 2011.08.19
- http://mirror.pointysoftware.net/archlinux/
Hyperboria
Troubleshooting
Out-of-sync mirrors: corrupted packages/file not found
Issues regarding out-of-sync mirrors pointed out in this news post may have already been sorted out for most users, but in the event that problems of this nature present themselves again, simply try to see if the packages are present in the [testing] repository.
After having synced with pacman -Sy
, use this command:
# pacman -Ud $(pacman -Sup | tail -n +2 | sed -e 's,/\(core\|extra\)/,/testing/,' \ -e 's,/\(community\)/,/\1-testing/,')
Doing so could help in any occasion where packages in the mirror have not been synced to [core] or [extra], and are still residing in [testing]. It is perfectly safe to install from [testing] in this case since the packages are being matched by version and release numbers.
In any event, it is best to switch mirrors and sync with pacman -Syy
than resorting to an alternate repository. However, all or some of the mirrors may at times be out-of-sync to some degree.
Using all mirrors
To emulate pacman -Su
's behavior of going through the entire mirror list, use this script:
~/bin/pacup
#!/bin/bash # Pacman will not exit on the first error. Comment the line below to # try from [testing] directly. pacman -Su "$@" && exit while read -r pkg; do if pacman -Ud "$pkg"; then continue else while read -r mirror; do pacman -Ud $(sed "s,.*\(/\(community-\)*testing/os/\(i686\|x86_64\)/\),$mirror\1," <<<"$pkg") && break done < <(sed -ne 's,^ *Server *= *\|/$repo/os/\(i686\|x86_64\).*,,gp' \ </etc/pacman.d/mirrorlist | tail -n +2 ) fi done < <(pacman -Sup | tail -n +2 | sed -e 's,/\(core\|extra\)/,/testing/,' \ -e 's,/\(community\)/,/\1-testing/,')
See Also
- MirUp – pacman mirrorlist downloader/checker