基于CentOS 6.8平台最新源代码包编译安装LAMP环境搭建(Apache+MySQL+PHP)
部署环境
系统:CentOS 6.8 x86_64
Apache:2.4.23
MySQL:5.7.14
PHP:7.0.10
apr:1.5.2
apr-util:1.5.4
boost:1.59.0
cmake:3.6.1
pcre:8.39
软件包准备
这里CentOS6.8系统(无需图形环境)的安装过程略,使用个人电脑(Windows系统)的浏览器访问Apache官方网站 http://www.apache.org/ 点击下载页面标签
点击建议的镜像下载站点
找到apr目录
这里下载最新版tar.gz格式的apr软件包,右击选择"复制链接地址"
登录到CentOS6.8系统,切换到/usr/src目录下,使用curl工具下载刚刚复制的链接文件
curl -O http://mirrors.cnnic.cn/apache/apr/apr-1.5.2.tar.gz
按照此方法将apr-util软件包也下载到/usr/src目录下
返回到上一级目录下
找到httpd目录
下载最新版Apache软件到/usr/src目录下
访问pcre官网 http://www.pcre.org/ 进入下载链接
下载最新版pcre软件包到/usr/src目录下
访问boost官网 http://www.boost.org/ 进入1.59.0版本信息
点击.tar.gz格式文件包
跳转到下载页面,自动激活浏览器下载器,复制下载地址到CentOS系统下载即可。
访问cmake官网 https://cmake.org/ 下载页面标签
下载最新发行版本
访问MySQL官网 https://www.mysql.com/
由于MySQL已经被Oracle公司收购,MySQL企业版的下载需要Oracle的授权,所以这里下载免费社区版。
前往下载页面
可用版本选择源代码包
通用Linux平台的tar源代码包
不登录账户,仅下载。
复制下载器地址进行下载
访问PHP官网 http://www.php.net/ 下载最新发行版本
选择距离我们最近的镜像站点,任选一个节点下载。
复制下载器里链接地址进行下载
所需软件包下载完成
部署过程
使用yum安装所必须的系统软件包
yum install -y gcc gcc-c++ ncurses ncurses-devel perl libxml2 libxml2-devel curl-devel libpng-devel
安装apr软件,解压、配置、有一个无法删除的错误,可以忽略。
tar zxf apr-1.5.2.tar.gz
cd apr-1.5.2
./configure --prefix=/usr/local/apr
编译安装
make && make install
切换到/usr/src目录继续安装apr-util软件
tar zxf apr-util-1.5.4.tar.gz
cd apr-util-1.5.4
./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr/
编译安装
make && make install
切换回/usr/src目录,继续安装pcre软件
tar zxf pcre-8.39.tar.gz
cd pcre-8.39
./configure --prefix=/usr/local/pcre
编译安装
make && make install
切换回/usr/src目录,安装Apache
tar zxf httpd-2.4.23.tar.gz
cd httpd-2.4.23
./configure --prefix=/usr/local/apache --enable-so --with-apr-util=/usr/local/apr-util/ --with-pcre=/usr/local/pcre/
编译安装
make && make install
切换回/usr/src目录安装boost软件
tar zxf boost_1_59_0.tar.gz
cd boost_1_59_0
./bootstrap.sh
编译安装,过程比较漫长,耐心等待。
./b2
安装
./b2 install --prefix=/usr/local/boost
切换回/usr/src目录,继续安装cmake
tar zxf cmake-3.6.1.tar.gz
cd cmake-3.6.1
./configure --prefix=/usr/local/cmake
编译安装
make && make install
切换回/usr/src目录安装MySQL数据库
tar zxf mysql-5.7.14.tar.gz
cd mysql-5.7.14
/usr/local/cmake/bin/cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DSYSCONFDIR=/usr/local/mysql/etc -DMYSQL_DATADIR=/usr/local/mysql/data -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DMYSQL_TCP_PORT=3306 -DMYSQL_USER=mysql -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_BOOST=/usr/local/boost/include
编译安装,漫长地等待。
make && make install
创建mysql用户以及相关的目录
useradd -M -s /sbin/nologin mysql
mkdir -p /usr/local/mysql/etc
mkdir -p /usr/local/mysql/data
mkdir -p /usr/local/mysql/log
mkdir -p /usr/local/mysql/run
删除默认配置文件/etc/my.cnf
rm -f /etc/my.cnf
新建配置文件 /usr/local/mysql/etc/my.conf 内容如下:
[mysqld]
datadir=/usr/local/mysql/data
socket=/usr/local/mysql/mysql.sock
user=mysql
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
[mysqld_safe]
log-error=/usr/local/mysql/log/mysqld.log
pid-file=/usr/local/mysql/run/mysqld.pid
为目录添加mysql用户权限
chown -R mysql:mysql /usr/local/mysql
初始化数据库,注意会生成临时登录账户和密码。
/usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data
启动数据库服务
/usr/local/mysql/bin/mysqld_safe &
使用生成的临时密码登录数据库
/usr/local/mysql/bin/mysql -u root -p
修改数据库登录密码
alter user 'root'@'localhost' identified by 'A2c@1B3';
修改启动脚本文件 /usr/local/mysql/support-files/mysql.server 以下参数
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
mysqld_pid_file_path=/usr/local/mysql/run/mysqld.pid
测试启动脚本
查看mysql进程与端口状态
切换回/usr/src目录,安装php。
tar zxf php-7.0.10.tar.gz
cd php-7.0.10
./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --with-apxs2=/usr/local/apache/bin/apxs --enable-mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --enable-mbstring --with-curl --with-gd --enable-fpm
编译安装
make && make install
拷贝配置文件
cp php.ini-production /usr/local/php/etc/php.ini
修改配置文件 /usr/local/php/etc/php.ini 修改参数,去掉前面的分号。
date.timezone = Asia/Shanghai
修改Apache配置文件/usr/local/apache/conf/httpd.conf,修改ServerName并添加php索引。
在末尾添加
SetHandler application/x-httpd-php
SetHandler application/x-httpd-php-source
在Apache文档目录创建php测试文件index.php
/usr/local/apache/htdocs/index.html
vi /usr/local/apache/htdocs/index.php
内容如下
phpinfo();
?>
启动Apache服务,查看进程与端口状态。
/usr/local/apache/bin/apachectl start
使用浏览器访问服务器IP即可查看到php测试页面正常显示。
MySQL有关的信息
创建Apache与MySQL开机自启动脚本
cp /usr/local/apache/bin/apachectl /etc/init.d/
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
编辑/etc/init.d/apachectl添加
# chkconfig: 2345 65 35
# description: A very fast and reliable apache engine.
添加到chkconfig服务管理
chkconfig --add apachectl
chkconfig --add mysql
关于MySQL的error日志记录的时间始终比系统时间慢8个小时的问题!
是因为MySQL 5.7版本中新增了 log_timestamps 这个参数,而且默认采用UTC时间。
将其修改为系统时间即可
SET GLOBAL log_timestamps = SYSTEM;
这样设置的全局变量在mysql服务重启后便会失效,若要永久生效需要在配置文件 /usr/local/mysql/etc/my.cnf 中加入
log_timestamps=SYSTEM
重启MySQL服务 service mysql restart,再次查看error日志,发现已经与系统时间一致。