【Linux】源码安装Apache、Mysql、PHP以及LAMP部署验证

news2025/1/18 5:52:50

文章目录

  • 源码安装相关理论
    • 源代码安装特点
    • 源码包安装步骤
  • 一、源码安装Apache
    • 1、编译安装依赖包 apr
    • 2、编译安装依赖包 apr-util
    • 3、编译安装依赖包 pcre
    • 4、编译安装 Apache
    • 5、重启 apache 服务
    • 6、修改网页显示内容
    • 7、访问测试
  • 二、源码安装Mysql
    • 1、把系统自带的 boost 库卸载,源码编译安装高版本
    • 2、卸载系统自带的 MySQL
    • 3、安装必要的资源包
    • 4、安装编译器及依赖包
    • 5、添加用户和组
    • 6、解压源码包
    • 7、规划安装目录
    • 8、编译安装 MySQL
    • 9、编译
    • 10、编译安装
    • 11、编辑配置文件
    • 12、添加 path 路径,让系统能读到 mysql 的命令
    • 13、使修改生效
    • 14、生成服务启动脚本
    • 15、修改权限
    • 16、初始化数据库
    • 17、启动服务
    • 18、数据库安全初始化设置
    • 19、登录数据库
    • 20、刷新权限
    • 21、查看当前数据库
    • 22、退出数据库
  • 三、源码安装PHP7.1.24
    • 1、Centos7 安装 epel 源
    • 2、安装所需依赖包
    • 3、配置相关参数
    • 4、编译&安装
    • 5、生成配置文件
    • 6、编辑 Apache 的配置文件,使其支持 php
    • 7、重启 apache 服务
    • 8、创建测试页
    • 9、测试,在浏览器输入:http://自己 IP 地址/index.php
    • 10、测试连接 mysql 是否成功
  • 四、源码LAMP部署验证
    • 1、Apache服务器验证
    • 2、Mysql验证
      • 2.1、登录数据库
      • 2.2、查看当前数据库
      • 2.3、退出数据库
    • 3、PHP验证
    • 4、PHP+Mysql验证


源码安装相关理论

源代码安装特点

源码包:即程序软件的源代码(一般也叫Tarball,即将软件的源码以tar打包后再压缩的资源包)。

开源,能看到代码并且可以按自己所需修改源代码
安装时要先在自己系统上编译再安装,所以更适合自己的系统,运行效率更高
需要编译所以比二进制包安装时间要长
编译安装过程中一旦报错新手难以解决


源码包安装步骤

  1. 官网下载源码包
  2. 解压缩
  3. 进入解压后的目录 执行命令
  4. “./config”,用于检测系统环境是否符合安装要求,此步骤会生成Makefile文件,里边写入了检测结果和一些定义好的功能选项。
  5. make 编译
  6. make clean (如果上两步执行出错了可以执行make
    clean,用于清空Makefile文件或编译产生的“.o”头文件)
  7. make install

图片转载https://blog.csdn.net/w00347190/article/details/100770984?ops_request_misc=&request_id=&biz_id=102&utm_term=linux%E6%BA%90%E7%A0%81%E5%AE%89%E8%A3%85%E6%A6%82%E5%BF%B5&utm_medium=distribute.pc_search_result.none-task-blog-2allsobaiduweb~default-0-100770984.142v68control,201v4add_ask,213v2t3_control2&spm=1018.2226.3001.4187
【图片转载】https://blog.csdn.net/w00347190/article/details/100770984


一、源码安装Apache

1、编译安装依赖包 apr

cd /opt/Apache 

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 

2、编译安装依赖包 apr-util

cd /opt/Apache 

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 

3、编译安装依赖包 pcre

cd /opt/Apache 

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

4、编译安装 Apache

cd /opt/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 &&make && make install

选项说明:

–prefix=/usr/local/apache #安装路径 enable-so #支持动态加载模块 enable-rewrite #支持网站地址重写 enable-ssl #支持 SSL 加密 
–with-pcre=/usr/local/pcre #pcre 路径 
–with-apr=/usr/local/apr #apr 路径  
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 
chmod 745 /usr/lib/systemd/system/apache.service 
#(5)启动服务 
systemctl enable apache 
systemctl start apache.service 
#(6)修改 Apache 的运行用户 
useradd -M -s /sbin/nologin apache #用该用户运行 Apache 
vim /usr/local/apache/conf/httpd.conf #修改配置文件改变Apache运行身份 
#(7)更改目录权限 
chown -R apache:apache /usr/local/apache/ 

5、重启 apache 服务

systemctl restart apache 

6、修改网页显示内容

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

7、访问测试

在浏览器输入自己虚拟机 IP 地址:192.168.0.107
在这里插入图片描述


二、源码安装Mysql

1、把系统自带的 boost 库卸载,源码编译安装高版本

yum -y remove boost-* 

2、卸载系统自带的 MySQL

yum -y remove mysql mariadb-* 

3、安装必要的资源包

4、安装编译器及依赖包

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

5、添加用户和组

