php-src/sapi/apache2handler
Rasmus Lerdorf cad60c3760 Add SAPI hook to get the request time if provided by the web server,
otherwise call time(0) on the first call and store it so subsequent
calls will get the same time.  Hook support for Apache1/2 included.
2004-08-10 17:40:00 +00:00
..
apache_config.c - A belated happy holidays and PHP 5 2004-01-08 08:18:22 +00:00
config.m4 Fixed bug #25768 2003-10-21 11:48:31 +00:00
config.w32 Make apache2handler build with new build system. 2003-12-19 18:28:56 +00:00
CREDITS Credits update. 2003-03-04 00:10:11 +00:00
EXPERIMENTAL These both are experimental still. (there has been a note in config.m4 2003-02-23 02:39:51 +00:00
mod_php5.c - A belated happy holidays and PHP 5 2004-01-08 08:18:22 +00:00
php5apache2.dsp - Renamed all *php4* files to *php5*, changed all php4/PHP4 to php5/PHP5 2004-01-17 13:00:38 +00:00
php_apache.h - Happy new year and PHP 5 for rest of the files too.. 2004-01-08 17:33:29 +00:00
php_functions.c - Nuke empty_string. It is a reminanent from the time where RETURN_FALSE() 2004-07-19 07:19:50 +00:00
php.sym update php module name to php5, not php4. 2003-03-29 04:52:46 +00:00
README initial checkin of the apache2 SAPI using a handler instead of filters. 2003-02-11 17:40:11 +00:00
sapi_apache2.c Add SAPI hook to get the request time if provided by the web server, 2004-08-10 17:40:00 +00:00

WHAT IS THIS?

    This module exploits the layered I/O support in Apache 2.0.

HOW DOES IT WORK?
    
    In Apache 2.0, you have handlers which generate content (like
    reading a script from disk). The content goes then through
    a chain of filters. PHP can be such a filter, so that it processes
    your script and hands the output to the next filter (which will
    usually cause a write to the network).

DOES IT WORK?

    Currently the issues with the module are:  
        * Thread safety of external PHP modules
        * The lack of re-entrancy of PHP. due to this I have disabled the 'virtual' 
          function, and tried to stop any method where a php script can run another php 
          script while it is being run.


HOW TO INSTALL

    This SAPI module is known to work with Apache 2.0.44.

        $ cd apache-2.x
        $ cd src
        $ ./configure --enable-so
        $ make install

    For testing purposes, you might want to use --with-mpm=prefork.
    (Albeit PHP also works with threaded MPMs. See Thread Safety note above)

    Configure PHP 4:

        $ cd php-4.x
        $ ./configure --with-apxs2=/path/to/apache-2.0/bin/apxs
        $ make install
   
    At the end of conf/httpd.conf, add:

        AddType application/x-httpd-php .php

    If you would like to enable source code highlighting functionality add:
    
        AddType application/x-httpd-php-source .phps
    
    That's it. Now start bin/httpd.

HOW TO CONFIGURE

    The Apache 2.0 PHP module supports a new configuration directive that
    allows an admin to override the php.ini search path. For example,
    place your php.ini file in Apache's ServerRoot/conf directory and
    add this to your httpd.conf file:

        PHPINIDir "conf"

DEBUGGING APACHE AND PHP
    
    To debug Apache, we recommened:

        1. Use the Prefork MPM (Apache 1.3-like process model) by
           configuring Apache with '--with-mpm=prefork'.
        2. Start httpd using -DONE_PROCESS (e.g. (gdb) r -DONE_PROCESS).

    If you want to debug a part of the PHP startup procedure, set a 
    breakpoint on 'load_module'. Step through it until apr_dso_load() is 
    done. Then you can set a breakpoint on any PHP-related symbol.

TODO

    PHP functions like apache_sub_req (see php_functions.c)
    Source Code Highlighting
    Protocol handlers