Skip to main content

A modern Python implementation of the tool for mirroring the Sisyphus repository.

Project description

English | Русский

A modern Python implementation of the tool for mirroring the Sisyphus repository.

The project is inspired by the original utility sisyphus-mirror.

Technical Requirements

  • GNU/Linux OS

  • Python 3.12+

  • RSync 3.2+

  • 110+ GB of free disk space

Installation

# Create dedicated user and directories:
useradd -rMU -d /opt/sisyphus-mirror -s /usr/sbin/nologin sisyphus-mirror
mkdir -p /etc/sisyphus-mirror /opt/sisyphus-mirror /srv/mirrors/altlinux
chown sisyphus-mirror:sisyphus-mirror /opt/sisyphus-mirror
chown sisyphus-mirror:sisyphus-mirror /srv/mirrors/altlinux

# Create Python virtual environment and install the package:
sudo -u sisyphus-mirror python3 -m venv /opt/sisyphus-mirror/venv
sudo -u sisyphus-mirror /opt/sisyphus-mirror/venv/bin/pip install sisyphus-mirror

# Add command
ln -s /opt/sisyphus-mirror/venv/bin/sisyphus-mirror /usr/local/sbin/sisyphus-mirror

# Create TOML configuration file:
echo '[sisyphus-mirror]
dry_run = false
verbose = false
debug = false

# Explicitly defined repository branches.
branch_list = ["p11"]

# Repository source URL.
source_url = "rsync://ftp.altlinux.org/ALTLinux"

# Working directory for snapshots and temporary synchronization data.
working_dir = "/srv/mirrors/altlinux"

# Target CPU architectures.
arch_list = ["noarch", "x86_64", "x86_64-i586"]

# Additional file include patterns.
include_files = ["list/**", ".timestamp"]

# Additional file exclude patterns.
exclude_files = ["*debuginfo*", "SRPMS"]

# Maximum number of snapshots per branch.
snapshot_limit = 1

# Limiting network I/O bandwidth.
rate_limit = "5m"

# Connection timeout (seconds).
conn_timeout = 60

# I/O timeout (seconds).
io_timeout = 600' > /etc/sisyphus-mirror/default.toml

Modify configuration if needed:

nano /etc/sisyphus-mirror/default.toml

Test Run

Dry-run synchronization with detailed output:

sudo -u sisyphus-mirror sisyphus-mirror --dry-run --verbose

Ensure that the reported total size fits the available disk space.

Production Run

Actual synchronization:

sudo -u sisyphus-mirror sisyphus-mirror

Systemd Integration

# systemd service unit:
echo '[Unit]
Description=sisyphus-mirror service
Wants=sisyphus-mirror.timer

[Service]
Type=oneshot
User=sisyphus-mirror
Group=sisyphus-mirror
WorkingDirectory=/opt/sisyphus-mirror
ExecStart=sisyphus-mirror
ProtectHome=true
ProtectSystem=true
SyslogIdentifier=sisyphus-mirror

[Install]
WantedBy=multi-user.target' > /etc/systemd/system/sisyphus-mirror.service

# Daily timer:
echo '[Unit]
Description=Periodic run of sisyphus-mirror

[Timer]
# Run at a random time between 00:15 and 07:45 local server time
OnCalendar=*-*-* 00:15:00
RandomizedDelaySec=7h 30min
Persistent=true
Unit=sisyphus-mirror.service

[Install]
WantedBy=timers.target' > /etc/systemd/system/sisyphus-mirror.timer

# Reloading systemd configuration and activating the timer:
systemctl daemon-reload
systemctl enable --now sisyphus-mirror.timer

Serving via rsyncd

Example for a previously unconfigured rsync installation:

echo 'port = 873
uid = 65534
gid = 65534
use chroot = yes
max connections = 30

[altlinux]
path = /srv/mirrors/altlinux
read only = yes
list = yes' > /etc/rsyncd.conf

systemctl enable rsync
systemctl restart rsync

Serving via Nginx

Example for a previously unconfigured Nginx installation:

echo 'server {
  listen 80 default_server;
  listen [::]:80 default_server;
  server_name _;
  location /altlinux/ {
      alias /srv/mirrors/altlinux/;
      index off;
      autoindex on;
      autoindex_exact_size off;
      autoindex_localtime on;
      try_files $uri $uri/ =404;
  }
}' > /etc/nginx/sites-available/altlinux

rm /etc/nginx/sites-enabled/default
ln -s /etc/nginx/sites-available/altlinux /etc/nginx/sites-enabled/altlinux

systemctl enable nginx
systemctl restart nginx

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

sisyphus_mirror-1.1.0.tar.gz (14.0 kB view details)

Uploaded Source

Built Distribution

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

sisyphus_mirror-1.1.0-py3-none-any.whl (13.0 kB view details)

Uploaded Python 3

File details

Details for the file sisyphus_mirror-1.1.0.tar.gz.

File metadata

  • Download URL: sisyphus_mirror-1.1.0.tar.gz
  • Upload date:
  • Size: 14.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.7

File hashes

Hashes for sisyphus_mirror-1.1.0.tar.gz
Algorithm Hash digest
SHA256 99bbcc7124c35c29f8933319ada775c3f3371adc6803fab916246ff6cf32ccde
MD5 e6afada09dd8cac9524abfd25709d848
BLAKE2b-256 e21d5ffd8637265922d233c00ac8210a0c36a639e9800f363658660c9e762b02

See more details on using hashes here.

File details

Details for the file sisyphus_mirror-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for sisyphus_mirror-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 70e6a5385e978d0eb72cf2e8c41516df06dcb9da05ebd203bfca4185a905ba91
MD5 89202a17bd7680dddc028a531672020f
BLAKE2b-256 1013b5178b2d0e93456511218ce629d21f81096050be3445064ce4694d83cce5

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