DESCRIPTION

Configuration information for apt-p2p.conf is searched for in the following order, with later entries overriding former ones:

1.

/etc/apt-p2p/apt-p2p.conf

2.

$HOME/.apt-p2p/apt-p2p.conf

3.

the location specified by the config-file parameter

FORMAT

apt-p2p.conf has a structure similar to Microsoft Windows INI files. The configuration file consists of sections, led by a '[section]' header and followed by 'name = value' or 'name: value' entries, with continuations in the style of RFC 822 (values can span multiple lines by starting the subsequent lines with one or more spaces). Some values indicate times, in which case a suffix of 'd' for days, 'h' for hours, 'm' for minutes, and 's' for seconds can be used. Boolean values can be '1', 'yes', 'true', and 'on' to evaluate to True, or '0', 'no', 'false', and 'off' to evaluate to false. Note that leading whitespace is removed from values, and case is not important. Lines beginning with '#' or ';' are ignored and may be used to provide comments.

VARIABLES

There are 2 required sections in the config file. The first is the DEFAULT section, providing variables for the configuration of the main application. The second is the section that provides variables for the configuration of the DHT.

DEFAULT

PORT = number

The number of the port to listen on for requests. The main application will use this TCP port to listen for requests from APT, and for uploads to other peers. If a port is not specified for the DHT, it will also use this UDP port to listen for DHT requests. (Default is 9977.)

UPLOAD_LIMIT = speed

The speed to limit sending data to peers to, in KBytes/sec. Set this to 0 to not limit the upload bandwidth. (Default is 0)

MIN_DOWNLOAD_PEERS = number

The minimum number of peers before the mirror is not used. If there are fewer peers than this for a file, the mirror will also be used to speed up the download. Set to 0 to never use the mirror if there are peers. (Default is 3)

CACHE_DIR = directory

The directory to store the downloaded files in. (Default is $HOME/.apt-p2p/cache.)

OTHER_DIRS = list

The list of directories containing packages to share with others. All files in these directories will be hashed and available for everybody to download. (Default is to share only the files downloaded.)

LOCAL_OK = boolean

Whether it's OK for the application to use for sharing files an IP address from a known local or private range (RFC 1918). This should only be set true if you are running your own private apt-p2p network that no one else will be connecting to. (Default is false)

REMOTE_STATS = boolean

Whether a remote peer can access the statistics page. (Default is True)

UNLOAD_PACKAGES_CACHE = time

The time of inactivity to wait for before unloading the packages cache. The packages cache uses a lot of memory, and only takes a few seconds to reload when a new request arrives. (Default is 5 minutes.)

KEY_REFRESH = time

The time after which to refresh DHT keys. This should be a time slightly less than the DHT's KEY_EXPIRE value. (Default is 2.5 hours.)

USERNAME = user

The user name to try and run as. Leaving this blank will try to run as current user. (Default is 'apt-p2p'.)

DHT = string

The DHT implementation to use. It must be possile to do (in python) 'from <DHT>.DHT import DHT' to get a class that implements the IDHT interface. There should also be a similarly named section in the config file to specify the options for the DHT. (Default is 'apt_p2p_Khashmir')

DHT-ONLY = boolean

Whether to only run the DHT. This can be useful for providing only a bootstrap node. (Default is false)

apt_p2p_Khashmir

PORT = number

The number of the port to listen on for DHT (UDP) requests. (Default is to use the value specified in the DEFAULT section.)

BOOTSTRAP = list

The list of bootstrap nodes to contact to join the DHT. Each node should be on a separate line, and start with the IP address or host name, followed by a colon and the port number. (Default is a list of known good nodes.)

BOOTSTRAP_NODE = boolean

Whether this node is a bootstrap node. (Default is false)

CHECKPOINT_INTERVAL = time

The time to wait between saves of the running state. (Default is 5 minutes.)

CONCURRENT_REQS = number

The concurrent number of calls per find node/value request. (Default is 8.)

STORE_REDUNDANCY = number

The number of redundant copies of a value to store in the DHT. (Default is 6.)

RETRIEVE_VALUES = number

The number of values to attempt to retrieve from the DHT. Setting this to 0 will try and get all values (which could take a while if a lot of nodes have values). Setting it negative will try to get that number of results from only the closest STORE_REDUNDANCY nodes to the hash. (Default is -10000, which is a large negative number so all values from the closest STORE_REDUNDANCY nodes will be retrieved.)

MAX_FAILURES = number

The number of times in a row a node can fail to respond before it's booted from the routing table. (Default is 3.)

MIN_PING_INTERVAL = time

The minimum time to wait before re-pinging a node. (Default is 15 minutes.)

BUCKET_STALENESS = time

The maximum time to wait before refreshing a bucket. (Default is 1 hour.)

LOCAL_OK = boolean

Whether it's OK to add nodes to the routing table that use an IP address from a known local or private range (RFC 1918). This should only be set true if you are running your own private apt-p2p network that no one else will be connecting to. (Default is to use the value specified in the DEFAULT section.)

KEY_EXPIRE = time

The time to wait before expiring unrefreshed keys. (Default is 3 hours.)

KRPC_TIMEOUT = time

The time to wait before KRPC requests timeout. (Default is 9 seconds.)

KRPC_INITIAL_DELAY = time

The time to start with when resending KRPC requests using exponential backoff. The request will first be resent after the delay set here. The request will be resent again after twice the delay set here, and so on. e.g. if TIMEOUT is 9 sec., and INITIAL_DELAY is 2 sec., then requests will be resent at times 0, 2 (2 sec. later), and 6 (4 sec. later), and then will timeout at 9. (Default is 2 seconds.)

SPEW = boolean

Whether to log lots of info about the requests and responses in the protocol. (Default is false)

RELATED TO apt-p2p.conf…

apt-p2p(8)

AUTHOR

This manual page was written by Cameron Dale <[email protected]> for the Debian system (but may be used by others). Permission is granted to copy, distribute and/or modify this document under the terms of the GNU General Public License, Version 2 or any later version published by the Free Software Foundation.

On Debian systems, the complete text of the GNU General Public License can be found in /usr/share/common-licenses/GPL.