Web www.freebsdmadeeasy.com
Main Menu

Other Sites





Installing PHP 5 on FreeBSD

A tutorial on installing PHP from the FreeBSD ports for Apache and MySQL. What you need to add to the httpd.conf file and which of the PHP5 ports to choose.

Choosing which port to use

In the past there were several ports for PHP such as /www/mod-php5, /lang/php5-cli, and /lang/php5. Since the release of PHP 5.1.14 there is now only /lang/php5 This port now allows you to choose if you want to install the CLI, CGI, and Apache module.

CLI stands for command line interpreter. It is used for running PHP scripts from the command line and makes creating shell scripts very simple if you already know PHP. The Apache PHP Module is disabled by default, so make SURE that if you plan to use this for web work that you enable it.

Installing the port

Since all PHP ports are now combined you will need to configure it to be sure the parts you need are built.

# cd /usr/ports/lang/php5
# make config
# make install

When you run make config you will be shown a list of options. To use PHP with Apache make sure the Apache Module box is selected.

Once php has installed you will need to install the extra modules for things such as MySQL. These modules are all located in the ports. Some of the most common modules are

/usr/ports/databases/php5-mysql - MySQL Database
/usr/ports/www/php5-session	- Sessions
/usr/ports/graphics/php5-gd - Graphics Library

Adding the PHP 5 module to Apache

Apache needs the following lines in the httpd.conf file to use php. These lines should already be added by the port but if you have problems you should double check your httpd.conf file. Note that Apache 2.x does not need the AddModule line.

# Apache 1.3.x
LoadModule php5_module        libexec/apache/libphp5.so
AddModule mod_php5.c
# Apache 2.x
LoadModule php5_module        libexec/apache/libphp5.so

If you installed using the port and had apache installed already it should do this automatically for you.

Next find your DirectoryIndex section in your httpd.conf file. Apache is set up for PHP 4, but not PHP 5 currently so you will need to modify it and change the 4s to 5s like this.

<IfModule mod_dir.c>
    <IfModule mod_php3.c>
        <IfModule mod_php5.c>
            DirectoryIndex index.php index.php3 index.html
        </IfModule>
        <IfModule !mod_php4.c>
            DirectoryIndex index.php3 index.html
        </IfModule>
    </IfModule>
    <IfModule !mod_php3.c>
        <IfModule mod_php5.c>
            DirectoryIndex index.php index.html index.htm
        </IfModule>
        <IfModule !mod_php4.c>
            DirectoryIndex index.html
        </IfModule>
    </IfModule>
</IfModule>

This code is telling Apache to open index.php first you have the PHP 5 module loaded. You can change the order as you wish. Or if you just wanted to skip it you could simply add the following line to the httpd.conf file since you know you are going to have php 5.

DirectoryIndex index.php index.html index.htm

Now apache just needs to know what it should parse the PHP files with. These two lines should be added to the httpd.conf file, and can be put at the bottom if needed.

AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps

If want to use PHP code inside of .htm files you can just add on those extensions.

AddType application/x-httpd-php .php .htm .html

Configuring PHP

Settings for PHP are stored in /usr/local/etc/php.ini You will need to create this file by copying it from /usr/local/etc/php.ini-dist

# cp /usr/local/etc/php.ini-dist /usr/local/etc/php.ini

In this file you can set the memory limit for programs. Turn on global variables if you must, set the max file upload size, and everything else you need.

Testing PHP

Once you have restarted Apache so the changes take effect you are ready to test it. To test it run the following command to create a php file that you can attempt to run

# echo "<? phpinfo(); ?>" >> /usr/local/www/data/test.php

Then point your web browser to http://yourdomain.com/test.php and if it works you will see several pages of information on your PHP settings. If it did not work you will see only the text you typed in.


Comments

Submitted by Eddy on May 18, 2007
This is a general comment on this site:
 "THANK YOU SO MUCH" Installing and working on freebsd has never been this simple for me.
Submitted by K-a-M-u-Z-u on May 28, 2007
What can i do when i get "error code 1" when installing php on FreeBSD?
Submitted by James on May 31, 2007
Error Code 1 is a generic "something went wrong" error code. Sometimes there is more information in the text above it. If you scroll back a bit you might be able to determine the cause. Sometimes I get an Error Code 1 when I am trying to install something that is already installed.
Submitted by jMCg on Jun 8, 2007
Seeing that there is the possibility to comment I‘d like to use this chance to provide a little correction from an Apache point of view.
 Using AddType to enable PHP [or any other script language] is a hack.
 Here‘s an explanation why:
 http://www.devside.net/articles/php
 
 [I‘m a regular of #Apache and PHP is generally a toothache for us, so we try to as hard as possible to raise people‘s awareness and correct those errors.]
Submitted by Joe on Jul 6, 2007
Hello,
 
 I have upgraded php4.4.4 to php5.2.3 but php -v shows 5.2.3 and phpinfo shows 4.4.4 can you please assist.
Submitted by Norsuzana Harun on Sep 7, 2007
Thank you for giving me a very simple guide to install PHP and enable it thru apache
Submitted by Cosmin C on Sep 10, 2007
This tutorial is very good with a little exception: For PHP5/Apache22 is required this line;
 AddModule php5_module libexec/apache22/libphp5.so
 not libexec/apache/libphp5.so.
 Thanks for ideea,
 Cosmin
Submitted by Khadija on Oct 19, 2007
Thanks for good explanation.
Submitted by Olav on Oct 19, 2007
Hi, I‘ve troubles installing php5.
 Actually a FreeBSD 6.2, Apache 2.2
 Mysql 4 and php4 run very well. But
 when I try an upgrade to php5, simply
 fails miserably. The new module
 crash httpd and let out php scripts.
 
 If I try an html page, theres no prob,
 but when I try (i.e. phpmysqladmin) one
 php script, simply fail and a httpd.core
 apear, when I try an analysis, I couldn‘t
 see something clear about what happen.
 
 Thanx in advance for your time.
 
 Olav.
Submitted by Armando Padilla on Feb 3, 2008
under FreeBSD.
 
 1. go to /usr/ports/lang/php5
 2. make deinstall
 3. make config
 4. select APACHE MODULES
 5. click ok
 6. make clean install
 7. read this page from AFTER the LoadModule section since the php install puts the proper LoadModule directive in there for us.
 
 
 Armando Padilla
Submitted by Nelson on Oct 30, 2007
Thanks! This document have been a great help.
Submitted by perk1z on Jan 15, 2008
Bravo .. thx
Ask a question or add a comment here.