手动搭建LAMP环境

配置yum源

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

  1. 编辑yum配置文件:
    mount /dev/sr0 /media
    vim /etc/yum.repos.d/CentOS-Media.repo

    [c6-media] 
    name=CentOS-$releasever - Media
    baseurl=file:///media/   * 修改为光盘挂载点
    gpgcheck=0
    enabled=1  * 改为1意为启用
    gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
    
  2. 剪切mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak

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

yum -y install gcc
yum -y install gcc-c++

准备工作

  1. 关闭系统rpm安装包的apache、mysql服务
    service httpd stop
    service mysqld stop
    并确定它们不能开机自启动
    chkconfig httpd off
    chkconfig mysqld off

  2. 关闭SELinux,允许防火墙80端口访问
    1)关闭SELinux
    vim /etc/selinux/config

    SELINUX=disabled # 若安装时没有禁用SELinux ,将enforcing改为disabled,重启Linux生效
    

    2)关闭防火墙Netfilter/iptables(因未做防火墙讲解,直接简单的关闭所有防火墙设置)
    iptables -F * 如果没有禁用防火墙,默认80端口禁止访问
    iptables -Z
    iptables -X

  3. 列出所有自启动服务ntsysv
    以下服务可保持自启动,其余都可以关闭:

    atd    
    crond         # atd、crond计划任务
    irqbalance
    microcode_ctl # 系统irq端口调用,系统服务
    network       # 网络设置
    sendmail      # 邮件
    sshd          # 远程管理
    syslog        # 系统日志
    
  4. 可编写个批量处理脚本,一次性把所有.tar.gz的安装包解包解压缩
    vim tar.sh

    cd /lamp
    /bin/ls *.tar.gz > ls.list
    for TAR in `cat ls.list`
    do
        /bin/tar -zxf $TAR
    done
    /bin/rm ls.list
    
  5. 查看确认磁盘空间未满df -h

安装libxml2

libxml2 是一个c语言版的xml解析器,是一个基于MIT License的免费开源软件。它除了支持c语言版以外,还支持C++、PHP、Pascal、Ruby、Tcl等语言的绑定,能在Windows、Linux、Solaris、MacOsX等平台上运行。
libxml是一个用来解析XML文档的函数库。它用C语言写成, 并且能为多种语言所调用,例如C/C++、XSH、C#、Python、Kylix/Delphi、Ruby、PHP等。Perl中也可以使用XML::LibXML模块。它最初是为GNOME开发的项目,但现在可以用在各种各样的方面。libxml 代码可移植性非常好,因为它基于标准的ANSI C库, 并采用MIT许可证。

如果报错,安装此包后再尝试安装
yum install -y libxml2-devel

必需安装
yum -y install python-devel

cd /lamp/libxml2-2.9.1
./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

安装libltdl

也在libmcrypt源码目录中,非新软件
cd /lamp/libmcrypt-2.5.8/libltdl
./configure --enable-ltdl-install
make
make install

安装mhash

Mhash是基于离散数学原理的不可逆向的php加密方式扩展库,其在默认情况下不开启。可以用于创建校验数值,消息摘要,消息认证码,以及无需原文的关键信息保存(如密码)等。
cd /lamp/mhash-0.9.9.9
./configure
make
make install

安装mcrypt

mcrypt 是php重要的加密支持扩展库,支持20多种加密算法和8种加密模式。
cd /lamp/mcrypt-2.6.8
下面两行是一条命令,LD_LIBRARY_PATH用于指定libmcrypt和mhash库的位置。
–with-libmcrypt-prefix用于指定libmcrypt软件位置。
LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib \
./configure --with-libmcrypt-prefix=/usr/local/libmcrypt

make
make install

安装zlib

zlib是提供数据压缩用的函式库,由Jean-loup Gailly与Mark Adler所开发,初版0.9版在1995年5月1日发表。zlib使用DEFLATE算法,最初是为libpng函式库所写的,后来普遍为许多软件所使用。此函式库为自由软件,使用zlib授权。
cd /lamp/zlib-1.2.3
./configure
make
make install
zlib指定安装目录可能造成libpng安装失败,故不指定,为卸载方便,建议make install执行结果输出到安装日志文件,便于日后卸载。

