Centos下源码编译安装apache、php、mysql

安装前准备

安装目录创建

mkdir /server

需要安装以下依赖

yum install gcc
yum install gcc-c++
yum install ncurses-devel
yum install autoconf
yum install expat-devel
yum install zlib-devel
yum install libxml2-devel
yum install openssl
yum install openssl-devel
yum install curl-devel
yum install libpng-devel
yum install freetype-devel

cmake编译参数详情:
https://blog.csdn.net/zero_295813128/article/details/51223209
https://www.cnblogs.com/martinzhang/p/3455681.html

Mysql源码编译安装

1. 资源获取

下载地址:https://dev.mysql.com/downloads/mysql/
版本区别:https://www.cnblogs.com/langtianya/p/5185601.html
获取安装包:

# cmake安装包获取
wget https://github.com/Kitware/CMake/releases/download/v3.14.2/cmake-3.14.2.tar.gz
# boost安装包获取 
# mysql5.7.5版本及以上需要boost,而且可能需要的boost版本还不一样,最好下载mysql源码的时候就下载带有boost的
#wget https://dl.bintray.com/boostorg/release/1.59.0/source/boost_1_59_0.tar.gz
#下面的mysql是自带boost的
# mysql安装包获取
wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-boost-5.7.26.tar.gz

5.7版本以后需要使用boost
不同版本的Mysql使用的boost版本不同

2.安装

  1. 安装cmake
tar -zxvf cmake-3.14.2.tar.gz && cd cmake-3.14.2
./configure --prefix=/usr/local/cmake
# 编译完会提示使用gmake 
# 在centos上gmake和make都是GUN make 在某些发行版上make不是GUN make就需要使用gmake,这里使用make就行
make && make install
  1. 安装mysql
# 检测是否有mysql用户
id mysql
# 创建mysql用户
groupadd -g 550 mysql
useradd -g mysql -u 550 mysql
# 创建mysql安装目录 版本号5.5
mkdir /server/mysql57
# 解压安装包并进入目录
tar -zxvf mysql-boost-5.7.26.tar.gz && cd mysql-5.7.26
/usr/local/cmake/bin/cmake . -DCMAKE_INSTALL_PREFIX=/server/mysql57 \
-DMYSQL_DATADIR=/server/mysql57/data \
-DWITH_BOOST=./boost/boost_1_59_0/ \ #使用mysql安装包自带的boost
-DSYSCONFDIR=/etc \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \
-DWITHOUT_FEDERATED_STORAGE_ENGINE=1 \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS=all \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_READLINE=1 \
-DMYSQL_UNIX_ADDR=/server/mysql57/mysql.sock \
-DMYSQL_TCP_PORT=3306 \
-DENABLE_DTRACE=0  \
-DWITH_DEBUG=1
make && make install

这一步编译时间较长

#增加环境变量
vim /etc/profile
# 添加到最后一行,保存
PATH=/server/mysql57/bin:/server/mysql57/lib:$PATH
source /etc/profile # 导入新的环境变量

初始化配置

# 创建数据存储目录
mkdir /server/mysql57/data
# 创建日志存放目录
mkdir /server/mysql57/log
# 创建日志文件
touch /server/mysql57/log/mariadb.log
#编辑配置文件
vim /etc/my.cnf

编辑配置文件

[mysqld]
datadir=/server/mysql57/data
socket=/server/mysql57/mysql.sock
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
# Settings user and group are ignored when systemd is used.
# If you need to run mysqld under a different user or group,
# customize your systemd unit file for mariadb according to the
# instructions in http://fedoraproject.org/wiki/Systemd
# 自定义内容
explicit_defaults_for_timestamp=true
port=3306
user=mysql


[mysqld_safe]
log-error=/server/mysql57/log/mariadb.log
pid-file=/server/mysql57/mariadb.pid

#
# include all files from the config directory
#
!includedir /etc/my.cnf.d

初始化

#两种方式 使用配置文件和使用参数
# 1.使用配置文件初始化
mysqld --defaults-file=/etc/my.cnf --initialize
# 2. 使用参数初始化
mysqld --initialize --user=mysql --basedir=/server/mysql57 --datadir=/server/mysql57/data
# 两种方式哪种都可以
# 初始化成功后会生成root用户的密码
# 使用--initialize-insecure代替--initialize就不会生成root的密码,root为无密码账户

# 读写权限
chown -R mysql:mysql /server/mysql
# 因为配置文件中用到的目录都在此目录下,所以一个命令就搞定,如果在不同的目录,需要分别授权或者修改目录所有者

# 复制启动脚本到/etc/init.d
cp /server/mysql55/support-files/mysql.server 

启动Mysql服务

service mysqld start # 启动服务
# 正常情况下能启动成功,出现问题可查看日志找到具体错误
cat /server/mysql57/log/mariadb.log

故障处理

如果服务启动成功,使用mysql通过socket连接本地服务提示Segmentation fault (core dumped)
修改源码重新编译

