源码编译安装LAMP(HTTP服务,MYSQL ,PHP,以及bbs论坛)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 通过以上步骤,你可以成功地在一台Linux服务器上从源码编译并安装LAMP环境,并配置一个BBS论坛(Discuz!)。这些步骤涵盖了从安装依赖、下载源代码、配置编译到安装完成的所有细节。每个命令的解释确保了过程的透明度,使即使是非专业人士也能够理解整个流程。

编译安装LAMP(Linux, Apache, MySQL, PHP)及BBS论坛

在编译安装LAMP时,我们需要从源代码编译安装HTTP服务(Apache)、数据库(MySQL)和PHP语言,然后再配置一个BBS论坛。LAMP架构是最常用的Web开发环境之一,它能为大多数Web应用程序提供强大的支持。以下是详细的步骤和解释。

1. 环境准备

首先,我们需要准备一台Linux服务器。以下的步骤假设使用的是Ubuntu 22.04系统,你也可以根据自己的实际情况选择合适的Linux发行版。

更新系统

sudo apt-get update
sudo apt-get upgrade -y
​

解释:这两条命令用于更新系统软件包的索引并升级所有已安装的软件包,确保系统处于最新状态。

安装必备工具

sudo apt-get install build-essential libtool autoconf -y
sudo apt-get install wget curl unzip tar -y
​

解释:这些工具是编译源代码所必需的。build-essential 包含了构建软件包所需的编译器等工具,libtoolautoconf 用于处理自动化配置文件,wgetcurl 用于下载源代码,unziptar 用于解压缩文件。

2. 编译安装Apache

下载并解压Apache源码

wget https://downloads.apache.org//httpd/httpd-2.4.57.tar.gz
tar -xzf httpd-2.4.57.tar.gz
cd httpd-2.4.57
​

解释:我们首先从Apache的官方网站下载最新的稳定版源代码并解压。cd命令进入解压后的目录。

安装依赖库

sudo apt-get install libpcre3 libpcre3-dev zlib1g zlib1g-dev openssl libssl-dev -y
​

解释:Apache依赖于PCRE库(Perl Compatible Regular Expressions)来支持正则表达式操作,并且还需要Zlib库来处理压缩和解压缩操作。OpenSSL库用于启用HTTPS支持。

配置并编译Apache

./configure --enable-so --enable-ssl --with-mpm=event --with-included-apr --enable-mods-shared=all
make
sudo make install
​

解释:./configure 是配置编译选项的命令,--enable-so 启用动态模块支持,--enable-ssl 启用SSL支持,--with-mpm=event 选择使用event多进程模块,--with-included-apr 使用Apache Portable Runtime库,--enable-mods-shared=all 启用所有动态模块。make 进行编译,sudo make install 进行安装。

配置Apache服务

sudo /usr/local/apache2/bin/apachectl start
​

解释:以上命令启动Apache服务器。Apache的默认安装路径为 /usr/local/apache2/

3. 编译安装MySQL

下载并解压MySQL源码

wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.33.tar.gz
tar -xzf mysql-8.0.33.tar.gz
cd mysql-8.0.33
​

解释:从MySQL官网获取源码并解压,cd 进入解压后的目录。

安装依赖库

sudo apt-get install libncurses5-dev libaio-dev bison -y
​

解释:MySQL需要 libncurses5 库来支持终端的高级控制功能,libaio 用于异步I/O支持,bison 是一个语法解析器生成器。

配置并编译MySQL

cmake . -DDOWNLOAD_BOOST=1 -DWITH_BOOST=boost
make
sudo make install
​

解释:使用 cmake 配置编译选项,-DDOWNLOAD_BOOST=1 表示下载并使用Boost库,-DWITH_BOOST=boost 指定Boost库的位置。接下来使用 make 进行编译并安装。

初始化MySQL数据库

sudo /usr/local/mysql/bin/mysqld --initialize
sudo /usr/local/mysql/bin/mysqld_safe --user=mysql &
​

解释:mysqld --initialize 初始化数据库目录,mysqld_safe 启动MySQL守护进程,并以 mysql 用户身份运行。

4. 编译安装PHP

下载并解压PHP源码

wget https://www.php.net/distributions/php-8.2.0.tar.gz
tar -xzf php-8.2.0.tar.gz
cd php-8.2.0
​

解释:从PHP官网下载PHP源代码并解压,cd 进入解压后的目录。

安装依赖库

sudo apt-get install libxml2-dev libsqlite3-dev libonig-dev -y
​

解释:PHP依赖 libxml2 库来解析XML文档,libsqlite3 支持SQLite数据库操作,libonig 提供正则表达式支持。

配置并编译PHP

./configure --with-apxs2=/usr/local/apache2/bin/apxs --with-mysqli --with-zlib --enable-mbstring --enable-soap --enable-intl
make
sudo make install
​

解释:使用 ./configure 配置编译选项,--with-apxs2 指定与Apache集成的路径,--with-mysqli 启用MySQL支持,--with-zlib 启用Zlib支持,--enable-mbstring 启用多字节字符串支持,--enable-soap 启用SOAP支持,--enable-intl 启用国际化支持。接着使用 make 编译并安装。