安装libpng

libpng 软件含 libpng 库,这些库被其他程式用于解码png图片。
cd /lamp/libpng-1.2.31
./configure --prefix=/usr/local/libpng
make
make install

安装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
make
make install
–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/
make
make install

安装Apache

准备工作:

(1)将下面两个包拷贝到apache安装包中。
cp -r /lamp/apr-1.4.6 /lamp/httpd-2.4.7/srclib/apr
cp -r /lamp/apr-util-1.4.1 /lamp/httpd-2.4.7/srclib/apr-util
没有会报错 configure: error: Bundled APR requested but not found at ./srclib/. Download and unpack the corresponding apr and apr-util packages to ./srclib/.
(2)安装pcre
cd /lamp/pcre-8.34
./configure && make && make install
没有会报错 configure: error: pcre-config for libpcre not found. PCRE is required and available from
(3)安装openssl-devel
yum install openssl-devel
没有会报错 checking whether to enable mod_ssl… configure: error: mod_ssl has been requested but can not be built due to prerequisite failures

安装:

cd /lamp/httpd-2.4.7
./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/参数

测试:

/usr/local/apache2/bin/apachectl start
ps aux | grep httpd
netstat –tlun | grep :80
通过浏览器输入地址访问,若显示“It works”即表明Apache正常工作。
若启动时提示/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 文件名即可解决。

开机启动:

vim /etc/rc.local
/usr/local/apache2/bin/apachectl start

安装ncurses

ncurses提供字符终端处理库,包括面板和菜单。它提供了一套控制光标,建立窗口,改变前景背景颜色以及处理鼠标操作的函数。使用户在字符终端下编写应用程序时绕过了那些恼人的底层机制。简而言之,他是一个可以使应用程序直接控制终端屏幕显示的函数库。若不安装ncurses编译MySQL时会报错。

(1)yum安装
yum -y install ncurses-devel
如果报错包找不到,是通配符没有识别,给文件名加双引号 “ncurses*”

(2)源代码编译
cd /lamp/ncurses-5.9
./configure --with-shared --without-debug --without-ada --enable-overwrite
make
make install
–without-ada参数为设定不编译为ada绑定,因进入chroot环境不能使用ada
–enable-overwrite参数为定义把头文件安装到/tools/include下而不是/tools/include/ncurses目录
–with-shared 生成共享库

安装cmake和bison

mysql在5.5以后,不再使用./configure进行编译安装。而使用cmake工具替代了./configure工具。
bison是一个自由软件,用于自动生成语法分析器程序,可用于所有常见的操作系统。
yum -y install cmake
yum -y install bison

安装MySQL

添加用户组mysql ,将mysql用户默认组设置为mysql用户组
groupadd mysql
useradd -g mysql mysql

cd /lamp/mysql-5.5.48
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_USER=mysql -DMYSQL_TCP_PORT=3306
make
make install

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql		安装位置
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock			指定socket(套接字)文件位置
-DEXTRA_CHARSETS=all						扩展字符支持
-DDEFAULT_CHARSET=utf8    					默认字符集
-DDEFAULT_COLLATION=utf8_general_ci    		默认字符校对
-DWITH_MYISAM_STORAGE_ENGINE=1   			安装myisam存储引擎
-DWITH_INNOBASE_STORAGE_ENGINE=1    		安装innodb存储引擎
-DWITH_MEMORY_STORAGE_ENGINE=1  			安装memory存储引擎
-DWITH_READLINE=1    						支持readline库
-DENABLED_LOCAL_INFILE=1   					启用加载本地数据
-DMYSQL_USER=mysql  						指定mysql运行用户
-DMYSQL_TCP_PORT=3306						指定mysql端口

如果报错,清除缓存 rm CMakeCache.txt

修改mysql目录权限
cd /usr/local/mysql/
chown -R mysql .
chgrp -R mysql .

