web 平台搭建-LAMP-源码包(CentOS-7)

一、准备工作

环境要求:
操作系统:CentOS 7.X 64 位

关闭 SELinuxfirewalld 防火墙
防火墙

[root@localhost ~]$ systemctl stop firewalld   #临时关闭
[root@localhost ~]$ systemctl disable firewalld   #永久关闭,enable开启

SELinux

[root@localhost ~]$ setenforce 0 && sed -i 's/^SELINUX=.*/SELINUX=disabled/' /etc/selinux/config && reboot
[root@localhost ~]$ getenforce

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

可参考之前的文章设置yum源
Linux配置yum源

[root@localhost ~]$ yum -y install gcc gcc-c++ make

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

为了防止 rpm 安装的软件和接下来安装的源码软件包冲突

[root@localhost ~]$ systemctl stop httpd && systemctl disable httpd
[root@localhost ~]$ systemctl stop mysqld && systemctl disable mysqld

1.3 拷贝源码包,解包解压缩

软件包百度网盘:
链接:https://pan.baidu.com/s/1rQ7_9XU2xSsg691bp-QrPw 提取码:u1mi

[root@localhost ~]$ yum install lrzsz #安装lrzsz,源码包直接拖进shell即可
[root@localhost ~]$ unzip LAMP-php7.zip #解压
[root@localhost ~]$ mkdir /lamp
[root@localhost ~]$ cd LAMP-php7/
[root@localhost ~]$ mv * /lamp
[root@localhost ~]$ vim tar.sh 
#!/bin/bash
cd /lamp
/bin/ls *.tar.gz > ls.list
 for TAR in $(cat ls.list)
	 do
	 /bin/tar -xf $TAR
	 done
/bin/rm ls.list
unzip pecl-memcache-php7.zip > /dev/null 
echo "ok"

源码软件包安装报错确认与解决方案

  • echo $? #安装软件过程中由于频繁刷屏,建议在每个步骤结束后执行此命令
  • ./configure #此步骤报错多是依赖关系没解决或是编译工具未安装(注意关键词提示)
  • make #此步骤多是编译时选项参数书写错误、不存在、漏写等问题#一般需要检查上一个步骤:./configure --help

注意:若遇到报错,最简答的办法是,找到问题解决后重新解压软件,重新安装,步骤最简洁

二、编译安装

在这里插入图片描述

注意:每个源码包配置编译安装完成后,确认安装目录下是否生成安装文件(并确定目录是否正确)
建议将安装路径指定为[--prefix=/usr/local/软件名]格式

2.1 安装 libxml2

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

[root@localhost ~]$ yum install -y libxml2-devel python-devel
[root@localhost ~]$ cd /lamp/libxml2-2.9.1
[root@localhost ~]$ ./configure --prefix=/usr/local/libxml2/  #检查依赖关系,检查编译工具,指定安装的功能,位置
[root@localhost ~]$ echo $?
0
[root@localhost ~]$ make #编译,源码转换为二进制
[root@localhost ~]$ make install #安装

[root@localhost ~]$ cd /usr/local/libxml2/
[root@localhost ~]$ ls
bin  include  lib  share

2.2 安装 libmcrypt

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

[root@localhost ~]$ cd /lamp/libmcrypt-2.5.8
[root@localhost ~]$ ./configure --prefix=/usr/local/libmcrypt/
[root@localhost ~]$ make 
[root@localhost ~]$ make install

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

[root@localhost ~]$ cd /lamp/libmcrypt-2.5.8/libltdl
[root@localhost ~]$ ./configure --enable-ltdl-install && make && make install

2.3 安装 mhash

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

[root@localhost ~]$ cd /lamp/mhash-0.9.9.9
[root@localhost ~]$ ./configure && make && make install

2.4 安装 mcrypt

mcrypt 是 php 里面重要的加密支持扩展库。mcrypt 库支持 20 多种加密算法和 8 种加密模式

[root@localhost ~]$ cd /lamp/mcrypt-2.6.8
[root@localhost ~]$ export LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib
#变量:LD_LIBRARY_PATH 用于指定 libmcrypt 和 mhash 的库的位置
[root@localhost ~]$ ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt && make && make install

