基于Centos7.5源码编译搭建LAMP架构

简介LAMP源码编译搭建LAMP架构

为什么要源码编译
一般来说,我们软件的安装方式有Yum(rpm),和源码编译两种方式,那么为什么我们需要源码编译安装一部分软件?选择源码编译安装软件有以下几个原因:
1. 满足不同的运行平台,我们Linux发行版本众多,但是每个版本采用的软件或者内核版本都不一样,而我们的二进制包所依赖的环境不一定能够正常运行,所以大部分软件直接提供源码!
2. 方便定制,满足不同的需求,很多时候我们所需要的软件都是可以定制的,我需要什么就安装什么,大多数二进制代码都是一键装全,所以自由度并不高!
3. 方便运维、开发人员维护,我们的源码是可以打包二进制的,但是对于这个软件的打包都会有一份代价不小的额外工作,包括维护,所以如果是源码的话,软件产商会直接维护,但是如果是二进制的话,一般都是Linux发行商提供!
什么是LAMP
LAMP=Linux Apache Mysql/MariaDB PHP/Perl/Python 这些软件都是开源免费的软件,几个程序各自是独立的,经常为了达到我们需要的效果而协同工作,组成了我们常见的LAMP架构平台! LAMP是世界上最流行的组合,当然同时也有Nginx,也就是LNMP: LAMP 相对于 Nginx来说较为安全,但是Nginx处理高并发比Apache要强,Nginx 相对于 LAMP 来说安全较为差一点,同样的配制环境负载远远高于 LAMP 国内的一些大公司,淘宝、新浪都在使用Nginx,像那么大的公司网站需要用到服务器群用LAMP搭建环境成本远远大于Nginx。打个比方本来1000000W访问量需要 10台LAMP环境服务器才能完成,但是使用Nginx也许只需要5、6台,这样一来对于这样的公司来说就大大的节约了成本。
从网站的流量上来说,70%以上的访问流量是LAMP来提供的,LAMP是最强大的网站解决方案,在以前这句话没有错,但是在现在,这句话有待证实!!!因为在以后的过程中,会发现我们会使用的架构是Nginx和Apache结合使用:使用Nginx可以做集群等相关配置,可以和Apache一起使用,有的会用Apache去跑php,然后用Nginx做反向代理,比如Apache运行在8080端口,Nginx在80端口,访问php文件时,反向代理到Apache,静态页通过Nginx处理。Nginx支持高并发,Apache对php的运行比较稳定。.
基于Centos7.5源码编译搭建LAMP架构_第1张图片
常见的网页类型:htm,html,shtml,stm.php,asp,aspx,shtm,jsp等等Apache本事只处理静态页面,处理动态页面需要使用libphp5.so这个模块去工作,编译php也其实是将一个至关重要的模块打入到Apache内部,然后Apache收到php请求,将请求交给这个模块来处理!

Apache工作原理:
Apache本身只处理html静态语言页面,当客户端需要访问php页面的时候,Apache会调用libphp5.so这个模块去工作,这个模块会把php页面转换成html静态页面,让Apache处理,Apache处理过,会返回给客户端
LAMP相关网站
Apache=http://httpd.apache.org/ #httpd主程序包
MySQL=http://dev.mysql.com/downloads/mysql/ #mysql主程序包
PHP=http://php.net/downloads.php #php主程序包
apr=http://apr.apache.org/ #apr是httpd的依赖包
apr-util=http://apr.apache.org/ #apr-util是httpd的第二个依赖包
apr和apr-util这个两个软件是对后端服务软件进行优化的.
apr-util只是在apr的基础上提供了更多的数据结构和操作系统封装接口而已。
pcre 是httpd的第三个依赖包 http://pcre.org/
PCRE(Perl Compatible Regular Expressions中文含义:perl语言兼容正则表达式)是一个用C语言编写的正则表达式函数库,PCRE被广泛使用在许多开源软件之中,最著名的莫过于Apache HTTP服务器和PHP脚本语言、R脚本语言,此外,正如从其名字所能看到的,PCRE也是perl语言的缺省正则库。

