Skip to main content

apt-mirror Python reimplementation

Project description

apt-mirror2

apt-mirror2 is the Python/asyncio reimplementation of the apt-mirror - an apt sources mirroring tool.
This project is intended to be a general drop-in apt-mirror replacement.

One of the main advantages of the apt-mirror2 over the apt-mirror is that it never leaves a broken mirror behind, provided it exits with code 0. This is ensured by data integrity checks at all stages of mirroring.

Requirements

Python 3.10 is the minimum supported version. PyPy 3.10 (7.3) is also supported.
For additional dependencies, please refer to the pyproject.toml and/or requirements.txt.

Installation

Container (Docker/Podman)

Container images are available in the Docker Hub under aptmirror/apt-mirror2 repository and in the Red Hat Quay.io under apt-mirror2/apt-mirror2 repository.

Supported architectures: amd64, arm64v8.

You can try them using

docker run -it --rm docker.io/aptmirror/apt-mirror2 --help

or

docker run -it --rm quay.io/apt-mirror2/apt-mirror2 --help

You may wish to use podman command instead of docker.

Image variants

aptmirror/apt-mirror2:latest

aptmirror/apt-mirror2:<version>

Images based on debian:stable image.

aptmirror/apt-mirror2:slim

aptmirror/apt-mirror2:<version>-slim

Images based on debian:stable-slim image.

aptmirror/apt-mirror2:alpine

aptmirror/apt-mirror2:<version>-alpine

Images based on alpine:3 image.

PyPI

PyPI package is available under the name apt-mirror:

pip install apt-mirror
apt-mirror --help

Distro packages

Packaging status

Debian

apt-mirror2 is available in the Debian Unstable (sid). Please note that as of now, apt-mirror2 does not replace apt-mirror in the Debian and thus package provides apt-mirror2 executable and /etc/apt/mirror2.list configuration file.

Packagecloud builds

Debian (bookworm, trixie) and Ubuntu (22.04, 24.04) packages are available in the Packagecloud repository.

Quick automated repository setup:

curl -s https://packagecloud.io/install/repositories/nE0sIghT/apt-mirror2/script.deb.sh | sudo bash

Package installation:

sudo apt-get install apt-mirror2

For manual steps, please refer to the Packagecloud repository.

Build from source with virtualenv

It's possible to use apt-mirror2 from a virtualenv:

# Let's work in the home folder
cd

# Create virtualenv
virtualenv ~/venv/apt-mirror2
source ~/venv/apt-mirror2/bin/activate

# Clone apt-mirror2 source code
git clone https://gitlab.com/apt-mirror2/apt-mirror2
cd apt-mirror2

# Install requirements
pip install -r requirements.txt

# Install apt-mirror2 into virtualenv
python setup.py install

apt-mirror --help

Usage

As the drop-in replacement for the apt-mirror, this project supports same CLI syntax.

usage: apt-mirror [-h] [--version] [configfile]

positional arguments:
  configfile  Path to config file. Default /etc/apt/mirror.list

options:
  -h, --help  show this help message and exit
  --version   Show version

apt-mirror compatibility

Most of apt-mirror configuration directives are supported.
As of now proxy for FTP repositories is not supported.

File lists (ALL, NEW, MD5, SHA256, SHA512) are not written by default, but you can enable them with the write_file_lists option.

In addition there are some enhancements available:

  • Non-zero exit code is returned if some of required files were not downloaded due to network or server errors or no repositories were configured.
  • Flexible support for filtering by package name, source name, section, or Debtags
  • Optional Release files GPG signature verification
  • Repositories lacking MD5 hashes are correctly mirrored
  • Old index files are properly cleaned and don't produce errors during the mirror processing
  • Standard sources.list [ arch=arch1,arch2 ] can be used to specify multiple repository architectures for mirroring.
  • Multiple codenames (or flat folders) can be specified using comma as delimiter.
  • mirror_path URL PATH option may be used to specify PATH to use for saving mirror files instead of the path that is generated from URL.
  • Additional configurations are loaded from the *.list files in the directory named the same as the configfile with the .d suffix. Eg /etc/apt/mirror.list.d/*.list.
  • Rate limit is enforced for overall download rate.
  • Slow download rate protection is enabled by default and can be configured via mirror.list.
  • HTTP user agent can be configured via user_agent configuration.
  • Configuration variables are exposed to the postmirror_script.
  • by-hash list option can be used to control whether Acquire-By-Hash Release option should be respected or enforced.
  • Mirror wipe protection is available and configurable via wipe_size_ratio and wipe_count_ratio settings.
  • Per-repository log files are available in the var_path folder
  • The dists folder is replaced almost atomically using move instead of copy/link
  • Native Prometheus metrics are supported

Deb822-style format

apt-mirror2 has supported the newer deb822 format since version 15.

While global settings still have to be specified in your mirror.list file, apt-mirror2 reads *.sources files from a drop-in directory (mirror.list.d if your main configuration file is named mirror.list).

All per-repository options are supported with underscores _ replaced by dashes - and all words written in CamelCase. For example, the option exclude_binary_packages becomes Exclude-Binary-Packages.

See the mirror.sources file for detailed information.

Common problems

LocalProtocolError: Max outbound streams is n, n open

This warning may appear with HTTP2 mirrors when you have too much nthreads configured. You may either lower nthreads value or disable http2 via http2-disable option. As of now, apt-mirror2 has no control over HTTP2 concurrent streams value used by httpx/h2 client, but does limit the count of simultaneously downloaded files (which can still exceed maximum outbound streams due to unknown reasons).

RuntimeError: can't start new thread

Long story short: upgrade Docker.

Look to this issue for more solutions.

dists folder is missing after running apt-mirror2

This is usually a result of errors in your source mirror. You should see some warnings either about missing files in the source or problems with metadata files. There should be a Metadata movement skipped because of download errors message in the log file and apt-mirror2 should exit with non-zero code.

You could try to change your mirror source, report this problem to the mirror owner, or increase the timeouts in your mirror.list.

License

GNU General Public License v3.0 or later

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

apt_mirror-15.tar.gz (621.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

apt_mirror-15-py3-none-any.whl (71.1 kB view details)

Uploaded Python 3

File details

Details for the file apt_mirror-15.tar.gz.

File metadata

  • Download URL: apt_mirror-15.tar.gz
  • Upload date:
  • Size: 621.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for apt_mirror-15.tar.gz
Algorithm Hash digest
SHA256 13c7f3ceabcd1cc96e4da2a8573093bf7fe682f7cdb4e89492b940a386db0944
MD5 227319dd8a0cbf36613b0e70f4d0b344
BLAKE2b-256 7ea567a2eac47b11861668dc27dff1dee869a997dd59874d16b67cdc78e2ebfa

See more details on using hashes here.

File details

Details for the file apt_mirror-15-py3-none-any.whl.

File metadata

  • Download URL: apt_mirror-15-py3-none-any.whl
  • Upload date:
  • Size: 71.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for apt_mirror-15-py3-none-any.whl
Algorithm Hash digest
SHA256 d4d8ce4c50c2dc0cc3becbca4ad176d980c814da5f3d6434ffa3336ac619e2d6
MD5 2a843dcc839e3a99a8056b2c8362d977
BLAKE2b-256 bc445a1b6e270218e899425aba63cc8dd61d3fd155ac51e724ab9ef21ce1eefe

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page