创建数据库授权表,初始化数据库
/usr/local/mysql/scripts/mysql_install_db --user=mysql

修改mysql目录权限
chown -R root .
chown -R mysql data

复制mysql配置文件
cp support-files/my-medium.cnf /etc/my.cnf

二次授权
/usr/local/mysql/scripts/mysql_install_db --user=mysql

启动MySQL服务

  1. 用原本源代码的方式去使用和启动mysql
    /usr/local/mysql/bin/mysqld_safe --user=mysql &
  2. 重启以后还要生效
    vim /etc/rc.local
    /usr/local/mysql/bin/mysqld_safe --user=mysql &
  3. 设定mysql密码
    /usr/local/mysql/bin/mysqladmin -uroot password 123456
    注意密码不能写成 “123456”
    如果报错Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’ (2)
    则完善mysql配置文件/etc/my.cnf,添加[mysqld]和[client]的mysql.sock位置。
    清空历史命令history -c
  4. 连接数据库
    /usr/local/mysql/bin/mysql -u root -p
    mysql>\s 查看字符集是否改为utf8。
    进入mysql以后用set来改密码。

安装php

准备

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

安装php

cd /lamp/php-7.0.7
./configure --prefix=/usr/local/php/ --with-config-file-path=/usr/local/php/etc/ --with-apxs2=/usr/local/apache2/bin/apxs --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-mcrypt=/usr/local/libmcrypt/ --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-soap --enable-mbstring=all --enable-sockets --with-pdo-mysql=/usr/local/mysql --with-gd --without-pear

若前面安装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-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-mcrypt=/usr/local/libmcrypt/		    指定libmcrypt位置
--with-mysqli=/usr/local/mysql/bin/mysql_config		指定mysqli位置
--with-gd                               启用gd库
--enable-soap							支持soap服务
--enable-mbstring=all					支持多字节,字符串
--enable-sockets						支持套接字
--with-pdo-mysql=/usr/local/mysql	    启用mysql的pdo模块支持
--without-pear	                不安装pear(安装pear需要连接互联网,pear是php扩展与应用库)

如果报错 configure: error: png.h not found.
是选择安装GD模块才会出现的错误,安装libpng, devel包即可解决:
yum install libpng
yum install libpng-devel

make
make install

生成php.ini

mkdir /usr/local/php/etc/
cp /lamp/php-7.0.7/php.ini-production /usr/local/php/etc/php.ini

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

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

AddType application/x-httpd-php .php .phtml 
AddType application/x-httpd-php-source .phps

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

重启apache服务
/usr/local/apache2/bin/apachectl stop
/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

测试
vim /usr/local/apache2/htdocs/test.php(rpm包安装的网页默认目录 /var/www/html/)

<?php
    phpinfo();

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

添加环境变量

查看环境变量
echo $PATH
添加
export PATH=/usr/local/php/bin:$PATH

永久添加
vim /etc/profile
在最后一行加上

export PATH="/usr/local/php/bin:$PATH"
export PATH="/usr/local/mysql/bin:$PATH"

source /etc/profile

安装openssl

openssl是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。

yum -y install openssl-devel 必须安装
cd /lamp/php-7.0.7/ext/openssl
mv config0.m4 config.m4 否则报错找不到config.m4
/usr/local/php/bin/phpize
./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config
make
make install

修改php配置文件
vim /usr/local/php/etc/php.ini
打开注释并修改
extension_dir = "/usr/local/php/lib/php/extensions/no-debug-zts-20151012/"
添加
extension="openssl.so"
重启apache,在phpinfo中可以找到这个模块。

安装phpMyAdmin

cp -r /lamp/phpMyAdmin-4.1.4-all-languages /usr/local/apache2/htdocs/phpmyadmin
cd /usr/local/apache2/htdocs/phpmyadmin
cp config.sample.inc.php config.inc.php
vim config.inc.php

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

设置auth_type为http,即设置为http身份认证模式。
通过浏览器访问
http://服务器地址/phpmyadmin/index.php
用户名root,密码为mysql设置时指定的root密码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值