安装和配置LAMP

需要源码编译安装的软件包
httpd-2.4.37.tar.gz #Apache主程序包
apr-1.6.2.tar.gz #Apache依赖包
apr-util-1.6.0.tar.gz #Apache依赖包
pcre-8.41.tar.gz #Apache依赖包
php-7.1.24.tar #php主程序包
mysql-5.7.19.tar.gz #mysql 主程序包

下载源码安装包
https://mirrors.aliyun.com/apache/httpd/httpd-2.4.37.tar.gz
http://archive.apache.org/dist/apr/apr-1.6.2.tar.gz
http://archive.apache.org/dist/apr/apr-util-1.6.0.tar.gz
ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.41.tar.gz

准备环境
装之前先安装make、gcc、openssl等编译工具和开发包

yum -y install make gcc gcc-c++ openssl openssl-devel expat-devel 

编译安装依赖包apr

tar xf apr-1.6.2.tar.gz -C /usr/local/src/
cd /usr/local/src/apr-1.6.2/
./configure --prefix=/usr/local/apr && make && make install

编译安装依赖包apr-util

tar xf apr-util-1.6.0.tar.gz -C /usr/local/src/
cd /usr/local/src/apr-util-1.6.0/
./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr/bin/apr-1-config && make && make install

如果执行make 报错:
xml/apr_xml.c:35:19: fatal error: expat.h: No such file or directory
解决:
yum install expat-devel

编译安装依赖包pcre

tar xf pcre-8.41.tar.gz -C /usr/local/src/
cd /usr/local/src/pcre-8.41/
./configure --prefix=/usr/local/pcre && make && make install

编译安装Apache

tar zxf httpd-2.4.37.tar.gz -C /usr/local/src/ 
 cd /usr/local/src/httpd-2.4.37/ 
./configure --prefix=/usr/local/apache --enable-so --enable-rewrite --enable-ssl --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --with-pcre=/usr/local/pcre --enable-modules=most --enable-mpms-shared=all --with-mpm=event

选项说明:
–prefix=/usr/local/apache      #安装路径
–enable-so            #支持动态加载模块
–enable-rewrite          #支持网站地址重写
–enable-ssl            #支持SSL加密
–with-pcre=/usr/local/pcre     #pcre路径
–with-apr=/usr/local/apr      #apr路径
–with-apr-util=/usr/local/apr-util   #apr-util路径

一共有三种稳定的MPM(Multi-Processing Module,多进程处理模块)模式。它们分别是prefork,worker和event,它们同时也代表这Apache的演变和发展。
make && make install

(1)配置文件
/usr/local/apache/conf/httpd.conf
(2)网站根目录
/usr/local/apache/htdocs/index.html
(3)生成启动脚本

cp /usr/local/apache/bin/apachectl /etc/init.d/
chmod +x /etc/init.d/apachectl

(4)写个apache系统服务脚本,754权限保存

vim /usr/lib/systemd/system/apache.service

[Unit]
Description=apache
After=network.target
[Service]
Type=forking
ExecStart=/etc/init.d/apachectl start
ExecReload=/etc/init.d/apachectl restart
ExecStop=/etc/init.d/apachectl stop
PrivateTmp=true
[Install]
WantedBy=multi-user.target

(5)启动服务

systemctl	enable apache
systemctl start Apache.service

(6)修改Apache的运行用户——默认是daemon用户运行的进程

单独创建一个用户来运行服务:

useradd -M -s /sbin/nologin apache       #用该用户运行Apache

vim /usr/local/apache/conf/httpd.conf       #修改配置文件改变Apache运行身份

改:166 User daemon      #运行用户
为:166 User apache

改:167 Group daemon      #运行组,创建Apache的时候已经即时创建了Apache这个组
为:167 Group apache
(7)更改目录权限

chown -R apache:apache /usr/local/apache/

源码编译mysql

MySQL官网:https://www.mysql.com/