groupadd mysql
useradd -M -s /sbin/nologin -r -g mysql mysql 

6、解压源码包

cd /opt/Mysql 
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 

7、规划安装目录

安装目录:/var/lib/mysql 
数据目录:/var/lib/mysql/data 
mkdir -p /var/lib/mysql/data 
chown -R mysql:mysql /var/lib/mysql 

8、编译安装 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

9、编译

grep processor /proc/cpuinfo | wc -l #查看服务器 CPU 核心数 
make -j 2 
#注:-j 用来指定 CPU 核心数,可加快编译速度。例如:想使用 2 核来进行编译,则在-j 后加 2,可以提高编译速度,当然你要确定你的虚拟机CPU 多少核心 

10、编译安装

make install 

11、编辑配置文件

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

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

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

13、使修改生效

. /etc/profile.d/mysql.sh 

14、生成服务启动脚本

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

15、修改权限

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

16、初始化数据库

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

17、启动服务

/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!

18、数据库安全初始化设置

mysql_secure_installation  

MySQL5.7 提供了三种密码策略,可以根据需要设置复杂度不同的密码,输入两次密码,然后一直 Y 下去直至完成

19、登录数据库

mysql -u root -p  ## 密码填上一步初始化设置的密码 

20、刷新权限

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

21、查看当前数据库

mysql> show databases; 

在这里插入图片描述

22、退出数据库

mysql> exit

三、源码安装PHP7.1.24

1、Centos7 安装 epel 源

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

2、安装所需依赖包

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
cd /opt/PHP
tar xf php-7.1.24.tar.gz -C /usr/local/src
cd /usr/local/src/php-7.1.24/

3、配置相关参数

./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 #支持构建 fpmenable-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

4、编译&安装

make -j 2 && make install

5、生成配置文件

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

6、编辑 Apache 的配置文件,使其支持 php

vim /usr/local/apache/conf/httpd.conf
在 393 行下面添加:
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps

在这里插入图片描述

7、重启 apache 服务

systemctl restart apache.service

8、创建测试页

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

<?php
 phpinfo();
?>

9、测试,在浏览器输入:http://自己 IP 地址/index.php

能打开上图页面即为成功

10、测试连接 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();
?>

11、测试,在浏览器输入:http://自己 IP 地址/index.php
在这里插入图片描述

页面左上角显示字样即为连接成功


四、源码LAMP部署验证

1、Apache服务器验证

在浏览器输入自己虚拟机 IP 地址 :192.168.0.107
在这里插入图片描述

2、Mysql验证

2.1、登录数据库

mysql -u root -p   ##密码填上一步初始化设置的密码 

在这里插入图片描述

2.2、查看当前数据库

mysql> show databases; 

在这里插入图片描述

2.3、退出数据库

mysql> exit

3、PHP验证

在这里插入图片描述

4、PHP+Mysql验证

测试,在浏览器输入:http://192.168.0.107/index.php
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/78572.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【mmdetection系列】mmdetection之loss讲解

目录 1.configs 2.具体实现 3.调用 3.1 注册 3.2 调用 配置部分在configs/_base_/models目录下&#xff0c;具体实现在mmdet/models/loss目录下。 1.configs 有的时候写在head中作为参数&#xff0c;有的时候head内部进行默认调用。 我们以为例&#xff08;这里没有直接…

linux timer浅析

