微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

centos编译安装lamp环境

一、准备工作

1、安装编译工具gccgcc-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依次安装gccgcc-c++ # yum -y install gcc

# yum -y install gcc-c++

2关闭系统RPM安装包的ApacheMysqL的服务 关闭启动的服务httpdMysqLd # service httpd stop

# service MysqLd stop

确定rpm包安装的httpdMysqLd不能开机自启动

chkconfig --level 2345 httpdMysqLdoff

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

使用setup

关闭防火墙和SElinux

1关闭SELinux

# vi /etc/selinux/config

SELINUX=disabled*若安装时没有禁用SELinux,将enforcing改为disabled 修改后需重新启动Linux方可生效!

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

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

4关闭不必要自启动服务

#ntsysv

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

atd

crond# atdcrond计划任务

irqbalance

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

network#网络设置

sendmail#邮件

sshd#远程管理

syslog#系统日志

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

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

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

# vitar.sh

cd /lamp /bin/ls *.tar.gz > ls.list /bin/ls *.tgz >> ls.list for TAR in `cat ls.list`dotar -zxf $TARdonerm ls.list 6、查看确认磁盘空间未满

df -h

*/分区已满,可以移动安装包到其他分区或删除其他无用文件 如何确定报错:

1)安装过程停止

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

如何确定安装成功:

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

二、编译安装

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

#安装libxml2

Libxml2一个xml c语言版的解析器,本来是为Gnome项目开发的工具,是一个基于MIT License的免费开源软件。它除了支持c语言版以外,还支持c++PHPPascalRubyTcl等语言的绑定,能在WindowsLinuxSolarisMacOsX等平台上运行。功能还是相当强大的,相信满足一般用户需求没有任何问题。#yum install -y libxml2-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/

make

make install

*调用gcc-c++编译器,未安装会报错#安装libltdl,也在libmcrypt源码目录中,非新软件

cd/lamp/libmcrypt-2.5.8/libltdl

./configure --enable-ltdl-install

#安装zlib

zlib是提供数据压缩用的函式库,由Jean-loup GaillyMark Adler所开发,初版0.9版在199551日发表。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

./configure

#安装GD

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

mkdir /usr/local/gd2

cd /lamp/gd-2.0.35

* png错误修改方法 vi gd_png.c#includepng.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/

make

*如果出现错误,把上面的两步重新执行一次 *若前面配置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

make

make install

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

启动Apache测试:

/usr/local/apache2/bin/apachectl start ps –aux| grep httpd

netstattlun | 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文件名”即可解决MysqLApache也可能有类似问题。 通过浏览器输入地址访问:http://Apache服务器地址,若显示It works”即表明Apache正常工作

设置Apache系统引导时启动:

echo "/usr/local/apache2/bin/apachectl start" >> /etc/rc.d/rc.local#安装ncursesNcurses提供字符终端处理库,包括面板和菜单 1yum -y installncurses*

注:如果报错,包找不到,是*通配符没有识别,给文件名加双引号 “ncurses* 2、源代码编译:

cd /lamp/ncurses-5.6

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

make

make install

*若不安装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设定支持字符集utf8gb2312gbk等。All所有--with-plugins=all设定支持所有插件-with-MysqLd-user=mysql设定MysqL用户--without-embedded-server去除embedde功能(嵌入服务)--with-server-suffix=-communityMysqL加个后缀,MysqL登录时,版本号后面可以看到--with-unix-socket-path=/tmp/MysqL.sock使用unix套接字,提高性能

参数为安装所有字符集*若编译失败,,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

/usr/local/MysqL/bin/MysqLd_safe --user=MysqL &

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

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

yum -y installlibtool*yum -y installlibtool-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

若前面配置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

测试PHP的连通性是否能解析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/apachectlstop

/usr/local/apache2/bin/apachectl start

* Apache无法启动,提示cannot restore 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.PHPRpm包安装的网页认目录/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&&makeinstall

#编译安装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

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

l/usr/local/PHP/etc//usr/local/apache2/bin/apachectl#安装memcache代码

首先安装依赖包libevent

yum -y installlibevent* cd /lamp/memcached-1.4.10

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

make && make install

useradd memcache

passwd memcache

* Linux不能用root运行memcache软件密码(lampbrother /usr/local/memcache/bin/memcached -umemcache &

netstat an | grep :11211

telnet 192.168.10.1 11211

stats

写入自启动:

vi /etc/rc.d/rc.local

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

#安装PHPMyAdmin cp-r/lamp/PHPMyAdmin-3.0.0-rc1-all-languages /usr/local/apache2/htdocs/PHPmyadmin

cd /usr/local/apache2/htdocs/PHPmyadmin

cp config.sample.inc.PHP config.inc.PHP

vi config.inc.PHP

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

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

*设置auth_typehttp,即设置为HTTP身份认证模式 通过浏览器输入地址访问:http://Apache服务器地址/PHPmyadmin/index.PHP用户名root,密码为MysqL设置时指定的root密码(lampbrother 安装过程中大多错误其实为输入错误,可以通过history命令查看历史记录检查。

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

sql语句,不是linux命令

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。