安装apache、php详解程序员

在Linux环境下配置安装PHP环境(Apache2),参考了一些别人的配置方法,遇到问题上网查。下面就是安装步骤:

一、安装Apache2.2.22
1、到官网下载  http://httpd.apache.org/download.cgi   
2、解压
   tar  -zxvf httpd-2.2.22.tar.gz
3、建立目标文件夹(注意以下所有操作都时在root用户下执行的)
   mkdir /usr/local/apache2
   也就是说等下安装的apache2要安装到这个文件夹里面
4、配置
   回到原来解压之后产生的文件夹
   ./configure –prefix=/usr/local/apache2 –enable-module=shared
   要加上后面的参数,否则无法使用php,-enable-module=shared表示Apache可以动态的加载模块

这一步,出现了很多问题:

第一个错误为:

checking for APR... no 
configure: error: APR not found.  Please read the documentation. 
解决方法: 

download the latest versions of both APR and APR-Util from 
Apache APR, unpack them into ./srclib/apr and ./srclib/apr-util (be sure the domain names do not have version numbers; for example, the APR distribution must be under ./srclib/apr/)

              即下载APR和APR-Util安装包,解压到.srclib/apr 和.srclib/apr-util

./configure --with-included-apr 
 
第二个问题为:pcre-config for libpcre not found 
解决方法就是 下载prce安装包,和APR类似,安装到/usr/local/pcre文件夹下面即可。 
5、编译 
    make     
6、安装 
    make install   
7、启动,重启和停止 ,先切换到安装完成后的目录/usr/local/apache2/bin 
    ./apachectl -k start 
    ./apachectl -k restart 
    ./apachectl -k stop   
8、配置文件(满足最基本的配置) 
     编辑 /usr/local/apache2/conf/httpd.conf 文件      
     找到: 
    AddType  application/x-compress .Z 
    AddType application/x-gzip .gz .tgz 
    在后面添加: 
    AddType application/x-httpd-php .php(使Apcche支持PHP) 
    AddType application/x-httpd-php-source .php5    
    找到: 
    <IfModule dir_module> 
    DirectoryIndex index.html 
    </IfModule> 
    添加: 
    <IfModule dir_module> 
    DirectoryIndex index.html index.php 
    </IfModule>     
    找到: 
    #ServerName www.example.com:80 
    修改为: 
    ServerName 127.0.0.1:80或者ServerName localhost:80 
    记得要去掉前面的“#”     
9、测试 
    在浏览器里输入http://127.0.0.1 
    如果出现It Works!说明成功。这是我的测试结果:O(∩_∩)O哈哈~

安装apache、php详解程序员

10、修改默认的Web站点目录(可忽略)

    默认的目录为  “/usr/local/apache2/htdocs”,修改apache的配置文件httpd.conf,比如在新建一个 /home/gyw/WebSite的目录作为apache的站点目录

    找到DocumentRoot这一行修改为:DocumentRoot “/home/gyw/WebSite”

  找到 <Directory> 这一行修改为:<Directory “/home/gyw/WebSite”>

 

  二、安装PHP 
1、 下载
    http://www.php.net/downloads.php
2、解压
    tar -zxvf php-5.3.16.tar.gz
3、建立目标文件夹
    mkdir /usr/local/php
    也就是说等下安装的php要安装到这个文件夹里面
4、配置
    回到原来解压后的文件夹
    ./configure –prefix=/usr/local/php  withconfigfilepath=/usr/local/php –with-apxs2=/usr/local/apache2/bin/apxs

    注意这里有一个-with-apxs2=/usr/local/apache/bin/apxs选项,其中apxs是在安装Apache时产生的,apxs是一个为Apache HTTP服务器编译和安装扩展模块的工具,使之可以用由mod_so提供的LoadModule指令在运行时加载到Apache服务器中。我的理解是通过这个工具把PHP模块动态加载到Apache中

出现错误:configure: error: xml2-config not found. Please check your libxml2 installation.

运行yum install libxml2,然后再运行yum install libxml2-devel安装完毕后,重新运行上面的./configure命令。

5、编译
    make   
6、测试编译
    make test   
7、安装
    make install

8、配置文件

    cp /usr/local/src/php-5.3.16/php.ini-development  /usr/local/php/lib/php.ini
    把原来位于源代码里面的php.ini-development拷贝到/usr/local/php/lib/php.ini下,并且重命名为php.ini

9.重启apache
10、测试
    在apache的htdocs下建立一个php文件test.php,里面的内容如下:
    <?php
    phpinfo();
    ?>
    然后在浏览器里输入http://127.0.0.1/test.php
    如果出现php的相关配置,成功,如果什么都没有输入,说明失败,重新以上步骤或者查找原因

如果决定在安装后改变配置选项,只需重复最后的三步configure, make, 以及 make install,然后需要重新启动 Apache 使新模块生效。Apache不需要重新编译。

测试结果如下图:

安装apache、php详解程序员

 三、安装MySql

1、下载
    到官网下载mysql-5.1.65.tar.gz(注意是源码包)
2、解压
    tar -zxvf mysql-5.1.65.tar.gz
