天天看点

兄弟连LAMP环境搭建

一、准备工作

1、安装编译工具gcc、gcc-c++

注意解决依赖关系,推荐使用yum安装,若不能联网可使用安装光盘做为yum源——

1)编辑yum配置文件:

# mount /dev/cdrom /mnt/cdrom

# vi /etc/yum.repos.d/CentOS-Media.repo

[c5-media]

name=CentOS-$releasever - Media

baseurl=file:///mnt/cdrom* 修改为光盘挂载点

file:///media/cdrom/

file:///media/cdrecorder/

gpgcheck=1

enabled=1* 改为1意为启用

gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-5

2)剪切/etc/yum.repos.d/CentOS-Base.repo

# mv /etc/yum.repos.d/CentOS-Base.repo /backup

3)依次安装gcc、gcc-c++

# yum -y install gcc

# yum -y install gcc-c++

2、关闭系统RPM安装包的Apache、MySQL的服务

关闭启动的服务httpd、mysqld

# service httpd stop

# service mysqld stop

确定rpm包安装的httpd和mysqld不能开机自启动

chkconfig--level2345httpd(mysqld)off

3、关闭SELinux,允许防火墙80端口访问

使用setup

关闭防火墙和SElinux

1)关闭SELinux

# vi /etc/selinux/config

SELINUX=disabled* 若安装时没有禁用SELinux ,将enforcing改为disabled

修改后需重新启动Linux方可生效!

2)关闭防火墙Netfilter/iptables

因尚未做防火墙讲解,直接简单的关闭所有防火墙设置:

# iptables -F* 如果没有禁用防火墙,默认80端口禁止访问

iptables -Z

iptables-X

4、关闭不必要自启动服务

# ntsysv

以下列出服务可保持自启动,未列出的服务都可以关闭:

atd

crond# atd、crond计划任务

irqbalance

microcode_ctl# 系统irq端口调用,系统服务

network#网络设置

sendmail#邮件

sshd#远程管理

syslog#系统日志

5、拷贝源码包,解包解压缩

建议将LAMP环境安装源码包统一存放在一个目录下,如/lamp

可编写个批量处理脚本,一次性把所有.tar.gz的安装包解包解压缩

# vi tar.sh

cd /lamp

/bin/ls *.tar.gz > ls.list

/bin/ls *.tgz >> ls.list

forTAR in `cat ls.list`

do

/bin/tar-zxf $TAR

done

/bin/rm ls.list

6、查看确认磁盘空间未满

df -h

* 若/分区已满,可以移动安装包到其他分区或删除其他无用文件

如何确定报错:

1)安装过程停止

2)停止后,一页界面中出现error或者warning

如何确定安装成功:

进入安装目录,确认安装程序出现,就是成功

二、编译安装

* 每个源码包配置编译安装完成后,确认安装目录下是否生成安装文件

makeclean

# 安装libxml2

Libxml2 是一个xml c语言版的解析器,本来是为Gnome项目开发的工具,是一个基于MIT License的免费开源软件。它除了支持c语言版以外,还支持c++、PHP、Pascal、Ruby、Tcl等语言的绑定,能在Windows、Linux、Solaris、MacOsX等平台上运行。功能还是相当强大的,相信满足一般用户需求没有任何问题。

#yuminstall-ylibxml2-devel如果报错,安装此包后再尝试安装

cd /lamp/libxml2-2.6.30

./configure --prefix=/usr/local/libxml2/

make

make install

# 安装libmcrypt

libmcrypt是加密算法扩展库。支持DES, 3DES, RIJNDAEL, Twofish, IDEA, GOST, CAST-256, ARCFOUR,SERPENT, SAFER+等算法。

cd /lamp/libmcrypt-2.5.8

./configure --prefix=/usr/local/libmcrypt/

* 需调用gcc-c++编译器,未安装会报错

# 安装libltdl,也在libmcrypt源码目录中,非新软件

cd /lamp/libmcrypt-2.5.8/libltdl

./configure --enable-ltdl-install

make

# 安装zlib

zlib是提供数据压缩用的函式库,由Jean-loup Gailly与Mark Adler所开发,初版0.9版在1995年5月1日发表。zlib使用DEFLATE算法,最初是为libpng函式库所写的,后来普遍为许多软件所使用。此函式库为自由软件,使用zlib授权