下载地址
http://www.mysql.com/Downloads/MySQL-5.7/mysql-5.7.19.tar.gz #MySQL程序。
http://liquidtelecom.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz      #Boost库是一个可移植、提供源代码的C++库。

MySQL从5.7版本之后,boost是必须的,建议把系统自带的boost库卸载,源码编译安装高版本

yum -y remove boost-*

卸载系统自带的MySQL

yum -y remove mysql mariadb-*

安装必要的资源包
建议使用网络yum源,RHEL7光盘中自带的软件包版本不够,mysql-5.7.19.tar.gz的编译对软件包的版本要求比较高,其中cmake的版本要不低于2.8
网络yum源配置可以参考
https://blog.sina.com.cn/s/blog_14e8c64ca0102vztv.html
安装依赖包

yum install -y cmake make gcc gcc-c++ bison ncurses ncurses-devel

添加用户和组

groupadd mysql
useradd -M -s /sbin/nologin -r -g mysql mysql             #-M不创建用户目录

在生成环境中,安装数据库之前,需要规划好数据存储的目录
这个目录最好是一块单独的分区或者磁盘,做成raid或者LVM,编译日后磁盘的维护和扩容
对于读写比较频繁的业务,可以采用SSD等转速高的磁盘


注:mysql-5.7.19.tar.gz安装时占用空间比较大,虚拟机环境下建议新添加一块硬盘进行安装,真实服务器中可不需要

解压源码包

tar xf boost_1_59_0.tar.gz -C /usr/local/src/
tar xf mysql-5.7.19.tar.gz  -C /usr/local/src/
cd /usr/local/src/mysql-5.7.19

规划安装目录:
安装目录: /var/lib/mysql
数据目录: /var/lib/mysql/data

mkdir -p /var/lib/mysql/data 
chown -R mysql:mysql /var/lib/mysql

编译安装MySQL

cmake -DCMAKE_INSTALL_PREFIX=/var/lib/mysql \
-DMYSQL_DATADIR=/var/lib/mysql/data \
-DSYSCONFDIR=/etc \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock \
-DMYSQL_TCP_PORT=3306 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DDOWNLOAD_BOOST=1 \
-DWITH_BOOST=/usr/local/src/boost_1_59_0

参数注释:
DCMAKE_INSTALL_PREFIX:指定MySQL程序的安装目录,默认/usr/local/mysql
DEFAULT_CHARSET:指定服务器默认字符集,默认latin1
DEFAULT_COLLATION:指定服务器默认的校对规则,默认latin1_general_ci
ENABLED_LOCAL_INFILE:指定是否允许本地执行LOAD DATA INFILE,默认OFF
WITH_COMMENT:指定编译备注信息
WITH_xxx_STORAGE_ENGINE:指定静态编译到mysql的存储引擎,MyISAM,MERGE, MEMBER以及CSV四种引擎默认即被编译至服务器,不需要特别指定。
WITHOUT_xxx_STORAGE_ENGINE:指定不编译的存储引擎
SYSCONFDIR:初始化参数文件目录
MYSQL_DATADIR:数据文件目录
MYSQL_TCP_PORT:服务端口号,默认3306
MYSQL_UNIX_ADDR:socket文件路径,默认/tmp/mysql.sock

这些编译参数的帮助寻找方法:
http://www.mysql.com→→Documentation→→选择对应的版本(5.7)Installation & Upgrades→→Installing MySQL from Source →→MySQL Source-Configuration Options
最终的URL https://dev.mysql.com/doc/refman/5.7/en/source-configuration-options.html

编译
mysql-5.7.19编译时会占用大量的系统资源,建议使用多个核心同时进行编译,否则可能会编译失败
make -j 4 #注:-j 用来指定CPU核心数,可加快编译速度。 加 -j 4我用4核心来编译的,可以提高编译速度;当然你要确定CPU多少核心

grep processor /proc/cpuinfo | wc -l       #查看服务器CPU核心数

安装
make install

编辑配置文件