2.5 安装 zlib

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

[root@localhost ~]$ cd /lamp/zlib-1.2.3
[root@localhost ~]$ ./configure
#然后修改配置文件,否则无法正常安装此软件
[root@localhost ~]$ vim Makefile
 CFLAGS=-O3 -DUSE_MMAP -fPIC
 #找到 CFLAGS=-O3 -DUSE_MMAP,在后面加入 -fPIC 变成(注意:小 f 大 PIC,空格)
[root@localhost ~]$ make && make install

2.6 安装 libpng

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

[root@localhost ~]$ cd /lamp/libpng-1.2.31
[root@localhost ~]$ ./configure --prefix=/usr/local/libpng && make && make install

2.7 安装 jpeg6

jpeg6 提供用于解码.jpg 和.jpeg 图片的库文件

[root@localhost ~]$ mkdir /usr/local/jpeg6
[root@localhost ~]$ mkdir /usr/local/jpeg6/bin
[root@localhost ~]$ mkdir /usr/local/jpeg6/lib
[root@localhost ~]$ mkdir /usr/local/jpeg6/include
[root@localhost ~]$ mkdir -p /usr/local/jpeg6/man/man1

注意:此软件默认不会自动创建所需目录,所以目录必须手工建立

[root@localhost ~]$ yum -y install libtool*
[root@localhost ~]$ cd /lamp/jpeg-6b
[root@localhost ~]$ cp -a /usr/share/libtool/config/config.sub ./
[root@localhost ~]$ cp -a /usr/share/libtool/config/config.guess ./
#复制 libtool 中的文件,覆盖 jpeg-6b 中的文件(64 位中的问题) 
[root@localhost ~]$ ./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static
[root@localhost ~]$ make && make install

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

2.8 安装 freetype

FreeType 库是一个完全免费(开源)的、高质量的且可移植的字体引擎,它提供统一的接口来访问多种字体格式文件,支持单色位图、反走样位图的渲染。

[root@localhost ~]$ cd /lamp/freetype-2.3.5
[root@localhost ~]$ ./configure --prefix=/usr/local/freetype/ && make && make install

2.9 安装 Apache

源码包 2.4.*版本中默认没有集成 apr 的依赖包,所以需要提前解决依赖问题

[root@localhost ~]$ cd /lamp/httpd-2.4.7
[root@localhost ~]$ cp -a /lamp/apr-1.4.6 /lamp/httpd-2.4.7/srclib/apr
[root@localhost ~]$ cp -a /lamp/apr-util-1.4.1 /lamp/httpd-2.4.7/srclib/apr-util

Apache 默认需要依赖 pcre 软件,但由于 Apache 软件版本较高,则系统预安装的 pcre 无法使用,所以需要人为手动安装适合版本

[root@localhost ~]$ cd /lamp/pcre-8.34
[root@localhost ~]$ ./configure && make && make install

Apache 的加密传输模块 mod_ssl,需要安装此软件产生

[root@localhost ~]$ yum -y install openssl-devel

httpd 软件安装

[root@localhost ~]$ cd /lamp/httpd-2.4.7
[root@localhost ~]$ ./configure --prefix=/usr/local/apache2 --sysconfdir=/usr/local/apache2/etc --with-included-apr --enable-so --enable-deflate=shared --enable-expires=shared --enable-rewrite=shared --enable-ssl
#  --prefix: 安装目录
#  --sysconfdir: 配置文件位置

[root@localhost ~]$ make && make install

若前面配置 zlib 时没有指定安装目录,Apache 配置时不要添加–with-z=/usr/local/zlib/参数, --enable-ssl 选项是为了后期实现 https 提前设置的参数

启动 Apache 测试

[root@localhost ~]$ /usr/local/apache2/bin/apachectl start
[root@localhost ~]$ ps aux | grep httpd
#使用进程查看命令确认 Apache 是否启动,是否产生进程

[root@localhost ~]$ netstat -tlun | grep :80
#使用网络进程查看命令确认 Apache 是否启动,是否开启了 80 监听端口