cd /lamp/zlib-1.2.3

./configure

make install >>/root/zlib.log

* zlib指定安装目录可能造成libpng安装失败,故不指定,为卸载方便,建议make install执行结果输出到安装日志文件,便于日后卸载

# 安装libpng

libpng 软件包包含 libpng 库.这些库被其他程式用于解码png图片

cd /lamp/libpng-1.2.31

./configure --prefix=/usr/local/libpng/

# 安装jpeg6

用于解码.jpg和.jpeg图片

mkdir /usr/local/jpeg6

mkdir /usr/local/jpeg6/bin

mkdir /usr/local/jpeg6/lib

mkdir /usr/local/jpeg6/include

mkdir -p/usr/local/jpeg6/man/man1

cd /lamp/jpeg-6b

./configure --prefix=/usr/local/jpeg6/--enable-shared --enable-static

* --enable-shared与--enable-static参数分别为建立共享库和静态库使用的libtool

# 安装freetype

FreeType库是一个完全免费(开源)的、高质量的且可移植的字体引擎,它提供统一的接口来访问多种字体格式文件,包括TrueType, OpenType, Type1, CID, CFF, Windows FON/FNT, X11 PCF等。支持单色位图、反走样位图的渲染。FreeType库是高度模块化的程序库,虽然它是使用ANSI C开发,但是采用面向对象的思想,因此,FreeType的用户可以灵活地对它进行裁剪。

cd /lamp/freetype-2.3.5

./configure--prefix=/usr/local/freetype/

# 安装autoconf

Autoconf是一个用于生成可以自动地配置软件源代码包以适应多种Unix类系统的shell脚本的工具

cd /lamp/autoconf-2.61

# 安装GD库

GD库,是php处理图形的扩展库,GD库提供了一系列用来处理图片的API,使用GD库可以处理图片,或者生成图片。在网站上GD库通常用来生成缩略图,或者用来对图片加水印,或者用来生成汉字验证码,或者对网站数据生成报表等。

mkdir /usr/local/gd2

cd /lamp/gd-2.0.35

* png错误,修改方法:

vi gd_png.c

把#include “png.h” 替换为#include "/usr/local/libpng/include/png.h"

./configure--prefix=/usr/local/gd2/ --with-jpeg=/usr/local/jpeg6/--with-freetype=/usr/local/freetype/ --with-png=/usr/local/libpng/

* 如果出现错误,把上面的两步重新执行一次

* 若前面配置zlib时没有指定安装目录,gd配置时不要添加--with-zlib=/usr/local/zlib/参数

# 安装Apache

cd /lamp/httpd-2.2.9

./configure --prefix=/usr/local/apache2/--sysconfdir=/usr/local/apache2/etc/ --with-included-apr --enable-so--enable-deflate=shared --enable-expires=shared --enable-rewrite=shared

* 若前面配置zlib时没有指定安装目录,Apache配置时不要添加--with-z=/usr/local/zlib/参数

启动Apache测试:

/usr/local/apache2/bin/apachectl start

ps –aux | grep httpd

netstat –tlun | grep :80

* 若启动时提示/usr/local/apache2/modules/mod_deflate.so无权限,可关闭SELinux或者执行命令chcon -t texrel_shlib_t/usr/local/apache2/modules/mod_deflate.so ,类似此类.so文件不能载入或没有权限的问题,都是SELinux问题,使用命令:“chcon -t texrel_shlib_t 文件名”即可解决,MySQL和Apache也可能有类似问题。

通过浏览器输入地址访问:http://Apache服务器地址,若显示“It works”即表明Apache正常工作

设置Apache系统引导时启动:

echo "/usr/local/apache2/bin/apachectlstart" >> /etc/rc.d/rc.local

# 安装ncurses

Ncurses 提供字符终端处理库,包括面板和菜单。

1、yum -y install “ncurses*”

注:如果报错,包找不到,是*通配符没有识别,给文件名加双引号“ncurses*”

2、源代码编译:

cd /lamp/ncurses-5.6

./configure--with-shared --without-debug --without-ada --enable-overwrite

