summaryrefslogtreecommitdiff
path: root/debian/php5-common.README.Debian
blob: ea9d858eb22822220a684b96f7b2f9db5f8767df (plain)
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
138
Table of Contents:
---------------------------------------------------------------------
* Using php5 with threaded webservers (eg. apache2-mpm-worker, caudium)
* Problems starting apache with php5
* Session storage
* Other caveats
* php5-cgi and apache/apache2
* Configuration layout
* Further documentation, errata, etc


Using php5 with threaded webservers (eg. apache2-mpm-worker, caudium)
---------------------------------------------------------------------

   After much back-and-forth with upstream (and even building our
   packages thread-safe for a while), we're currently admitting defeat
   on that front, and are NOT building any thread-safe versions of
   PHP for any webservers.  Our recommendation is that, if you need
   to use a threaded webserver, you should use php5-cgi in either
   'normal' CGI mode, or in FastCGI mode.

Adam Conrad <adconrad@0c3.net>  Sun, 06 Feb 2005 08:24:56 -0700


Problems starting apache with php5
----------------------------------

   At the time of writing, there are no *known* incompatibilities
   between any of the php5 modules we ship.  However, there have been
   many bug reports in the past due to dynamically-loaded extensions,
   and it's possible there are still bugs in the released packages.  If
   Apache fails to start after you install php5, check your list of
   enabled extensions at the bottom of /etc/php5/apache/php.ini (and in
   the per-sapi configuration directory), and try commenting out or
   reordering the extensions until you find a combination that works.

   For example, in the past the mhash extension was incompatible with
   some other common extensions.  To work around this, you could list
   the mhash extension first in php.ini.

   If you find an extension-related bug in the Debian packages, and you
   are willing to help debug the problem, please send us a bug report
   that lists all enabled PHP5 extensions (extension=), in the order
   in which they appear in php.ini, as well as all enabled Apache modules
   (LoadModule), with version numbers where possible.

Steve Langasek <vorlon@debian.org>  Fri, 26 Apr 2002 13:39:00 -0500


Session storage
---------------

    Session files are stored in /var/lib/php5.  For security purposes, this
    directory is unreadable by non-root users.  This means that php5 running
    from apache, for example, will not be able to clean up stale session
    files.  Instead, we have a cron job run every 30 mins that cleans up
    stale session files; /etc/cron.d/php5.  You may need to modify how
    often this runs, if you've modified session.gc_maxlifetime in your
    php.ini; otherwise, it may be too lax or overly aggressive in cleaning
    out stale session files.  

Andres Salomon <dilinger@debian.org>  Fri, 03 Sep 2004 03:12:54 -0400


Other caveats
-------------

 * extension_dir and include_path should be commented out, if you don't need
   special settings for them so php will look in compiled-in paths. If you set
   them, you should also add appropriate php install directories there.

php5-cgi and apache/apache2
---------------------------

In 99% of cases, what you probably want isn't php5-cgi at all, but rather
the libapache-mod-php5 or libapache2-mod-php5 package, which will configure
themselves on installation and Just Work(tm).  If, however, you have a need
to use the CGI version of php5 with apache/apache2, the following should
help get you going, though there are dozens of different ways to do this.

Please note that this process will never be made automatic, as php5-cgi
is meant to be a webserver-agnostic package that can be used with any
httpd, and we don't want it to conflict with the httpd-specific packages
such as libapache-mod-php5.  If both were installed side-by-side and both
were automatically enabled, the results would be a bit confusing, obviously.

If you want to use php5-cgi in apache
  1) activate mod_action (apache-modconf apache enable mod_actions)
  2) Add the following to a config snippet in /etc/apache/conf.d
      <IfModule mod_actions.c>
        Action application/x-httpd-php /cgi-bin/php5
      </IfModule>

To use php5-cgi with apache2
  1) activate CGI (it's on by default in default debian setups)
     a) If using the prefork MPM, use 'a2enmod cgi'
     b) If using a threaded MPM, use 'a2enmod cgid'
  2) activate mod_actions (a2enmod actions)
  3) Add the following to a config snippet in /etc/apache2/conf.d
      <IfModule mod_actions.c>
        Action application/x-httpd-php /cgi-bin/php5
      </IfModule>

Adam Conrad <adconrad@0c3.net>  Sat, 04 Sep 2004 23:04:26 -0600

Configuration Layout
---------------------------------------------------------------------

Each of the 4 SAPI's (apache/apache2/cgi/cli) have a different
central configuration file /etc/php5/$SAPI/php.ini.  

Additionally, each SAPI is configured with the compile-time option 

	--with-config-file-scan-dir=/etc/php5/$SAPI/conf.d

which for all SAPI's is actually a symlink pointing to a central
directory /etc/php5/conf.d.  Any file found in this directory ending
in .ini will be treated as a configuration file by the php SAPI.

The rationale with this method is that each SAPI can thus be
identically configured with a minimal amount of conffile handling,
but at the same time if you want to have SAPI-specific configuration,
you can just remove the symlink.

sean finney <seanius@debian.org>  Thu, 19 Oct 2006 23:33:05 +0200

Further documentation, errata, etc
---------------------------------------------------------------------

Errata and other general information about PHP in Debian can be found
in the debian wiki at:

	http://wiki.debian.org/PHP
	
If after reading the documentation in this file you still have unanswered
questions, that's a good next place to go.

sean finney <seanius@debian.org>  Thu, 19 Oct 2006 22:57:52 +0200