Linux下安装Apache PHP MYSQL

Linux下安装Apache

1.解压 tar -zxvf httpd-2.2.15.tar.gz

2.进入httpd-2.2.15目录,运行

[admin@test208003 httpd-2.2.15]$./configure --prefix=/home/admin/apache --enable-so
--enable-mods-shared=most --with-mpm=worker
 

prefix=<Install_Path> 指明编译后的二进制文件安装到<Install_Path>目录,用实际安装路径替换 <Install_Path>,如--prefix=/usr/local/apache-2.2.15 ,如果省略此配置参数,默认安装 到/usr/local/apache2目录。

--enable-so 指明编译动态加载模块(DSO)支持到httpd二进制文件,此模块使得Apache的各功能模块可以与核心分开编 译、运行时动态加载。有了DSO支持,升级和增加模块时只需编译相关的模块即可,不必重新编译整个系统。最新版本的 Apache缺省编译此模块到httpd二进制文件,如果你在使用早期版本的apache并且需要DSO支持,可能要明确指出此选项。

--enable-mods-shared=<MODULE-LIST> 明确指明要以DSO方式编译的模块,<MODULE-LIST>为空格分隔的模块名列 表、all或者most,all表示包含所有模块,most表示包含大部分模块,如 --enable-mods-share="rewrite deflate",--enable-mods-share=most,效果等同于多个 --enable-<FEATURE>=share

--with-mpm=<MPM> 先择Apache多路处理模块,<MPM>={beos|event|worker|prefork|mpmt_os2},prefork为 Unix系统下默认处理模块,它将运行一个非线程型的、预派生的Web服务器,适合于没有线程安全库,需要避免线程兼容性问 题的系统,它是要求将每个请求相互独立的情况下最好的MPM,这样若一个请求出现问题就不会影响到其他请求。worker 为支持混合的多线程多进程的多路处理模块,由于使用线程来处理请求,所以可以处理海量请求,而系统资源的开销小于基于 进程的MPM,同时,它也使用了多进程,每个进程又有多个线程,以获得基于进程的MPM的稳定性。如果你的系统是基于线 程安全的,那么建议使用worker替代prefork,它将使得你的系统得到实际的性能改善。


3.[admin@test208003 httpd-2.2.15]$ make

4.[admin@test208003 httpd-2.2.15]$ make install