3、建立目标文件夹
    mkdir /usr/local/mysql
    也就是说等下安装的mysql要安装到这个文件夹里面
4、配置
    ./configure –prefix=/usr/local/mysql/ 

在./configure时出现错误:error: No curses/termcap library found

下载安装相应软件包

yum list|grep ncurses

yum -y install ncurses-devel

yum install ncurses-devel

5、编译
    make
6、安装
    make install

7、启动
    MySQL服务并不会自动启动,还需要先初始化MySQL数据库,操作如下:
    cd /usr/local/mysql/bin
    sudo ./mysql_install_db –user=root
    注意,这里最后的root是指可以操作数据库的用户,可以是当前用户,也可以新建用户,与linux上的root用户是两回事,可以自己取一个名字
    ./mysqld_safe –user=root & 这条命令负责启动mysql服务的守护进程,此外最后的&时必须的,因为希望守护进程在后台运行
    这里的root就是刚才的那个
8、为根用户创建密码
        ./mysqladmin -u root password ‘123456’
        如果root已经设置过密码,采用如下方法
        ./mysqladmin -u root password oldpass ‘123456’       
9、测试
    mysql -u root -p
    会提示输入密码,就用刚才设置的密码
    123456
    如果出现mysql>,说明连接成功了,下面通过命令 创建一个数据库、建一个表,增加一条记录,为后面的测试准备

   mysql> create database gywtest;
  mysql> use gywtest;

  mysql> create table student(id int(4) not null primary key auto_increment,stuname char(20));

  mysql> insert into student(stuname) values(‘Tom’);

  注意每条命令后面有个分号,如果上面的都成功,后面就可以用这个测试。

 四、将PHP与MySql结合起来

 1、重新配置PHP,改变配置选项,只需重复PHP安装时的最后的三步configure, make, 以及 make install,然后需要重新启动 Apache 使新模块生效,Apache不需要重新编译。

 2、配置

./configure –prefix=/usr/local/php  –with-apxs2=/usr/local/apache2/bin/apxs –with-mysqli=/usr/local/mysql/bin/mysql_config  注意mysql_config 的路径
3、编译 make

4、安装 make installe

5、测试 写一个页面test.php,放在apache的web目录下,测试上面用命令创建的数据库

    <?php 
  $mysqli=new mysqli();
  $mysqli->connect(‘localhost’,’root’,’123456′,’gywtest’);
  // 创建查询
  $sqlstr=’select * from student’;
  //发送查询给MySql
  $result=$mysqli->query($sqlstr);
    while($row=$result->fetch_object())
    { 
      $name=$row->stuname;
      echo $name;
    }
?>

Fatal error: Class ‘mysqli’ not found in /home/lufangtao/Project/DB.php on line 3

解决方法:

/usr/local/php/bin/phpize 这里回车运行

出错:

Cannot find config.m4. 
Make sure that you run ‘./phpize’ in the top level source directory of the module

解决方法:

PHP源码包文件夹下的EXT文件夹就是放置着目前版本的可用扩展,CD进去看看都有哪些你需要的?应该看到mysqli文件夹了吧~~~

在当前目录下执行phpize

[[email protected] mysqli]#/usr/local/php/bin/phpize

Configuring for:

PHP Api Version:                    20090626

Zend Modeule Api No:            20090626

Zend Extension Api No:          220090626

Cannot find autoconf. Please check your autoconf installation and the
$PHP_AUTOCONF environment variable. Then, rerun this script.

解决方法:

yum install autoconf再次运行上面的命令即可。

[[email protected] mysqli]#./configure –prefix=/opt/mysqli –with-php-config=/opt/php/bin/php-config –with-mysqli=/opt/mysql/bin/mysql_config

[[email protected] mysqli]#make

[[email protected] mysqli]#make install

安装完成后会有提示扩展所在目录路径,如:

/opt/php/lib/php/extensions/no-debug-zts-20090626php

所需的mysqli.so便会在此目录下,接下来修改/opt/php/etc/下的php.ini文件,加入mysqli扩展,即加入如下一行:

extension=/opt/php/lib/php/extensions/no-debug-zts-20090626/mysqli.so

这里还是会出现错误:

解决不用扩展连接MySQL的方法。

最终还是没有解决MySQLi连接的问题,但是可以使用MySQL数据库了,下面是测试程序

<?php 
 
$link=mysql_connect('localhost','root','123456'); 
 
if(!$link) echo "F!"; 
 
else echo "S!"; 
 
mysql_select_db("students") or die("Could not select database"); 
$query="SELECT * FROM student;"; 
$result=mysql_query($query) or die("Query failed"); 
print "<table>/n"; 
 
 while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) {         
print "/t<tr>/n";       
  foreach ($line as $col_value) {     
        print "/t/t<td>$col_value</td>/n";        
 }        
 print "/t</tr>/n";    }    
 print "</table>/n"; 
 
 
 
    /* 释放资源 */ 
 
 
 
mysql_free_result($result); 
mysql_close(); 
 
?> 
~  

 

安装apache、php详解程序员



原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/7464.html

(0)
上一篇 2021年7月17日
下一篇 2021年7月17日

相关推荐

发表回复

登录后才能评论