* 若不安装ncurses编译MySQL时会报错

* --without-ada参数为设定不编译为ada绑定,因进入chroot环境不能使用ada ;--enable-overwrite参数为定义把头文件安装到/tools/include下而不是/tools/include/ncurses目录

# 安装MySQL

groupadd mysql

useradd -g mysql mysql

* 添加用户组mysql ,将mysql用户默认组设置为mysql用户组

cd /lamp/mysql-5.1.59

./configure--prefix=/usr/local/mysql --without-debug --enable-thread-safe-client--with-pthread --enable-assembler --enable-profiling--with-mysqld-ldflags=-all-static --with-client-ldflags=-all-static--with-extra-charsets=all --with-plugins=all --with-mysqld-user=mysql--without-embedded-server --with-server-suffix=-community--with-unix-socket-path=/tmp/mysql.sock

选项:

--without-debug去除诊断模式

--enable-thread-safe-client以线程方式编译客户端

--with-pthread强制使用pehread库

--enable-assembler使用字符函数的汇编版本

--enable-profiling启动profile功能(慢查询)

--with-mysqld-ldflags=-all-static以静态方式编译服务端

--with-client-ldflags=-all-static以静态方式编译客户端

--with-extra-charsets=all设定支持字符集utf8,gb2312,gbk等。All所有

--with-plugins=all设定支持所有插件

-with-mysqld-user=mysql设定mysql用户

--without-embedded-server去除embedde功能(嵌入服务)

--with-server-suffix=-community给mysql加个后缀,mysql登录时,版本号后面可以看到

--with-unix-socket-path=/tmp/mysql.sock使用unix套接字,提高性能

* --with-extra-charsets=all参数为安装所有字符集

* 若编译失败,,make clean后再make ; make install 。默认不支持innodb存储引擎,其中--with-plugins=all可以把innodb加载进来。

cp /usr/local/mysql/share/mysql/my-medium.cnf /etc/my.cnf

修改mysql配置文件

vi/etc/my.cnf

1)[client]

default-character-set=utf8

2)[mysqld]

character-set-server=utf8

collation-server = utf8_general_ci

* 生成MySQL配置文件

setfacl -m u:mysql:rwx -R /usr/local/mysql

setfacl-m d:u:mysql:rwx -R /usr/local/mysql

* 用acl来让mysql用户对/usr/local/mysql有所有权限

/usr/local/mysql/bin/mysql_install_db--user=mysql

* 创建数据库授权表,初始化数据库

启动MySQL服务:

1.用原本源代码的方式去使用和启动mysql

/usr/local/mysql/bin/mysqld_safe --user=mysql &

2.重启以后还要生效:

vi /etc/rc.local

3.设定mysql密码

/usr/local/mysql/bin/mysqladmin -uroot password 123

清空历史命令history-c

* 给mysql用户root加密码lampbrother

*注意密码不能写成“lampbrother”

/usr/local/mysql/bin/mysql -u root -p

mysql>show databases;

mysql>use test;

mysql>show tables;

mysql>\s#查看字符集是否改为utf8

* 进入mysql以后用set来改密码

mysql> exit

* 登录MySQL客户端控制台设置指定root密码

# 安装PHP

编译前确保系统已经安装了libtool和libtool-ltdl软件包,安装:

yum -y install “libtool*”

yum -y install “libtool-ltdl*”

cd /lamp/php-5.2.6

./configure --prefix=/usr/local/php/--with-config-file-path=/usr/local/php/etc/--with-apxs2=/usr/local/apache2/bin/apxs --with-mysql=/usr/local/mysql/--with-libxml-dir=/usr/local/libxml2/ --with-jpeg-dir=/usr/local/jpeg6/ --with-png-dir=/usr/local/libpng/--with-freetype-dir=/usr/local/freetype/ --with-gd=/usr/local/gd2/ --with-mcrypt=/usr/local/libmcrypt/--with-mysqli=/usr/local/mysql/bin/mysql_config --enable-soap--enable-mbstring=all --enable-sockets

l若前面配置zlib时没有指定安装目录,PHP配置时不要添加--with-zlib-dir=/usr/local/zlib/参数

--with-config-file-path=/usr/local/php/etc/指定配置文件目录

