基于Centos7.5源码编译搭建LAMP架构_tar xf mysql-5.7.19.tar.gz -c /usr/local/src的命令解析-程序员宅基地

技术标签: 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的运行比较稳定。.
在这里插入图片描述
常见的网页类型: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
<?php
        phpinfo();
?>

测试链接mysql是否成功

 vim /usr/local/apache/htdocs/index.php
<?php
    $mysqli = new mysqli("localhost", "root", "123456");
    if(!$mysqli)  {
        echo"database error";
    }else{
        echo"php env successful";
    }
    $mysqli->close();
  phpinfo();
?>

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

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_30632605/article/details/93894866

智能推荐

oracle怎么ping别人,在Oracle中,如何跟踪tnsping过程?-程序员宅基地

文章浏览阅读111次。A答案如下所示:sqlnet是oracle提供的与网络层面交互的一个工具,比如如何解析客户端发起的连接,如何对客户端发起的连接进行辨别,如何对客户端连接进行阻隔限制,或者启用日志及跟踪(log and trace)功能等等一系列的功能。所以,可以通过sqlnet工具对tnsping进行跟踪分析,查找为何外部网络无法连接数据库的原因。可以在客户端的sqlnet.ora中配置:tnsping.trac..._oracle 执行 ping

springcloudalibaba架构(15):Gateway自定义路由断言_gateway 自定义断言-程序员宅基地

文章浏览阅读971次。如果内置断言不满足我们的场景,如何自定义路由断言?我们知道了内置的断言,那么要自定义路由断言该如何操作呢?我们可以查看内置的断言如何实现?举例:BetweenRoutePredicateFactoryCtrl+NIDEA查找类知道内置路由断言的实现细节,我们只需要按照它的实现方式,来按部就班的实现自己的路由断言即可。下面我们就实现一个自己的路由断言。需求假设: 大于16岁,并且小于60岁,才能访问。先进行路由配置。......_gateway 自定义断言

C语言三角形的判断代码_c语言判断三角形类型等腰直角三角形-程序员宅基地

文章浏览阅读371次。C语言三角形的判断代码_c语言判断三角形类型等腰直角三角形

linux 迁移文件windows,如何完成Linux文件系统与Windows文件系统间的迁移?-程序员宅基地

文章浏览阅读386次。我常常遇到这样的情况:服务器上已经有可悲的是,这样的转换几乎是不可能的,而且我认为这在将来也不会成为可能。很多原因导致该功能在最初不会是一个好想法,而且它会变得越来越不必要。下面就是原因。一开始,磁盘格式的就地转换本身就很危险。当你在给定系统唯一可用的副本上工作时,这是颇具风险的行为。你相信该程序可以立刻操控整个卷,不会有多大失误。如果转换期间某部分出错了,该数据的唯一副本就破坏了。此外,如果该数..._文件系统 ext3怎么把数据导到window

Go语言/golang/位操作/取反/异或/左移/右移-程序员宅基地

文章浏览阅读3.5k次。为什么80%的码农都做不了架构师?>>> ..._go 取反操作

北大AI公开课2019 | 雷鸣:人工智能革命与机遇-程序员宅基地

文章浏览阅读132次。2019年2月20日,北京大学“人工智能前沿与产业趋势”正式开课。本学期的课程邀请到了商汤科技副总裁沈徽、驭势科技CEO吴甘沙、微软亚洲研究院副院长周明、360人工智能研究院院长颜水成、YC中国创始人及CEO、百度集团副董事长陆奇等14位来自产业界的大咖进行授课,我们作为独家合作媒体将全程跟进并对北大这14场公开课进行整理,敬请关注!北大人工智能创新中心主任雷鸣作为课程的发起人与主持人率先开讲。作...

随便推点

VSCode GDB调试配置_vscode debug 参数-程序员宅基地

文章浏览阅读3.2w次,点赞6次,收藏39次。VSCode GDB调试配置1. vscode启动debug窗口按Ctrl+Shift+D,打开Debug窗口默认是“No configurations”, 点击“F5”,会提示你配置GDB参数(选择gcc build and debug active file),配置文件名称为launch.json(配置参考3)配置完成后,再按F5, 会提示配置GCC,选择“Configure Task..._vscode debug 参数

Mybatis查询语句返回的对象中部分字段为null(空)_mybatis resulttype部分字段未null-程序员宅基地

文章浏览阅读2.4w次,点赞20次,收藏38次。sql是正确的,但是商品这个对象只有price(价格),stock(存量)是有值的,其他的都没有.我自己的解决办法是:不使用resultType(问题很多),而是使用resultMap.下面是我的应用场景和解决思路./** * 商品 */public class Goods { /** * 商品id */ private Integer go..._mybatis resulttype部分字段未null

ImageMagick:png序列转gif(适合处理带透明度的图片)_png序列转透明底gif-程序员宅基地

文章浏览阅读5.1k次,点赞3次,收藏6次。最近需要将几组png序列转成gif,之前有用过“Ulead GIF Animator” 和 “Photoshop”,这两款软件应该能满足需求!“Ulead GIF Animator”只有windows版,这些年mac是主力机且一直刻意减少使用PS,通过命令行应该有法子可以生成gif?首先想到的是ffmpeg,虽然ffmpeg主要是视频处理,最近发现可以用它来做一些图片处理,例如 png转jpg、gif转png序列、裁切图片等。一般用ffmpeg基本都是截取视频生成gif,gif没有透明度 ffmpeg _png序列转透明底gif

java调用cmd进入指定目录并执行任务_java在指定目录调用cmd命令-程序员宅基地

文章浏览阅读4.7k次。特此记录:连续使用两个cmd命令中间用 &&相连 cmd /c是运行完后关闭窗口 cmd /k是运行完后不关闭,注意!!!这个String里面的内容最好自己手敲,复制进去可能运行不了。 String cmd="cmd /c cd /d d:\\nginx_rtmp\\nginx && .\\nginx.exe -c .\\conf\\nginx-win-rtmp.conf"; Runtime run = Runtime.getRuntime(); _java在指定目录调用cmd命令

【每周一库】 imgui-rs - Rust下的Dear ImGui binding-程序员宅基地

文章浏览阅读1k次。本期的每周一库带来的是imgui-rs,是一个Rust下的Dear ImGui binding,从名字不难看出,这是一个GUI框架的库下面我们主要参考i..._rust imgui

Android自定义控件之轮播图控件-程序员宅基地

文章浏览阅读52次。为什么80%的码农都做不了架构师?>>> ..._android studio怎么用轮播图组合其他控件

推荐文章

热门文章

相关标签