vim ./mysql-5.7.26/cmd-line-utils/libedit/terminal.c
#将869行注释
/*char buf[TC_BUFSIZE];*/
# 将879行修改 原  area = buf; 修改为
area = NULL;
# 然后重新cmake make make install

安装Apache

获取源码包

# 获取apache
wget http://mirror.bit.edu.cn/apache//httpd/httpd-2.4.29.tar.gz
# 新版apache不包含apr和apr-util
# 获取 apr
wget http://mirror.bit.edu.cn/apache//apr/apr-1.6.3.tar.gz
# 获取apr-util源码包
wget http://archive.apache.org/dist/apr/apr-util-1.5.2.tar.gz
# 获取pcre源码包
wget https://ftp.pcre.org/pub/pcre/pcre-8.41.tar.gz

安装apr

mkdir /server/apr
tar tar -zxvf apr-1.6.5.tar.gz
cd apr-1.6.5
./configure --prefix=/server/apr
make && make install

安装apr-util

tar -jxvf apr-util-1.6.1.tar.bz2
cd apr-util-1.6.1
./configure --prefix=/server/apr-util --with-apr=/server/apr
make && make install

安装pcre

mkdir /server/pcre
tar -zxvf pcre-8.41.tar.gz
cd pcre-8.41
./configure --prefix=/server/pcre
make && make install

安装Apache

apache编译参数详解:https://blog.51cto.com/superleedo/1890080

groupadd www
# 创建一个不允许登录的用户www 属于www用户组
useradd -g www www -s /bin/false
mkdir /server/httpd # apache安装目录
mkdir /server/www # web服务根目录
tar -zxvf httpd-2.4.38.tar.gz
cd httpd-2.4.38
./configure --prefix=/server/httpd \
--with-apr=/server/apr \
--with-apr-util=/server/apr-util \
--with-pcre=/server/pcre \
--sysconfdir=/server/httpd/conf \
--datadir=/server/www \
--enable-so \
--enable-deflate=shared \
--enable-expires=shared \
--enable-rewrite=shared  \
--enable-cache
make

make时,如果出现undefined reference to "XML_GetErrorCode"错误,需要安装libxml2-devel,并重新编译安装apr-util

rm /server/apr-util/* -rf
cd /server/source/apr-util-1.6.1
make clean
./configure --prefix=/server/apr-util --with-apr=/server/apr
make && make install

然后重新执行httpd 编译 configure
修改配置文件
vim /server/httpd/conf/httpd.conf
162行附近 修改User daemon 为 www
163行附近 修改Group daemon 为 www
193行附近 修改为 ServerName 127.0.0.1:80
保存

chown -R www /server/www/*
cp /server/httpd/bin/apachectl /etc/init.d/httpd
# 启动服务
/etc/init.d/httpd start

虚拟机测试可能需要关闭防火墙,或者开通对应端口
systemctl stop firewalld.service

安装php

资源获取

wget https://www.php.net/distributions/php-5.6.38.tar.gz
wget https://downloads.sourceforge.net/project/mcrypt/Libmcrypt/2.5.8/libmcrypt-2.5.8.tar.gz

安装libmcrypt

mkdir /usr/local/libmcrypt
tar -zxvf libmcrypt-2.5.8.tar.gz
cd libmcrypt-2.5.8
./configure --prefix=/usr/local/libmcrypt
make
make install

安装php

tar -zxvf php-5.6.38.tar.gz
cd php-5.6.38
./configure --prefix=/server/php56 \
--with-apxs2=/server/httpd/bin/apxs \
--with-mysql=mysqlnd \
--with-mysqli=mysqlnd \
--with-pdo-mysql=mysqlnd \
--with-openssl \
--enable-mbstring \
--with-zlib \
--enable-sockets \
--with-curl \
--with-pcre-regex \
--with-mcrypt=/usr/local/libmcrypt \
--with-gd \
--with-png-dir \
--with-freetype-dir \
--enable-gd-native-ttf \
--enable-opcache

注意
如果在configure过程中出现如下错误

configure: error: Don’t know how to define struct flock on this
system, set --enable-opcache=no

解决办法:

vim /etc/ld.so.conf.d/local.conf
# 添加2行
/usr/local/lib64   //64系统
# 如果是32位 则换成 /usr/local/lib
# libmcrypt源码下的/lib/.libs
/usr/local/src/libmcrypt-2.5.7/lib/.libs
# 加载动态链接库
ldconfig
# 重新configure

make
make install
cp /server/source/php-5.6.38/php.ini-development /server/php56/lib/php.ini
# 修改httpd配置文件
vim /server/httpd/conf/httpd.conf
# 添加如下内容
<FilesMatch "\.php$">
  SetHandler application/x-httpd-php
</FilesMatch>
# 启动httpd服务
/etc/init.d/httpd start

你可能感兴趣的:(linux,php,mysql,nosql,python)