Skip to main content

Mirroring tool that implements the client (mirror) side of PEP 381

Project description

This application implements a PyPI mirror application according to PEP 381.

Installation

It is possible to run this application directly from the source distribution. Alternatively, ‘python setup.py install’ could be used.

The actual mirroring is performed by the pep381run script, which should be invoked through cron like this:

*/15 *  *   *   *     /path/pep381client/pep381run -q /var/pypi

The command line arguments points to root of the data files that the mirror creates. An initial run (without the -q option) should be performed manually. It is possible to interrupt the mirroring; it will automatically know where to continue when restarted.

In above example, /var/pypi/web must be served through the webserver. An Apache configuration could read like this:

<VirtualHost IPADDRESS:80>
  ServerName X.pypi.python.org
  CustomLog /var/log/apache2/pypi.log combined
  DocumentRoot /var/pypi/web
  SetEnv PYPITARGET /var/pypi
  ScriptAlias /sync /path/pep381sync.cgi
</VirtualHost>

Notice that supporting the sync URL requires that the web server user has access to the mirror data, or else that the CGI script runs as the mirror user.

To propagate the download statistics back to the central server, processlogs must be run regularly, e.g. through:

10 7  *   *   *     /path/pep381client/processlogs /var/pypi /var/log/apache2/pypi.log{,.1}

Contact

If you have questions or comments, please submit a bug report to http://bitbucket.org/loewis/pep381client/issues/new, or contact me at martin@v.loewis.de

Changes

1.4 (2011-04-27):

  • Improve installation procedure (Jannis Leidel)

  • Add support for alternative storage backends (Jacob Kaplan-Moss)

  • Print nicer message for Ctrl-C (Jacob Kaplan-Moss)

  • Add –help option to pep381run (Horst Gutmann)

  • Drop mvindex again

  • Add support for master-initiated sync operations

  • Hotfix processing of empty project names

1.3 (2010-07-06):

  • The individual index pages where put into the wrong location; this is now fixed. Users should run ‘mvindex /var/pypi’ to fix their mirrors.

1.2 (2010-07-06):

  • Fix #1 for good.

1.1 (2010-07-05):

  • Issue #1: properly setup sqlite connection when initializing mirror.

1.0 (2010-07-05):

  • Initial release

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

pep381client-1.4.tar.gz (8.8 kB view details)

Uploaded Source

File details

Details for the file pep381client-1.4.tar.gz.

File metadata

  • Download URL: pep381client-1.4.tar.gz
  • Upload date:
  • Size: 8.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for pep381client-1.4.tar.gz
Algorithm Hash digest
SHA256 f2c19065d3cd480810dfb1d8b6ebb69a792628b4ad48cae323f732b053d5f781
MD5 7a463119a01ed57d69ae9bf678579382
BLAKE2b-256 58213f65b9ea6108fe407210d873b1ed95335d0b8c0a3146fe0a968f78417e95

See more details on using hashes here.

Supported by

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