注意事项: 在 CentOS 7 操作系统上 Apache 默认监听了 Ipv6 地址的 80 端口,没有监听 Ipv4 的地址,所以需要修改下配置文件使其监听。 Listen 0.0.0.0:80

[root@localhost ~]$ vim /usr/local/apache2/etc/httpd.conf
#添加如下内容
Listen 0.0.0.0:80

#修改如下内容
ServerName localhost:80

报错提示: 若启动时提示/usr/local/apache2/modules/mod_deflate.so 无权限,可关闭 SELinux 解 决,类似此类.so 文件不能载入或没有权限的问题,都是 SELinux 问题,MySQL 和 Apache 都可能有类似问题。

警告提示: 发现启动服务提示:AH00558: httpd: Could not reliably determine the server’s fully qualified domain name, using localhost.localdomain. Set the ‘ServerName’ directive globally to suppress this message

解决办法: 打开主配置文件 /usr/local/apache2/httpd.conf
搜索 ServerName (约在 200 行左右)
改为 ServerName localhost:80(并且去掉前面的#注释)

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

2.10 安装 ncurses

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

[root@localhost ~]$ yum -y install ncurses-devel
[root@localhost ~]$ cd /lamp/ncurses-5.9
[root@localhost ~]$ ./configure --with-shared --without-debug --without-ada --enable-overwrite
[root@localhost ~]$ make && make install

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

2.11 安装 cmake 和 bison

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

[root@localhost ~]$ yum -y install cmake bison

2.12 安装 MySQL

为 MySQL 软件创建运行用户,创建为系统用户,并限制此用户登录操作系统

[root@localhost ~]$ useradd -r -s /sbin/nologin mysql
[root@localhost ~]$ cd /lamp/mysql-5.5.48
[root@localhost ~]$ 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
#有点长,要全部复制
[root@localhost ~]$ 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 端口

MySQL 安装后需要调整相应配置文件和参数才能正常运行

修改 MySQL 目录的用户归属

[root@localhost ~]$ cd /usr/local/mysql/
[root@localhost ~]$ chown -R root .
[root@localhost ~]$ chown -R mysql data

生成配置文件,并初始化授权表

复制 MySQL 配置文件到指定位置,覆盖掉系统自带文件

[root@localhost ~]$ cp -a /lamp/mysql-5.5.48/support-files/my-medium.cnf /etc/my.cnf

创建数据库授权表,初始化数据库,相当于安装完操作系统后的引导设置(添加第一个用户)

[root@localhost ~]$ cd /usr/local/mysql 
[root@localhost ~]$ ./scripts/mysql_install_db --user=mysql

报错提示: FATAL ERROR: Could not find ./bin/my_print_defaults

原因: mysql_install_db 初始化所调用文件时使用的是相对路径,路径不在/usr/local/mysql 时,是无法调用 my_print_defaults 文件并初始化成功的。

启动 MySQL 服务

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

[root@localhost ~]$ /usr/local/mysql/bin/mysqld_safe --user=mysql &

[root@localhost ~]$ netstat -antp | grep 3306

设定 MySQL 密码

[root@localhost ~]$ /usr/local/mysql/bin/mysqladmin -uroot password 123456

登录 MySQL

[root@localhost ~]$ /usr/local/mysql/bin/mysql -u root -p
Enter password:      #输入密码
mysql>show databases;
mysql>use test;
mysql>show tables;
mysql>exit

2.13 安装 PHP

[root@localhost ~]$ cd /lamp/php-7.0.7
[root@localhost ~]$ ./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
[root@localhost ~]$ make && make install

选项详解:

--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  需要连接互联网)

PHP 安装后需要调整相应配置文件和参数才能正常运行

生成 php 配置文件

[root@localhost ~]$ mkdir /usr/local/php/etc
[root@localhost ~]$ cp /lamp/php-7.0.7/php.ini-production /usr/local/php/etc/php.ini

修改 Apache 配置文件,使其识别*.php 文件,并能通过 php 模块调用 php 进行页面解析

