Setting up a Mirror
This page is a WIP, please join our Discord for more updates!
In the context of Linux package management, a mirror refers to a server or repository that contains a copy of software packages and related metadata from another source, typically an official distribution server. The primary purpose of mirrors is to provide users with alternative, geographically distributed locations from which they can download software packages.
Definition
There are different mirror synchronization protocols deployed for different purposes and used for different types of content. The following definitions are not related to the protocol used to retrieve and install packages on the endpoint of the user, but they are related to the protocols used to synchronize mirrors each other.
Rsync
- Purpose: a rsync mirror is commonly used for mirroring files and directories, such as Linux distribution packages or other large datasets.
- Setup: the rsync command is used to synchronize files between servers. A basic example is
rsync -a source/ destination/
. - Usage: rsync mirrors are often set up to regularly synchronize with the upstream source to ensure the mirror remains up to date.
Git
- Purpose: a Git mirror is often used for version control systems, allowing users to clone, fetch, and push changes to a repository.
- Setup: to create a Git mirror, you can use the
--mirror
option withgit clone
. This option ensures that all remote branches and tags are mirrored. - Usage: users can clone from the Git mirror, and the mirror can periodically synchronize with the upstream repository using
git fetch --all --prune
.
HTTP/HTTPS
- Purpose: HTTP or HTTPS servers can serve as mirrors for distributing files, packages, or software updates.
- Setup: configure the server to host the files, and users can download them using a web browser or tools like
wget
orcurl
. - Usage: users can download files by navigating to the server’s URL using a web browser. Alternatively, they can use command-line tools like
wget
orcurl
to retrieve files.
FTP
- Purpose: FTP servers can also be used to mirror files, and users can access them using FTP clients.
- Setup: similar to HTTP servers, configure the FTP server to host the files for distribution.
- Usage: users can access the FTP server using FTP clients such as
ftp
or graphical FTP clients.
When creating a mirror, consider the specific needs of the content you are mirroring and choose the appropriate server type accordingly. Additionally, ensure that your mirroring process includes regular synchronization with the upstream source to keep the mirror up to date.
Axyl Projects Mirrors
At the beginning, Arch-based Axyl Projects synchronized mirrors by git protocol but it was not suitable for package mirroring for the nature of git usage. One suitable option to consider has been rsync protocol.
Rsync
- Efficiency: Rsync is designed for efficient file synchronization. It only transfers the differences between files, making it bandwidth-friendly and quick.
- Ease of Use: Rsync is straightforward to set up and use. It’s a common choice for mirroring tasks and is widely supported.
- Network Usage: Rsync is generally more bandwidth-efficient, as it only transfers the parts of files that have changed.
- Incremental Updates: Rsync excels at incremental updates, ensuring that only the changes are transferred, saving time and resources.
Git
- Versioning: Git provides versioning, allowing you to track changes over time. This can be beneficial if you need to audit or understand the history of the repository.
- Ease of Collaboration: Git is a distributed version control system, which can be advantageous if you have multiple contributors or if you want to collaborate with others on managing the mirrored repository.
- Branching and Merging: Git supports branching and merging, enabling you to experiment with changes before applying them to the main repository.
- Granular Control: Git provides more granular control over what parts of the repository you want to mirror. You can clone specific branches or tags, which can be useful for selectively mirroring only the components you need.
Considerations Rsync vs. Git
Type of Repository
- Rsync: best for simple mirroring tasks where you just need the latest version of files.
- Git: useful for scenarios where versioning, collaboration, and granular control are important.
Bandwidth
- Rsync: generally more bandwidth-efficient.
- Git: can consume more bandwidth, especially if you need the entire version history.
Complexity
- Rsync: simple and effective for basic mirroring tasks.
- Git: adds complexity, but offers powerful version control features.
Storage
- Rsync: requires less storage space as it only transfers differences.
- Git: can consume more storage space, especially if you mirror the entire version history.
In conclusion, rsync is often the more straightforward and bandwidth-friendly choice. If versioning, collaboration, and granular control are important, git may be a better fit. So, for a package repository, rsync should be the most suitable choice.
Setting up a mirror server
The purpose of this guide is to set a mirror for Axyl Projects ISO images and Axyl Projects Arch packages. In Axyl Projects Nix there is no need to mirror packages because package mirror system is not used on Nix environment.
It is assumed that you own a server (i.e., you subscribed a VPS (Virtual Private Server) service) complying the specified requirements.
Requirements
- CPU: >= 4 cores
- RAM: >= 8 GB
- Storage: the Axyl Projects repository size is around 5 GB, so you can set at least x3 repository size as server storage
- Bandwidth: >= 1 Gbps
- Operating System: Arch Linux, Debian, Ubuntu (or any Linux distro you wish)
- Backup: snapshots at regular interval
- Performance optimization: CDN, caching, compression
- Monitoring: centralized monitoring system of mirrors to check server resources and ensure reliability
- Dependencies:
rsync
,cron
,nginx
,certbot
- Protocol used for mirroring:
rsync
- Protocol used to expose mirror server to the final users:
HTTP/HTTPS
- Mirroring synchronization strategy: Pull
- Sync Time: <= 6 hours
Firewall Setting
If your network is restricted, ensure that the following connections are allowed:
Protocol | Port | Domain Name | IP Address |
---|---|---|---|
Rsync | 873/TCP | hub.Axyl Projectsos.org | 89.116.236.99 |
Publish
Finally, to be deployed to all users, your mirror must be added communicated to Axyl Projects Team in order to be added in the official Axyl Projects mirrorlist.
Send the following information to keeper@Axyl Projectsos.org:
- public hostname
- scheduled sync time
- email to inform you in case we make changes on mirroring design
Once Axyl Projects Team accepts your request, you will be informed your mirror has been added on Axyl Projects mirrorlist.