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
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已装好。
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 桃子━━━━━━━━