[root@localhost ~]$ vim /usr/local/apache2/etc/httpd.conf
#添加下面两行
AddType application/x-httpd-php .php .phtml 
AddType application/x-httpd-php-source .phps

重启 Apache 服务

[root@localhost ~]$ /usr/local/apache2/bin/apachectl restart

测试 php 页面是否能正常解析(即 apache 和 php 连通性)

[root@localhost ~]$ vim /usr/local/apache2/htdocs/test.php
 <?php
	phpinfo();
 ?>

通过浏览器输入地址访问:http://Apache服务器地址/test.php
在这里插入图片描述

2.14 为 PHP 安装 openssl 模块

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

[root@localhost ~]$ cd /lamp/php-7.0.7/ext/openssl
[root@localhost ~]$ mv config0.m4 config.m4
[root@localhost ~]$ /usr/local/php/bin/phpize
[root@localhost ~]$ ./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config && make && make install

2.15 为 PHP 安装 memcache 模块

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

[root@localhost ~]$ cd /lamp/pecl-memcache-php7
[root@localhost ~]$ /usr/local/php/bin/phpize
[root@localhost ~]$ ./configure --with-php-config=/usr/local/php/bin/php-config && make && make install

2.16 修改 php 配置文件,使其识别并调用 openssl 和 memcache 两个模块

[root@localhost ~]$ vim /usr/local/php/etc/php.ini
 extension_dir="/usr/local/php/lib/php/extensions/no-debug-zts-20151012/"
 #添加以上路径(此路径来自于模块安装命令的结果)
 extension="openssl.so";
 extension="memcache.so";
 #添加以上两个库文件的调用

重启 apache,刷新 phpinfo 页面,并查看是否有两个新增的模块

[root@localhost ~]$ /usr/local/apache2/bin/apachectl restart

2.17 安装 memcached 服务

[root@localhost ~]$ wget ftp://ftp.pbone.net/mirror/ftp.centos.org/7.6.1810/os/x86_64/Packages/libevent-devel-2.0.21-4.el7.x86_64.rpm
[root@localhost ~]$ yum -y install libevent-devel
[root@localhost ~]$ cd /lamp/memcached-1.4.17
[root@localhost ~]$ ./configure --prefix=/usr/local/memcache && make && make install

[root@localhost ~]$ useradd -r -s /sbin/nologin memcache
#添加 memcache 用户,此用户不用登录,不设置密码

[root@localhost ~]$ /usr/local/memcache/bin/memcached -umemcache &
#启动 memcache 服务,并设置为后台运行

[root@localhost ~]$ netstat -an | grep :11211
#检查 memcache 是否正常启动,并监听了 11211 端口

2.18 安装 phpMyAdmin

phpMyAdmin 是一个以 PHP 为基础,以 Web-Base 方式架构在网站主机上的 MySQL 的数据库管理工具,让管理者可用 Web 接口管理 MySQL 数据库。

[root@localhost ~]$ cp -a /lamp/phpMyAdmin-4.1.4-all-languages /usr/local/apache2/htdocs/phpmyadmin
[root@localhost ~]$ cd /usr/local/apache2/htdocs/phpmyadmin
[root@localhost ~]$ cp -a config.sample.inc.php config.inc.php
[root@localhost ~]$ vim config.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 密码 123456

2.19 设置 Apache、MySQL、Memcache 开机自启

借助系统自带脚本/etc/rc.local,此脚本开机后会自动加载,我们可以将源码安装的服务启动命令写入该脚本,间接实现开机自启动

[root@localhost ~]$ vim /etc/rc.local
/usr/local/apache2/bin/apachectl start
/usr/local/mysql/bin/mysqld_safe --user=mysql &
/usr/local/memcache/bin/memcached -umemcache &

2.20 项目迁移

  1. 把 php 项目拷贝到网站默认目录下:/usr/local/apache2/htdocs/**
  2. 使用 phpMyAdmin 创建网站所需数据库
    注意事项:注意目录权限和归属,防止权限过大或者权限过小
    切记:做完 LAMP 环境后保存一个快照,后面 Apache 要使用!
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值