--with-apxs2=/usr/local/apache2/bin/apxs指定apache动态模块位置

--with-mysql=/usr/local/mysql/指定mysql位置

--with-libxml-dir=/usr/local/libxml2/指定libxml位置

--with-jpeg-dir=/usr/local/jpeg6/指定jpeg位置

--with-png-dir=/usr/local/libpng/指定libpng位置

--with-freetype-dir=/usr/local/freetype/指定freetype位置

--with-gd=/usr/local/gd2/指定gd位置

--with-mcrypt=/usr/local/libmcrypt/指定libmcrypt位置

--with-mysqli=/usr/local/mysql/bin/mysql_config指定mysqli位置

--enable-soap支持soap服务

--enable-mbstring=all支持多字节,字符串

--enable-sockets支持套接字

生成php.ini

cp /lamp/php-5.2.6/php.ini-dist/usr/local/php/etc/php.ini

测试Apache与PHP的连通性,看Apache是否能解析php文件

vi /usr/local/apache2/etc/httpd.conf

AddType application/x-httpd-php .php .phtml.phps (注意T的大小写)

* .phtml为将.phps做为PHP源文件进行语法高亮显示

重启Apache服务:/usr/local/apache2/bin/apachectl stop

/usr/local/apache2/bin/apachectlstart

* Apache无法启动,提示cannotrestore segment prot after reloc: Permission denied错误,为SELinux问题,可关闭SELinux或者执行命令chcon -t texrel_shlib_t/usr/local/apache2/modules/libphp5.so

测试:vi /usr/local/apache2/htdocs/test.php

<?

phpinfo();

?>

通过浏览器输入地址访问:http://Apache服务器地址/test.php

Rpm包安装的网页默认目录/var/www/html/

* 有时第一次浏览器测试会失败,关闭浏览器重启再尝试即可,非编译错误

# 编译安装memcache

Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

cd /lamp/memcache-2.2.5

/usr/local/php/bin/phpize

./configure--with-php-config=/usr/local/php/bin/php-config

make && make install

# 编译安装PDO_MYSQL

PDO扩展为PHP访问数据库定义了一个轻量级的、一致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函数执行查询和获取数据。

cd /lamp/PDO_MYSQL-1.0.2/

./configure--with-php-config=/usr/local/php/bin/php-config--with-pdo-mysql=/usr/local/mysql

修改/usr/local/php/etc/php.ini

extension_dir= "/usr/local/php//lib/php/extensions/no-debug-non-zts-20060613/"

extension="memcache.so";

extension="pdo.so";

extension="pdo_mysql.so";

# 安装Zend加速器

cd /lamp/ZendOptimizer-3.2.6-linux-glibc21-i386

./install.sh

l注意PHP配置文件和Apache启动脚本所在目录指定正确即可

l/usr/local/php/etc/

l/usr/local/apache2/bin/apachectl

#安装memcache源代码

首先安装依赖包libevent

yum -yinstall “libevent*”

cd /lamp/memcached-1.4.10

./configure --prefix=/usr/local/memcache

make&& make install

useraddmemcache

passwdmemcache

*Linux不能用root运行memcache软件密码(lampbrother)

/usr/local/memcache/bin/memcached-umemcache &

netstat an | grep:11211

telnet192.168.10.1 11211

stats

写入自启动:

vi/etc/rc.d/rc.local

# 安装phpMyAdmin

cp -r /lamp/phpMyAdmin-3.0.0-rc1-all-languages/usr/local/apache2/htdocs/phpmyadmin

cd/usr/local/apache2/htdocs/phpmyadmin

cpconfig.sample.inc.php config.inc.php

viconfig.inc.php

$cfg['Servers'][$i]['auth_type']= 'cookie';

$cfg['Servers'][$i]['auth_type']= 'http';

* 设置auth_type为http ,即设置为HTTP身份认证模式

通过浏览器输入地址访问:http://Apache服务器地址/phpmyadmin/index.php

用户名为root ,密码为MySQL设置时指定的root密码(lampbrother)

安装过程中大多错误其实为输入错误,可以通过history命令查看历史记录检查。

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'IDENTIFIED BY '123' WITH GRANT OPTION;