linux timer 1、数据结构 1.1 timer_list struct timer_list {struct hlist_node entry;unsigned long expires;void (*function)(struct timer_list *);u32 flags;#ifdef CONFIG_LOCKDEPstruct lockdep_map lockdep_map; #endif };entry:定时器保存到哈希表中的节点&am…

QT+Python停车场车牌识别计费管理系统

程序示例精选 Python停车场车牌识别计费管理系统 如需安装运行环境或远程调试&#xff0c;见文章底部微信名片&#xff01; 前言 QTPython是非常经典的窗体编程组合&#xff0c;功能完善&#xff0c;可视化界面美观易维护&#xff0c;这篇博客针对停车场车牌识别计费方面编写代…

JavaScript前端实用的工具函数封装

这篇文章主要为大家介绍了JavaScript前端实用的一些工具函数的封装&#xff0c;有需要的朋友可以借鉴参考下&#xff0c;希望能够有所帮助! 1.webpack里面配置自动注册组件 第一个参数是匹配路径,第二个是深度匹配,第三个是匹配规则 const requireComponent require.contex…

20-Django REST framework-Serializer序列化器

Serializer序列化器前言序列化器作用定义Serializer定义方法字段与选项创建Serializer对象序列化使用基本使用增加额外字段关联对象序列化反序列使用模型类序列化器ModelSerializer指定字段前言 本篇来学习Serializer序列化器知识 序列化器作用 进行数据的校验对数据对象进行…

[附源码]计算机毕业设计基于VUE的网上订餐系统Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

【代码审计-JAVA】基于javaweb框架开发的

目录 一、javaweb三大框架 1、Spring&#xff08;开源分层的框架&#xff09; 2、Struts&#xff08;MVC设计模式&#xff09; 3、Hibernate&#xff08;开源的对象关系映射框架&#xff09; 二、特征 1、结构 2、Servlet 三、重要文件 1、web.xml 2、pom.xml 3、web…

【文献研究】班轮联盟下合作博弈的概念

前言&#xff1a;以下是本人做学术研究时搜集整理的资料&#xff0c;供有相同研究需求的人员参考。 1. 合作博弈的一些概念 合作博弃中比较重要的问题是共赢状态下的利润分配问题&#xff0c;这关系到联盟的合作机制能否长期有效。这里首先介绍几个重要的概念&#xff1a; &…

174.Django中文件上传和下载

1. 文件上传和下载环境搭建 创建django项目和子应用urls中包含子应用&#xff0c;在子应用中创建urls.py配置数据库sqlite3&#xff08;默认就是&#xff0c;无需配置&#xff09;配置settings&#xff0c;上传文件目录编写模型代码&#xff08;下面给出&#xff09;模型的预迁…

如何使用Java获取货币符号?

1. 前言 最近做了一个支付相关的需求&#xff0c;要求在收银台页面显示商品的价格时带上货币符号&#xffe5;&#xff0c;类似下图中的格式&#xff1a; 最初我是用的下面这样的代码&#xff1a; System.out.println(Currency.getInstance(Locale.CHINA).getSymbol());本机测…

postgresql_internals-14 学习笔记(一)

梳理一下之前理解不太清楚的知识点&#xff0c;重点内容可能会再拆出来单独研究。 原书链接&#xff1a;Index of / 一、 数据组织 1. pg系统库 template0&#xff1a;用于从逻辑备份还原&#xff0c;或创建不同字符集的数据库&#xff0c;不可以修改template1&#xff1a;真…

[附源码]Python计算机毕业设计SSM基于框架的毕业生就业管理系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Unity脚本 (1) --- 创建脚本以及挂载脚本的本质,脚本模板的修改

值类型 --- 在栈区中开辟内存空间并直接存储在栈区中&#xff0c;引用类型 --- 在栈区中开辟内存空间存引用&#xff0c;在堆区中开辟内存空间存数据&#xff08;有可能堆区中还要开辟引用&#xff09;&#xff0c;然后将堆区中存储数据的内存空间的地址传给引用接收 什么是脚本…

HTTP 请求走私

目录 0x01 简介 0x02 成因 2.1 Keep-Alive 2.2 Pipeline 2.3 Content-Length 2.4 Transfer-Encoding 0x03 分类 0x04. 攻击 4.1. CL不为0的GET请求 4.2 CL-CL 4.3 CL-TE 4.4 TE-CL 4.5. TE-TE 0x05 防御 参考资料&#xff1a; 0x01 简介 HTTP请求走私是一种干扰…

Mysql优化-全面详解(学习总结---从入门到深化)

Sql性能下降的原因 在程序的运行过程中&#xff0c;我们会发现这样的一个现象&#xff0c;随着程序运行 时间的不断推移以及数据量越来越大&#xff0c;程序响应的时间逐渐变慢&#xff0c; 程序变得卡顿&#xff0c;但最开始的时候并不是这样的&#xff0c;那是什么原因导致 的…

2023最新SSM计算机毕业设计选题大全(附源码+LW)之java毕业生回访系统564c4

最近发现近年来越来越多的人开始追求毕设题目的设创、和新颖性。以往的xx管理系统、xx校园系统都过时了。大多数人都不愿意做这类的系统了&#xff0c;确实&#xff0c;从有毕设开始就有人做了。但是很多人又不知道哪些毕设题目才算是新颖、创意。太老土的不想做&#xff0c;创…

RISC-V SiFive U64内核——HPM硬件性能监视器

学习、沉淀、分享&#xff0c;才能有所获~ 文章目录HPM简介性能监控计数器重置行为固定功能性能监控计数器事件可编程性能监控计数器事件选择器寄存器事件选择器编码计数使能寄存器对于性能分析&#xff0c;通常我们会使用Perf工具。而perf中的硬件事件&#xff0c;则需要硬件的…

阿里、腾讯、字节跳动大厂Java岗面试秘籍!(含答案解析)

本文主要是汇集整理了最新的阿里、腾讯、字节跳动大厂面试真题及答案解析&#xff0c;以及面试中被频繁问到的内容&#xff0c;主要作为参考大纲&#xff0c;供大家互相学习。 一、阿里篇&#xff08;27题&#xff09; 1.1.1 如何实现一个高效的单向链表逆序输出&#xff1f;…

当我用ChatGPT中学习CNN卷积神经网络时...

本文节选自本人博客&#xff1a;https://www.blog.zeeland.cn/archives/chatgpt-asoihgoihrx Introduction ChatGPT大火&#xff0c;在这一段时间并没有觉得ChatGPT特别厉害&#xff0c;最多就是一个基于生成式对话的NLP模型罢了&#xff0c;直到我看到了AI扮演Linux虚拟机&am…

[附源码]计算机毕业设计基于web的建设科技项目申报管理系统Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…