5.配置http.conf (注意80端口是否被占用,linux下使用1024之内的端口需要root或sudo权限

User admin

Group admin

上面2个配置是Apache的安全保证,Apache在打开端口之后,就将其本身设置为这两个选项设置的用户

和组权限进行运行,这样就降低了服务器的危险性。这个选项也只用于 Standalone模式,inetd模式在inetd.conf中指定

运行Apache的用户。由于服务器必须执行改变身份的setuid()操作,因此初始进程应该具备root权限,如果是使用非root

用户来启动Aapche,这个配置就不会发挥作用。

 

 


6.切换至apache 的bin 目录下

[admin@test208003 bin]$ ./apachectl -k start

 Linux下安装PHP

1.解压,进入目录,同apache

2.运行

[admin@test208003 php-5.2.14]$ ./configure --prefix=/home/admin/php
--with-apxs2=/home/admin/apache/bin/apxs  
--with-config-file-path=/home/admin/php/lib

3.运行make和make install ,同apache,

复制php.ini-recommended到php的lib目录下,改名为php.ini

修改apache配置文件,加入AddType application/x-httpd-php .php


4.php安装独立扩展,拿curl扩展举例,同样下载curl包,将其解压安装

[admin@test208003 curl-7.13.0]$ ./configure --prefix=/home/admin/curl
[admin@test208003 curl-7.13.0]$ make
[admin@test208003 curl-7.13.0]$ make install

此处注意make时可能会报错gcc: /usr/lib/libidn.so: No such file or directory 解决方法:

方法一: 执行ln -s /usr/lib64/libidn.so.11.4.6 /usr/lib/libidn.so

一定要注意你的libidn的版本号和lib目录,跟机器位数相关,此处测试的机器是64的,所以选择lib64.

方法二: ./configure --prefix=/home/admin/curl --with-libidn=/usr/lib64 即指定路径,还要运行autoreconf.

方法三: ./configure LDFLAGS=-L/usr/lib64 (指定一个环境变量,这个就是告诉gcc去哪儿找.so文件)

然后编译生成扩展,进入php源码目录

[admin@test208003 php-5.2.14]$ cd ext/
[admin@test208003 ext]$ cd curl/
[admin@test208003 curl]$ /home/admin/php/bin/phpize
[admin@test208003 curl]$./configure --with-curl=/home/admin/curl 
       --with-php-config=/home/admin/php/bin/php-config
[admin@test208003 curl]$make
[admin@test208003 curl]$ make install
Installing shared extensions:     /home/admin/php/lib/php/extensions/no-debug-zts-20060613/
[admin@test208003 curl]$ cd /home/admin/php/lib/php/extensions/no-debug-zts-20060613/
[admin@test208003 no-debug-zts-20060613]$ ls
  curl.so
[admin@test208003 no-debug-zts-20060613]$

可以看到curl.so已经生成了,在php.ini里,设置扩展目录: extension_dir = /home/admin/php/lib/php/extensions/no-debug-zts-20060613/" 并添加扩展模块引用: extension = curl.so 重启apache即可


5.安装pdo的mysql扩展进入php源码目录

[admin@test208003 php-5.2.14]$ cd ext/
[admin@test208003 ext]$ cd pdo_mysql/
[admin@test208003 pdo_mysql]$ /home/admin/php/bin/phpize
[admin@test208003 pdo_mysql]$ ./configure --with-php-config=/home/admin/php/bin/php-config
[admin@test208003 pdo_mysql]$ make
[admin@test208003 pdo_mysql]$ make install

最后修改php.ini加入extension=pdo_mysql.so,重启apache即可


6. php一次性安装mysql,curl,pdo扩展,更简单的方法只需在configure参数修改即可

./configure --prefix=/home/admin/php --with-apxs2=/home/admin/apache/bin/apxs 
--with-config-file-path=/home/admin/php/lib --with-mysql=/home/admin/mysql 
--with-pdo-mysql=/home/admin/mysql --with-curl=/home/admin/curl --enable-mbstring


这样配置的前提是mysql数据库和curl已装好。

 Linux下安装MySQL

1.解压mysql的源码包mysql-5.1.50.tar.gz,切换到安装目录下

./configure --prefix=/home/admin/mysql --sysconfdir=/home/admin/mysql 
--localstatedir=/home/admin/mysql/data
--with-unix-socket-path=/home/admin/mysql/tmp/mysql.sock 
--with-charset=gbk --with-plugins=innobase --with-client-ldflags=-all-static
--with-mysqld-ldflags=-all-static

sysconfdir表示mysql的配置文件路径,localstatedir表示数据文件路径,socket配置和最后2个属性主要用来提升性能

如果要使用innodb引擎,记得加上--with-plugins=innobase

 make
 make install

2.复制/home/admin/mysql/share/mysql/my-medium.cnf 到mysql根目录下,改名为my.cnf

切换到mysql的bin目录下,运行

./mysql_install_db --basedir=/home/admin/mysql --datadir=/home/admin/mysql/data

3.复制/home/admin/mysql/libexec/mysqld到mysql的bin目录下,启动mysql服务

/home/admin/mysql/bin/mysqld_safe --ledir=/home/admin/mysql/bin 
--log-error=/home/admin/mysql/data/t.err --datadir=/home/admin/mysql/data 
--socket=/home/admin/mysql/tmp/mysql.sock --pid-file=/home/admin/mysql/data/mysqld.pid &

再用ps命令查看mysql是否启动,如果不能启动用netstat命令检查3306端口是否被占用,如果是则修改my.cnf的端口配置。

切换到mysql的bin目录下,运行 ./mysqladmin -u root password '123' 来修改root登录密码

修改/home/admin/mysql/share/mysql/mysql.server代码

pid_file=/home/admin/mysql/data/mysqld.pid

停止mysql服务

/home/admin/mysql/share/mysql/mysql.server stop

为了方便,可以把启动和停止mysql服务命令写成shell脚本.

建议在my.cnf中添加sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"


━━━━━━━━Written By 桃子━━━━━━━━

你可能感兴趣的:(apache,PHP,linux,mysql,扩展,extension)