vim /etc/my.cnf
[mysqld]
basedir=/var/lib/mysql
datadir=/var/lib/mysql/data
port=3306
socket=/var/lib/mysql/mysql.sock
character-set-server=utf8
log-error=/var/log/mysqld.log
pid-file=/tmp/mysqld.pid
[mysql]
socket=/var/lib/mysql/mysql.sock 
[client]
socket=/var/lib/mysql/mysql.sock

添加path路径,让系统能读到mysql的命令:

vim /etc/profile.d/mysql.sh
export PATH=/var/lib/mysql/bin:$PATH

使修改生效

. /etc/profile.d/mysql.sh

生成服务启动脚本

cp /var/lib/mysql/support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld

修改权限:

chown -R mysql:mysql /var/lib/mysql

初始化数据库

/var/lib/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/var/lib/mysql --datadir=/var/lib/mysql/data

启动服务

/etc/init.d/mysqld start
Starting MySQL                          [  OK  ]

如果启动失败,报错:
[root@xuegod63 ~]# /etc/init.d/mysqld start
Starting MySQL… ERROR! The server quit without updating PID file (/tmp/mysqld.pid)

解决方法:
把数据目录删除,重新初始化:

cd /var/lib/mysql/data/
rm -rf ./*
/var/lib/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/var/lib/mysql --datadir=/var/lib/mysql/data

启动

 /etc/init.d/mysqld start
Starting MySQL. SUCCESS!

修改登录密码
mysql -u root -p
mysql> set password for root@localhost = password(‘123456’);
Query OK, 0 rows affected, 1 warning (0.01 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

安全初始化:
[root@xuegod63 mysql]# mysql_secure_installation
MySQL5.7 提供了三种密码策略,根据需要设置复杂度不同的密码
输入两次密码,然后一直Y 下去

源码编译安装php7.1.24

官网地址:http://php.net/
Php7.1.24程序包下载地址 http://jp2.php.net/distributions/php-7.1.24.tar.gz
Centos7安装epel源:

rpm -ivh http://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
yum clean all
yum list

安装所需依赖包

yum -y install php-mcrypt libmcrypt libmcrypt-devel  autoconf  freetype gd libmcrypt libpng libpng-devel libjpeg libxml2 libxml2-devel zlib curl curl-devel re2c php-pear
	
tar xf php-7.1.24.tar.gz -C /usr/local/src 
cd /usr/local/src/php-7.1.24/

配置相关参数

 ./configure --prefix=/usr/local/php/ \
--with-apxs2=/usr/local/apache/bin/apxs \
--enable-mbstring \
--with-curl \
--with-gd \
--enable-fpm \
--enable-mysqlnd \
--with-pdo-mysql=mysqlnd \
--with-config-file-path=/usr/local/php/etc/ \
--with-mysqli=mysqlnd \
--with-mysql-sock=/var/lib/mysql/mysql.sock \
--enable-maintainer-zts 		

Php配置选项中文手册http://php.net/manual/zh/configure.about.php
参数注释:
–with-apxs2       #将php编译为Apache的一个模块进行使用
–enable-mbstring     #多字节字符串的支持
–with-curl        #支持cURL
–with-gd        #支持gd库
–enable-fpm      #支持构建fpm
–enable-mysqlnd      #启用mysqlnd
–with-pdo-mysql       #支持pdo:MySQL支持
–with-config-file-path      #设置配置文件路径
–with-mysqli       #支持MySQLi
–with-mysql-sock      #关联mysql的socket文件
–enable-maintainer-zts     #如果Apache是event模型,那需要指定zts


编译&安装

make -j 4 && make install

生成配置文件

 cp php.ini-production /usr/local/php/etc/php.ini

编辑Apache的配置文件,支持php的文件:

vim /usr/local/apache/conf/httpd.conf

在393行下面添加:
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps

创建测试页

 vim /usr/local/apache/htdocs/index.php

测试链接mysql是否成功

 vim /usr/local/apache/htdocs/index.php
close();
  phpinfo();
?>

返回successful即为连接成功
也可以测试phpMyadmin

你可能感兴趣的:(基于Centos7.5源码编译搭建LAMP架构)