Skip to main content

Filetracker caching file storage

Project description

filetracker

Build Status

A simple file storage module for distributed systems.

About

Filetracker has a client-server architecture: the server is the primary storage, and every client may have its own cache. Client has a Python API, and can be also invoked from the shell. Interaction between client and server is based on a simple HTTP API (Filetracker protocol).

Files are stored on the server compressed and deduplicated. A peculiar versioning scheme is supported: files are versioned by their modification timestamps, and some operations accept file versions as parameters (e.g. adding a file with an older version will have no effect if there's already a file with the same name and newer version).

Using

CAUTION: Filetracker has no security measures since it's meant to be used in internal networks. Don't put any sensitive data in filetracker without first making sure that it can't be reached from untrusted hosts.

Filetracker server requires Berkeley DB to run. On Debian-based systems it can be installed as libdb-dev.

After installing filetracker in a virtualenv, various scripts are added to $PATH. The most important ones are filetracker-server and filetracker. A simple filetracker server can be started with filetracker-server -L log.txt -l 127.0.0.1 -p 9999 -D. Read the scripts' help pages for more detailed information on running them.

Scripts

There are some useful scripts for working with filetracker in filetracker.scripts package, namely:

  • filetracker-migrate for uploading directories recursively to the server
  • filetracker-recover for recovering storage metadata after serious failures
  • filetracker-cache-cleaner for cleaning client cache

Check out the source or run them with -h for detailed information.

Upgrading from older versions

Testing

The recommended way to run tests is using tox. Install tox globally (either with pip install tox, or using your distribution's package manager), and simply run tox.

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

filetracker-2.3.1.tar.gz (59.4 kB view details)

Uploaded Source

Built Distribution

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

filetracker-2.3.1-py3-none-any.whl (61.6 kB view details)

Uploaded Python 3

File details

Details for the file filetracker-2.3.1.tar.gz.

File metadata

  • Download URL: filetracker-2.3.1.tar.gz
  • Upload date:
  • Size: 59.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for filetracker-2.3.1.tar.gz
Algorithm Hash digest
SHA256 132eaf5002f156f13af652ca43b21638c3ba5f64bf8643494d549e262efa5a39
MD5 e83ecf020b91bb4d91b694c2865e8ef5
BLAKE2b-256 0e43cbb48d9f8b36d9347159d52db4e7631d257812174f459030b7c1f7f631d2

See more details on using hashes here.

File details

Details for the file filetracker-2.3.1-py3-none-any.whl.

File metadata

  • Download URL: filetracker-2.3.1-py3-none-any.whl
  • Upload date:
  • Size: 61.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for filetracker-2.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 82fb962c74bc4e0945d1ed428f1e154a0e3a3badb5550510a2709105123e0405
MD5 170e35dcf88df1f2a81001d3c87276e5
BLAKE2b-256 e75544bcd69e5250af7ceef2db605890afbd309cb7a95a8c97475ea303935523

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