配置PHP与Apache的集成

sudo cp php.ini-development /usr/local/lib/php.ini
sudo echo "LoadModule php_module modules/libphp.so" >> /usr/local/apache2/conf/httpd.conf
sudo echo "AddHandler php-script .php" >> /usr/local/apache2/conf/httpd.conf
sudo echo "DirectoryIndex index.php" >> /usr/local/apache2/conf/httpd.conf
sudo echo "AddType application/x-httpd-php .php" >> /usr/local/apache2/conf/httpd.conf
​

解释:将PHP的配置文件 php.ini-development 复制到 /usr/local/lib/ 目录下并重命名为 php.ini。然后在Apache的 httpd.conf 文件中添加对PHP模块的支持,指定 .php 文件的处理方式,并设置默认的主页为 index.php

5. 安装BBS论坛(Discuz!)

下载Discuz!源码

wget https://download.comsenz.com/DiscuzX/3.4/Discuz_X3.4_SC_UTF8.zip
unzip Discuz_X3.4_SC_UTF8.zip -d /var/www/html/discuz
​

解释:从Discuz!官网下载源码并解压到Apache的Web根目录 /var/www/html/discuz 下。

配置数据库

进入MySQL命令行:

sudo /usr/local/mysql/bin/mysql -u root -p
CREATE DATABASE discuz;
GRANT ALL PRIVILEGES ON discuz.* TO 'discuzuser'@'localhost' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;
EXIT;
​

解释:以上命令创建一个名为 discuz 的数据库,并为其创建用户 discuzuser,设置相应的权限。

配置Discuz!

在浏览器中访问 http://your_server_ip/discuz/,根据安装向导完成Discuz!的安装配置。

6. 启动LAMP服务

sudo /usr/local/apache2/bin/apachectl restart
​

解释:重启Apache服务,使得所有配置生效。

总结

通过以上步骤,你可以成功地在一台Linux服务器上从源码编译并安装LAMP环境,并配置一个BBS论坛(Discuz!)。这些步骤涵盖了从安装依赖、下载源代码、配置编译到安装完成的所有细节。每个命令的解释确保了过程的透明度,使即使是非专业人士也能够理解整个流程。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
数据可视化 关系型数据库 MySQL
ELK实现nginx、mysql、http的日志可视化实验
通过本文的步骤,你可以成功配置ELK(Elasticsearch, Logstash, Kibana)来实现nginx、mysql和http日志的可视化。通过Kibana,你可以直观地查看和分析日志数据,从而更好地监控和管理系统。希望这些步骤能帮助你在实际项目中有效地利用ELK来处理日志数据。
245 90
|
1月前
|
存储 JSON Go
PHP 日志系统的最佳搭档:一个 Go 写的远程日志收集服务
为了不再 SSH 上去翻日志,我写了个 Go 小脚本,用来接收远程日志。PHP 负责记录日志,Go 负责存储和展示,按天存储、支持 API 访问、可远程管理,终于能第一时间知道项目炸了。
42 10
|
2月前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
177 25
|
4月前
|
存储 关系型数据库 MySQL
PHP与MySQL动态网站开发:从基础到实践####
本文将深入探讨PHP与MySQL的结合使用,展示如何构建一个动态网站。通过一系列实例和代码片段,我们将逐步了解数据库连接、数据操作、用户输入处理及安全防护等关键技术点。无论您是初学者还是有经验的开发者,都能从中获益匪浅。 ####
|
4月前
|
关系型数据库 MySQL PHP
php实现一个简单的MySQL分页
通过本文的详细步骤和代码示例,我们实现了一个简单的PHP MySQL分页功能。主要步骤包括计算总记录数、设置分页参数、查询当前页的数据以及生成分页链接。这种分页方式适用于大多数Web应用,能够有效提升用户体验和页面响应速度。
129 4
|
4月前
|
SQL 关系型数据库 MySQL
PHP与MySQL的高效交互:从基础到实践####
本文深入探讨了PHP与MySQL数据库之间的高效交互技术,涵盖了从基础连接到高级查询优化的全过程。不同于传统的摘要概述,这里我们直接以一段精简代码示例作为引子,展示如何在PHP中实现与MySQL的快速连接与简单查询,随后文章将围绕这一核心,逐步展开详细讲解,旨在为读者提供一个从入门到精通的实战指南。 ```php <?php // 数据库配置信息 $servername = "localhost"; $username = "root"; $password = "password"; $dbname = "test_db"; // 创建连接 $conn = new mysqli($se
132 0
|
26天前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
1月前
|
关系型数据库 MySQL 数据库连接
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
252 82
|
20小时前
|
SQL 关系型数据库 MySQL
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)
本文深入介绍 MySQL 数据库 SQL 语句调优方法。涵盖分析查询执行计划,如使用 EXPLAIN 命令及理解关键指标;优化查询语句结构,包括避免子查询、减少函数使用、合理用索引列及避免 “OR”。还介绍了索引类型知识,如 B 树索引、哈希索引等。结合与 MySQL 数据库课程设计相关文章,强调 SQL 语句调优重要性。为提升数据库性能提供实用方法,适合数据库管理员和开发人员。
|
3月前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决