forked from php/web-php
-
Notifications
You must be signed in to change notification settings - Fork 0
/
mirroring-troubles.php
137 lines (122 loc) · 4.98 KB
/
mirroring-troubles.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<?php
$_SERVER['BASE_PAGE'] = 'mirroring-troubles.php';
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/prepend.inc';
$SIDEBAR_DATA = '
<h3>Other mirror information</h3>
<p>
Properly working mirror sites are listed on <a href="/mirrors.php">our
mirrors page</a> and set by <a href="/my.php">my.php</a>. See also the
instructions for <a href="/mirroring.php">setting up a mirror</a>.
</p>
';
site_header("The PHP mirrors problem and troubleshooting guide", array("current" => "help"));
?>
<h1>Common troubles that PHP.net mirrors face</h1>
<p>
Mirroring a PHP.net server requires a few specific settings and
considerations, and this document provides a list of problems with possible
solutions. The mirror tools check for these problems and automatically
disable the problematic mirrors. The [<strong>?</strong>] link within each
title may be used to test this mirror.
</p>
<a name="multiviews"></a>
<h3>MultiViews are on [<a href="/functions">?</a>]</h3>
<p>
Because the 'Options' directive may be ignored in VirtualHost, a
solution is to move the MultiViews option into a specific
directory and disable it from there. For example:
</p>
<pre class="info">
<VirtualHost *:80>
<Directory /path/to/phpweb>
Options -Indexes -MultiViews
</Directory>
DocumentRoot /path/to/phpweb
ServerName ....
....
</VirtualHost>
</pre>
<p>
The <a href="mirroring.php#settings">mirror settings</a> example also
demonstrates this use. See also the Apache documentation that describes
<a href="http://httpd.apache.org/docs/content-negotiation.html">
Content Negotiation</a>.
</p>
<a name="content-type"></a>
<h3>Improper Content-Type [<a href="/manual/en/faq.html.php">?</a>]</h3>
<p>
Some pages are returning incorrect <code>Content-Type</code> headers. For example,
xx.php.net/manual/en/faq.html.php should be returning <code>text/html</code>
instead of <code>application/x-httpd-php</code>. See also the Apache
documentation describing
<a href="http://httpd.apache.org/docs/content-negotiation.html">Content
Negotiation</a>. This problem might be specific to
<a href="http://apache.lexa.ru/">Russian Apache</a>.
</p>
<a name="manual-redirect"></a>
<h3>Manual redirects [<a href="/manual/">?</a>]</h3>
<p>
By default, Apache inserts an alias for <code>/manual/</code> in the configuration
and this causes problems for mirrors. So for example if you find that
the manuals are listed on the documentation page but all of the links
open up a search page, you probably suffer from this problem and must
remove that alias.
</p>
<a name="shortcuts"></a>
<h3>Broken manual shortcuts [<a href="/echo">?</a>]</h3>
<p>
If the shortcut features [e.g. xx.php.net/echo] are not working, be sure
the manual files are really under <code>DOCUMENT_ROOT</code> and that the English
manual files are present. Also make sure that you have a correct
ErrorDocument setting.
</p>
<a name="invalid-data"></a>
<h3>Invalid data types [<a href="/testing">?</a>]</h3>
<p>
Invalid data is being received, and this is probably caused by improper error
handler settings. See the <a href="mirroring.php">mirror guidelines</a>
for how to setup the ErrorDocument.
</p>
<a name="var"></a>
<h3>A misguided var handler [<a href="/manual/en/ref.var.php">?</a>]</h3>
<p>
The <a href="mirroring.php">mirroring guidelines</a> mention that Apache2
enables a 'var' handler by default and this may be disabled by using
<code>RemoveHandler var</code> in the configuration file.
</p>
<a name="msi"></a>
<h3>Mishandling of .msi files</h3>
<p>
When improperly set, users are not given a "download this file" prompt
when attempting to download the PHP Installer (a .msi file). Your web
server configuration should be adjusted to force .msi files as
'application/octet-stream'. In Apache this may be done by using:
<code>AddType application/octet-stream .msi</code>
</p>
<a name="unlisted"></a>
<h3>An unlisted mirror</h3>
<p>
If you have an official mirror server but it's not listed on
<a href="/mirrors.php">mirrors.php</a> or available from
<a href="/my.php">my.php</a> then your mirror most likely failed the mirror
tests and suffers from one of the problems listed here. Mirrors that fail
the tests are automatically removed from the listing for our user's
convenience. We send out weekly notifications to all disabled mirror
maintainers, and to the [email protected] mailing list.
</p>
<a name="slow"></a>
<h3>Slow response time</h3>
<p>
Although this test is currently a little unfair (it's only based from the
USA), the response time of the server exceeds five seconds. Please confirm
the speed of these mirrors and we'll likely adjust the testing procedure.
This test will be performed from multiple locations in the future.
</p>
<a name="outbound"></a>
<h3>Unable to do external searches [<a href="results.php?q=curl&p=manual&l=en">?</a>]</h3>
<p>
Several searches require outbound connections to www.php.net, so this is
a test for that. The www.php.net box then connects to a third-party search engine.
</p>
<?php
site_footer();