Mirroring The PHP Website

If you would like to participate in the official PHP mirrors program, please read and follow these instructions carefully. You should have the consent of your hosting company (if you aren't a hosting company yourself), and be prepared for some potentially significant bandwidth usage. As of 25 September, 2013, the network of mirrors is averaging 251GB per day (about 7.52TB per month). At the time of the updating of this page, this load was spread across 90 active mirrors, indicating an overall average of 2.9GB per mirror. This can go up to 12GB per day or more for busy mirrors, such as those in the US, UK, and India. And immediately following new releases of PHP, the traffic spikes even higher (as should be expected) due to a surge in the number of downloads. Please be sure your server or hosting account is able to handle a minimum of roughly 42 gigabytes of transfer each month without incurring any additional costs or penalties, as the mirrors with the fewest requests per month are still averaging this amount of bandwidth usage per month. In the event that such action is taken against your account, remember: it is your responsibility.

Official mirror program participants are required to use PHP 5.3.21 or greater, but please note that we encourage maintainers to always use the latest stable versions of actively-developed branches. Please note that we do, somewhat regularly (about once per year) require existing maintainers to upgrade their PHP versions to a new minimum, so always being proactive in upgrades will ensure that your mirror remains in compliance with the official mirrors program. Set it up as an Apache module with the settings outlined below, or in any other Apache connected way (CGI, FastCGI, etc), considering the requested PHP settings outlined below in the Apache vhost instructions. The size of the full website is approximately 4.7 gigabytes.

NOTE: Some of our maintainers prefer to use web servers other than Apache, such as Nginx. While this is permitted (as long as everything ultimately works as directed), we do not officially support these setups at this time. If you would like to learn how to set up an alternative environment, feel free to post a question to current mirror maintainers on the mailing list at php-mirrors@lists.php.net.

Applications to join the official mirror program are reviewed on a case-by-case basis, but we will only approve those from ISPs and web hosting providers; universities and state-recognized academic institutions; PHP-centric web development firms; and PHP user groups and individual enthusiasts. Under no circumstances will we even review applications from marketing firms, website portals or directories, or anything of questionable moral or legal standing. We also reserve the right, at our discretion, and without warning, to refuse any application for any reason, or to suspend or expell any active mirrors if it is discovered that any information on the application was false or otherwise incorrect, or if the mirrors fails to remain in compliance with the official mirrors program.

Please note that we are currently only accepting new applications for countries in which we don't already have two official mirror presences. For a list of active official mirrors, see mirrors.php. Prior to attempting to set up an official mirror site, you are advised to contact php-mirrors@lists.php.net (a public mailing list, archived in numerous places on the Internet) to inquire as to whether or not your application may be accepted. We have found that this limit serves our users well, so please do not ask to provide a third mirror for a country that already has two. Please also be aware that the mirror is required to be physically located in the country you would like to serve. If there are already two mirrors in a country for which you would like to provide an official mirror, you may add your information to the official waiting list, which can be found here. If and when a vacancy becomes available, we will go through the applications on the waiting list before entertaining new public applications.

If you are not an official mirror (e.g. you mirror the site for your company's internal use), you should not synchronize from our network more frequently than once every six hours, or you may find your IP blocked. Also, please make an effort to only mirror those parts of the site that you actually need. (For example, exclude the manual in all languages that you will not be using and exclude the distributions directory.)

Get Files With Rsync

First, you need to have a rsync installed. To better serve our official mirror providers and maintainers, we switched to a geographically-decentralized distribution architecture. By switching from a single United States-based master server to three Regional Rsync Nodes (RRNs), we're able to reduce the amount of latency and time to transfer data between an RRN and a mirror, serve more requests per hour (allowing for a closer to real-time network update globally), and provide redundancy in the event of an outage of a sync server.

To synchronize your server with the appropriate RRN, first view the coverage map and identify which RRN your mirror should be using. Next, modify the following code for use with your mirror. Replace YOUR_RRN_HOSTNAME with your RRN's hostname as indicated by the coverage map and be sure to change /your/local/path with the path to where your php.net mirror will reside on the filesystem.

    rsync -avzC --timeout=600 --delete --delete-after \
      --include='distributions/*.exe' \
      YOUR_RRN_HOSTNAME::phpweb /your/local/path 

Setting up an unofficial mirror, and want to only mirror one language of the manual? Add:

    --include='manual/en/' --include='manual/en/**' --exclude='manual/**' --exclude='distributions/manual/**'

after "--delete-after" in the command line above (substituting your prefered language code in place of 'en'). You can also exclude the whole distributions directory (and the related extra folder) by replacing "--exclude='distributions/manual/**'" with "--exclude='distributions/**' --exclude='extra/**'".

Official PHP mirror sites should provide the exact content coming from our servers, and must not be altered in any way unless explicitly stated in the mirroring guidelines. Failing to do will result in immediate termination and permanent expulsion of your participation in the program.

Add SQLite 3 Support

SQLite is an embedded SQL database implementation that has very high performance for applications with low write concurrency. PHP mirrors currently employ SQLite for URL shortcut lookups, and it is a requirement of all official mirrors to have it installed and available to PHP.

There are a couple of SQLite 3 implementations in PHP. One is via the PDO extension by using the SQLite driver (pdo_sqlite, which is required). The other is via the SQLite3 extension. These extensions are both compiled into PHP by default. Note: Some Linux distributions disable many extensions in their package systems, including SQLite. Please make sure you install the "php5-sqlite" (or similar) package if using such a system.

Setup Apache VirtualHost

Make sure your web server is set up to serve .php files as PHP parsed files. If it isn't, add the MIME type to your config.

Please make sure you have turned off output compression for binary files.

Create a VirtualHost entry, which looks something like:

<VirtualHost *-or-your-hostname-or-your-ip-here>
     <Directory /www/htdocs/phpweb>
          # Do not display directory listings if index is not present,
          # and do not try to match filenames if extension is omitted
          Options -Indexes -MultiViews
     </Directory>

     ServerName ccx.php.net
     ServerAlias cc.php.net www.php.net the.cname.you.set.up.example.com
     ServerAdmin yourname@example.com
     UseCanonicalName On
     
     # Webroot of PHP mirror site
     DocumentRoot /www/htdocs/phpweb
     
     # Log server activity
     ErrorLog logs/error_log
     TransferLog logs/access_log
     
     # Set directory index
     DirectoryIndex index.php index.html
     
     # Handle errors with local error handler script
     ErrorDocument 401 /error.php
     ErrorDocument 403 /error.php
     ErrorDocument 404 /error.php
     
     # Add types not specified by Apache by default
     AddType application/octet-stream .chm .bz2 .tgz .msi
     AddType application/x-pilot .prc .pdb 

     # Set mirror's preferred language here
     SetEnv MIRROR_LANGUAGE "en"

     # The next two lines are only necessary if generating
     # stats (see below), otherwise you should comment them out
     Alias /stats/ /path/to/local/stats/
     SetEnv MIRROR_STATS 1

     # Apache2 has 'AddHandler type-map var' enabled by default.
     # Remove the comment sign on the line below if you have it enabled.
     # RemoveHandler var
     
     # Turn spelling support off (which would break URL shortcuts)
     <IfModule mod_speling.c>
       CheckSpelling Off
     </IfModule>

     # A few recommended PHP directives
     php_flag display_errors off
     
     # If you have Russian Apache with mod_charset installed,
     # do not forget to search for this line in your existing
     # configuration, and comment it out:
     # AddHandler strip-meta-http .htm .html 
         
</VirtualHost>

You should only start to set up an Apache VirtualHost for an official mirror if you have contacted us first and received the permanent names for your mirror. The names for all official PHP mirrors are in the convention: ccx.php.net, where cc stands for the 2-letter ISO country code of your mirror's location and x is an incremental identifier for the mirrors of that country. Do not assume that you know the code you will receive until your application has been reviewed and approved, and do not submit an application saying, for example, "We are applying to become DE1.PHP.NET." It's possible that the mirror already exists, but is experiencing issues that have it temporarily removed from active rotation, and delisted from the roster of mirrors. We do not want anyone to waste their time only to have their application altered or rejected. The mirrors should also listen for the cc.php.net hostname, as we moved to providing a simple load-balancing solution: round-robin DNS. All mirrors are required to be configured for both CC and CCX, so any active mirror can receive traffic for their respective cc.php.net hostname, thus providing redundancy and improved uptime for visitors.

Before adding new official mirrors to our DNS, we require the maintainers to set up the mirrors with an address we can use as a CNAME in the DNS. This subdomain (the.cname.you.set.up.example.com in the above example) will be checked by mirror admins before the mirror is added. Therefore it is important that the mirror is capable of serving requests for this name and the (www.)cc(x).php.net address provided by the mirror administrators.

The hostname you provide to us must be a configured hostname to be entered into our DNS as a CNAME, not an IP address to be used as an A record. Your local DNS information may then translate into both IPv4 and IPv6, should you so desire and have the capabilities, but may not exclude IPv4 from the record until further notice.

When setting up the vhost, provide an asterisk, a hostname, or an IP address in the VirtualHost container's header (depending on whether you would like to make the vhost work for all IPs handled by Apache, or just a specific hostname/IP address). Consult the Apache documentation for the differences of the two methods. It is very important to use your ccx.php.net address as the ServerName, so URL redirections will keep the requests in the php.net domain, ensuring that the My PHP.net service will work. Failure to do so will also cause your mirror to show up as an unofficial mirror, and to be removed from the roster page.

Change the DocumentRoot setting as appropriate, specify the mirror's preferred language, and provide settings according to your stats setup, if your mirror is going to provide stats. For the preferred language setting, choose one from those available as manual translations. If you provide something else, your default language will be English. After you restart Apache, your mirror site should start working.

Setting Up Local Stats

Setting up local stats can be a plus on your mirror. We provide some setup instructions for that.

Setup Regular Updates

You must also set up a cron job that periodically does an rsync to refresh your web directory. We prefer that all mirrors update from the appropriate RRN from the coverage map every five minutes, to speed up the distribution of updates to the site and available packages. Something like:

   */5 * * * * rsync -avzC --timeout=600 --delete --delete-after --include='distributions/*.exe' YOUR_RRN_HOSTNAME::phpweb /your/local/path

Remember to specify the same rsync parameters you used to get the phpweb files as explained near the top of this page. If you're unable to synchronize every five minutes, you may pick your own update frequency, provided it does not exceed fifteen minutes.

Sponsor Logo

We would like to thank you for providing a mirror, so if you would like to display a logo on the mirror site promoting your company, you are able to do so by following these steps:

The PHP Group and the Network Infrastructure Manager reserve the right to refuse images based on content, but most things should be fine.

We have chosen a banner size which conforms with the Internet Advertising Bureau standards.

And finally, don't forget to put a nice little PHP logo somewhere on your hosting company's site if possible. Grab one of the logos from the logos download page, and link it to your mirror. This shows the community that you are a proud supporter of PHP and open source technology, and you will be worshipped every hour, on the hour, in song and dance, by millions of proboscis monkeys the world over. Well, okay, perhaps not.... but folks will certainly appreciate your generosity and support!

Mirror Setup Troubleshooting

The mirror troubleshooting guide contains information about the common and potential problems discovered when setting up and maintaining a PHP.net mirror. Included are links that perform many of the tests executed by the automated mirror management tools.

Data Registered About Official Mirrors

Once you have done the above and your site appears to work, send a message to php-mirrors@lists.php.net with the following information, and appropriate steps will be taken to integrate your mirror site:

There is a mailing list named "php-mirrors" at lists.php.net, to which you are required to subscribe. This mailing list is very low-traffic and only used for communication between mirror maintainers and php.net webmasters, and to provide automatic information on mirror outages and other issues.

To subscribe send an empty message to: php-mirrors-subscribe@lists.php.net

We also operate an EFNet channel, and encourage you to join us there. If you are interested, please join us at #php.mirrors. Many maintainers and staff members idle in the room around the clock, and are available to address questions, concerns, or issues in real-time (keeping in mind that the mailing list is the official support channel, and this is just a convenient additional method of communication between teams).

Thank you for your interest in providing a mirror! If you ever have any questions or concerns, drop us a line at php-mirrors@lists.php.net --- we are here to help!

To Top