部署环境
系统:CentOS6.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 -Ohttp://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-develcurl-devellibpng-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
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
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
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
chown -R 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索引。
在末尾添加
<FilesMatch "\.ph(p[2-6]?|tml)$">
SetHandler application/x-httpd-PHP
</FilesMatch>
<FilesMatch "\.PHPs$">
SetHandler application/x-httpd-PHP-source
</FilesMatch>
/usr/local/apache/htdocs/index.html
vi/usr/local/apache/htdocs/index.PHP
内容如下
<?PHP
PHPinfo();
?>
启动Apache服务,查看进程与端口状态。
/usr/local/apache/bin/apachectl start
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
原文链接:https://www.f2er.com/centos/380915.html