LAMP的配置

运维 系统运维
LAMP(Linux-Apache-MySQL-PHP)网站架构是目前国际流行的Web框架,该框架包括:Linux操作系统,Apache网络服务器,MySQL数据库,Perl、PHP或者Python编程语言,所有组成产品均是开源软件,是国际上成熟的架构框架。

  LAMP配置

  1.安装Mysql

   其实老实说直接安装Mysql官方网站提供的rpm包也是一个比较可行的办法,他的官方网站的rpm包的提供基本跟tar包发行是同步的,这点我比较喜欢,至少安装rpm包的在后面的调试中不会出现mysql库文件找不到的情况。但这里还是有必要讲一下自定义安装的步骤,毕竟网友自定义安装的还说挺多的。

  软件获取:http://www.mysql.com/downloads/index.html

  安装步骤:

  tar zxvf mysql-3.23.58.tar.gz

  cd mysql-3.23.58

  ./configure --prefix=/usr/local/mysql --sysconfdir=/etc --localstatedir=/var/lib/mysql

  1.   make  
  2.  
  3.   make install  
  4.  
  5.   #prefix=/usr/local/mysql mysql安装的目标目录  
  6.  
  7.   #sysconfdir=/etc my.ini配置文件的路径  
  8.  
  9.   #localstatedir=/var/lib/mysql 数据库存放的路径  
  10.  

  安装完以后要初始化数据库,当然你是升级的话不用做这步;

  /usr/local/mysql/bin/mysql_install_db

  如果系统没有mysql这个用户的话,最好做以下这步:

  1.   useradd -M -o -r -d /var/lib/mysql -s /bin/bash -c "MySQL Server" -u 27 mysql  
  2.  

  然后我启动mysql

  /usr/local/mysql/bin/safe_mysqld &

  ok,先看看mysql能否正常工作

  mysql -uroot mysql

  一般情况下都是不能正常链接数据库,错误提示一般为:

  ERROR 2002: Cant connect to local MySQL server through socket /var/lib/mysql/mysql.sock (2)

  其实网上大家问的最多的都是整个问题,说什么链接不到mysqld.sock,其实大家不妨看看mysql的错误日志就明白怎么回事,我这里的错误日志是在

  /var/lib/mysql/*.err 你会发现mysql只所以不能启动,是因为/var/lib/mysql的权限不允许mysql服务访问,英文mysql默认是调用mysql用户来启动服务的,好了,既然知道是什么原因找到不能启动,那就简单了。我们只要

  chown -R mysql:mysql /var/lib/mysql 就行,如果还是启动不了,再慢慢调试权限,反正一般启动不了都是权限的问题。

  如果大家还是不能启动不了的话,那就用我的比较繁琐的权限的设置,反正我每次都是这么做的,一般不会有问题,见下:

  1.   chown -R root /usr/local/mysql  
  2.  
  3.   chgrp -R mysql /usr/local/mysql  
  4.  
  5.   chown -R root /usr/local/mysql/bin  
  6.  
  7.   chgrp -R mysql /usr/local/mysql/bin  
  8.  
  9.   chgrp -R mysql /var/lib/mysql  
  10.  
  11.   chmod 777 /var/lib/mysql  
  12.  
  13.   chown -R root /var/lib/mysql/mysql  
  14.  
  15.   chgrp -R mysql /var/lib/mysql/mysql  
  16.  
  17.   chmod 777 /var/lib/mysql/mysql  
  18.  
  19.   chown -R root /var/lib/mysql/mysql/*  
  20.  
  21.   chgrp -R mysql /var/lib/mysql/mysql/*  
  22.  
  23.   chmod 777 /var/lib/mysql/mysql/*  
  24.  
  25.   chmod 777 /usr/local/mysql/lib/mysql/libmysqlclient.a  
  26.  

  做完上面的步骤,然后把你编译目录的一个脚本COPY过去

  1.   cp support-files/mysql.server /etc/rc.d/init.d/mysqld  
  2.  
  3.   chkconfig --add mysqld  
  4.  

  用ntsysv设置使mysql每次启动都能自动运行。

  好了,至此mysql安装完毕,你可以这样起动你的mysql服务

  /etc/rc.d/init.d/mysqld start

  下面这步比较关键,

  1.   ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql  
  2.  
  3.   ln -s /usr/local/mysql/include/mysql /usr/include/mysql  
  4.  

  大家可以不做这步,大可以在编译其他软件的时候自定义myslq的库文件路径,但我还是喜欢把库文件链接到默认的位置,这样你在编译类似PHP,Vpopmail等软件时可以不用指定mysql的库文件地址。

  2.安装Apache1.3.29。我没有选择安装Apache2.0是我对他还是不放心,因为网上最新公布的apache的漏洞基本上是针对2.0,当然大家可以自己选择安装相应的版本。我这里讲的都是采用DSO动态编译的方法编译Apache.

  软件获取:http://httpd.apache.org/

  tar zvxf apache_1.3.29.tar.gz

  cd apache_1.3.29

  修改src/include/httpd.h 增大最大线程数

  1.   #define HARD_SERVER_LIMIT 256  
  2.  

  改成

  1.   #define HARD_SERVER_LIMIT 2560  
  2.  

  保存退出编译apache

  ./configure --prefix=/usr/local/apache --enable-module=so --enable-module=rewrite --enable-shared=max --htdocsdir=/var/www

  1.   make  
  2.  
  3.   make install  
  4.  

  #这里我们通过enable-module参数告诉设置脚本,我们需要启动so和rewrite模块,so模块是用来提DSO支持的apache核心模块,而rewrite模块则是用意实现地址重写的模块,由于rewrite模块需要DBM支持,如果在初次安装时没有编译进apache,以后需要用到时需要重新编译整个apache才可以实现。为此除非你可以确定以后不会用到rewrite模块,否则还是建议你在第一次编译的时候把rewrite模块编译好。

  enable-shared=max 这个参数的作用时编译apache时,把除了so以外的所有apache的标准模块都编译成DSO模块。而不是编译进apache核心内。

  好了安装apache很简单的哦,启动apache看看

  /usr/local/apache/bin/apachectl start

  然后用ie看http://你的服务器地址。应该能看到熟悉的apache羽毛标志。

  3.安装PHP4.3.4

  软件获取:http://www.php.net/downloads.php

  tar zvxf php-4.3.4.tar.gz

  cd php-4.3.4

  ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --enable-force-cgi-redirect --with-freetype-dir=/usr --with-png-dir=/usr --with-gd --enable-gd-native-ttf --with-ttf --with-gdbm --with-gettext --with-iconv --with-jpeg-dir=/usr --with-png --with-zlib --with-xml --enable-calendar --with-apxs=/usr/local/apache/bin/apxs

  1.   make  
  2.  
  3.   make install  
  4.  

  #我这里由于服务器需要用到GD库,所以加了一些支持GD的编译参数 ,GD直接用了redhat自带的GD库,大家没有安装的话可以从安装盘安装,注意除了安装GD以外,还要安装libjpeg,libpng等库文件。另外--with-mysql=/usr/local/mysql指向你安装mysql的路径。--with-apxs指向apache的apxs文件的路径。

  vi /usr/local/apache/conf/httpd.conf

  查找

  在此范围添加

  1.   AddType application/x-httpd-php .php  
  2.  
  3.   AddType application/x-httpd-php-source .phps  
  4.  

  然CPOPY PHP的配置文件

  1.   cp php.ini-dist /usr/local/php/lib/php.ini  
  2.  

  修改php.ini文件

  1.   register_globals = On 
  2.  

  ok!重新启动一下apache服务器

  /usr/local/apache/bin/apachectl restart

  然后写个php测试页info.php:内容如下

  1.   phpinfo();  
  2.  
  3.   ?> 
  4.  

  正常的话,应该能看到php的信息了,恭喜你的Apche+Mysql+PHP安装成功。

【编辑推荐】

Ubuntu下LAMP的配置

Ubuntu10.04下LAMP环境的搭建

LAMP配置MYsql问题-1045

责任编辑:zhaolei 来源: CSDN
相关推荐

2011-03-21 10:15:07

LAMPLAMP安装LAMP配置

2011-03-09 15:13:00

UbuntuLAMP配置

2011-03-14 11:29:43

2011-03-11 10:27:45

UbuntuLAMP配置

2011-03-09 09:25:53

RedHatLinuxLAMP

2011-03-23 09:31:42

LAMP安装LAMP配置

2011-03-21 16:30:42

CentOSLAMP

2011-03-11 13:58:51

2011-03-11 14:48:03

phpmyadmin配置

2011-03-11 14:02:53

Apache配置

2011-03-11 12:57:30

CentosLAMP

2011-03-09 15:25:36

UbuntuLAMPPHPadmin

2011-03-11 16:42:38

Ubuntu安装LAMP

2011-03-23 11:14:47

LAMP配置

2011-03-22 13:06:18

LAMPMysql

2011-03-22 12:53:35

UbuntuLAMPApache

2011-03-14 11:01:42

LAMPMYsql1045

2011-03-21 11:33:09

LAMPApache

2011-03-11 14:02:55

LAMP安装PHP5

2011-03-21 13:04:38

LAMPApache
点赞
收藏

51CTO技术栈公众号