Ubuntu22.04搭建LAMP环境(linux服务器学习笔记)

server/2024/12/14 2:04:50/

目录

引言:

一、系统更新

二、安装搭建Apache2

1.你可以通过以下命令安装它:

2.查看Apache2版本

3.查看Apache2运行状态

4.浏览器访问

三、安装搭建MySQL

1.安装MySQL

2.查看MySQL 版本

 3.安全配置MySQL

3.1是否设置密码?(按y|Y表示是,按其他任意键表示否) :

3.2是否删除匿名用户  ?(按y|Y表示是,按其他任意键表示否)

3.3禁止root远程登录?(按y|Y表示是,按其他任意键表示否) :

3.4删除'test'数据库及其访问权限?(按y|Y表示是,按其他任意键表示否) :

3.5现在重新加载权限表?(按y|Y表示是,按其他任意键表示否) :

4.创建新的用户

4.1root用户的身份登录到MySQL

4.2创建新用户 

4.3给新建用户添加权限

5看情况修改配置文件

 情况1:不允许远程访问(默认)

 情况2:允许远程访问(需要配置)

四、安装PHP及其扩展

1.安装PHP及其扩展

 2.启用php-mysqli扩展

        2.1查看PHP的版本

        2.2vim查看编辑PHP的配置文件

 3.安装完成后,重启Apache2服务以使PHP生效:

五、测试LAMP环境

六、总结:



引言

LAMP(Linux, Apache, MySQL, PHP)是一种流行的开源Web服务器软件栈,广泛应用于构建动态网站和Web应用程序。本文将整合本人学习Linux搭建过的单体服务器,详细介绍如何在Ubuntu 22.04上搭建LAMP环境,从系统更新到安装和配置各个组件,再到测试环境是否搭建成功。

一、系统更新

在开始之前,确保你的Ubuntu 22.04系统是最新的。打开终端并输入以下命令来更新系统:

sudo apt update
sudo apt upgrade

如下图,等待更新完毕.....

二、安装搭建Apache2

Apache2是LAMP环境中的Web服务器

1.你可以通过以下命令安装它:
sudo apt install apache2

 如下图,等待安装完毕.....

2.查看Apache2版本
sudo apache2 -v

  如下图,我这边的版本是Apache/2.4.52 (Ubuntu)

3.查看Apache2运行状态

安装完成后,你可以使用如下命令检查Apache2是否正在运行。

sudo systemctl status apache2

如下图,我这边显示Apache HTTP服务器已经成功启动,并且正在运行。

4.浏览器访问

在浏览器中访问服务器的IP地址,以验证Apache2的默认页面是否可以正常显示。

三、安装搭建MySQL

1.安装MySQL
sudo apt install mysql-server mysql-client

等待安装完毕....

2.查看MySQL 版本
sudo mysql --version

如下图: 

 3.安全配置MySQL

安装完成后,运行以下命令进行安全配置,如设置root密码、删除匿名用户等。

sudo mysql_secure_installation

运行后如下图: 

3.1是否设置密码?(按y|Y表示是,按其他任意键表示否) :

要求设置一个密码。询问你,是否想要设置密码?如果是,输入y或Y;如果不设置,输入其他。

这边选择y,输入后回车,如下:

        要求你选择一个级别来设置密码验证策略。     

  • 低级别(LOW):密码长度至少为8个字符。
  • 中级别(MEDIUM):密码长度至少为8个字符,且必须包含数字、大小写字母以及特殊字符。
  • 高级别(STRONG):密码长度至少为8个字符,包含数字、大小写字母、特殊字符,并且不能是字典文件中的单词(这通常意味着密码需要足够复杂,以避免与常见单词或短语匹配)。

分别对应[0,1,2],输入对应的数字即可:

3.2是否删除匿名用户  ?(按y|Y表示是,按其他任意键表示否)

在大多数情况下,建议移除匿名用户以增强数据库的安全性。如果你确实需要允许某些用户以匿名方式访问数据库(尽管这在大多数情况下是不推荐的),你应该仔细考虑并设置适当的权限和访问控制。

输入y后按enter  成功删除 

3.3禁止root远程登录?(按y|Y表示是,按其他任意键表示否) :

为了增强MySQL服务器的安全性,通常建议仅允许root用户从本地主机(即服务器本身)进行连接,而不允许从远程位置连接。这是因为root用户拥有对数据库的完全访问权限,如果允许远程连接,那么任何能够访问该网络的人都有可能尝试猜测或破解root密码,进而获得对数据库的完全控制权。

输入Y,禁止root远程登录。回车后,如下:

3.4删除'test'数据库及其访问权限?(按y|Y表示是,按其他任意键表示否) :

在生产环境中,出于安全考虑,通常建议删除默认的'test'数据库。这是因为如果保留该数据库,任何能够连接到MySQL服务器的人都可能访问它,这可能会带来安全风险,尤其是如果该数据库包含敏感信息或测试数据时。

输入Y,删除'test'数据库及其访问权限。回车后,如下:

3.5现在重新加载权限表?(按y|Y表示是,按其他任意键表示否) :

在MySQL中,权限表存储了关于用户账户、它们可以访问哪些数据库、表以及可以执行哪些操作的信息。当你对MySQL的用户权限进行更改(例如添加新用户、删除用户、更改用户密码或修改用户权限)后,这些更改不会立即生效,直到你重新加载权限表。

重新加载权限表是一个必要的步骤,以确保MySQL服务器知道最新的权限设置,并能够根据这些设置来允许或拒绝用户的访问请求。

输入Y,选择重新加载权限表。回车后,如下:

All done! 意味着所有的步骤都已经完成,如移除匿名用户、禁止root远程登录、删除'test'数据库以及重新加载权限表等。

4.创建新的用户

由于上述步骤禁止root远程访问,所以要添加一个用户和密码。

4.1root用户的身份登录到MySQL
sudo mysql -u root -p

回车后输入前面设置的root用户的密码,如下图 :

4.2创建新用户 

输入以下命令创建 新用户zzj2144

create user 'zzj2144'@'%' identified by 'zzj123456789';

 成功创建:

查看用户    

select user,host,plugin from mysql.user;

执行这条查询语句后,你将得到一个结果集,其中包含了MySQL服务器上所有用户账户的用户名、允许连接的主机以及使用的身份验证插件。

4.3给新建用户添加权限

由于新建的MySQL用户基本上没有什么权限,我们需要手动添加。

GRANT ALL PRIVILEGES ON mydatabase.* TO 'zzj2144'@'%';

这里的ALL PRIVILEGES表示所有权限,mydatabase.*表示mydatabase数据库中的所有对象,'zzj2144'@'%'表示用户zzj2144可以从任何主机连接。

 成功添加

5看情况修改配置文件

vim查看编辑MySQL服务器配置文件

vim /etc/mysql/mysql.conf.d/mysqld.cnf
 情况1:不允许远程访问(默认)
bind-address            = 127.0.0.1
mysqlx-bind-address     = 127.0.0.1

 情况2:允许远程访问(需要配置)
user            = mysqlpid-file       = /var/run/mysqld/mysqld.pidsocket = /var/run/mysqld/mysqld.sockport           = 3306datadir        = /var/lib/mysql

四、安装PHP及其扩展

 PHP是LAMP环境中的脚本语言,用于处理Web页面上的动态内容。你可以通过以下命令安装PHP及其必要的扩展:

1.安装PHP及其扩展
sudo apt install php libapache2-mod-php php-mysql

等待安装...

 2.启用php-mysqli扩展
        2.1查看PHP的版本
php -v

 这边PHP的版本是8.1

        2.2vim查看编辑PHP的配置文件
sudo vim /etc/php/你的php版本/apache2/php.ini

如:vim /etc/php/8.1/apache2/php.ini

去掉这个注释:

 3.安装完成后,重启Apache2服务以使PHP生效:
sudo systemctl restart apache2

五、测试LAMP环境

为了验证LAMP环境是否搭建成功,你可以创建一个简单的PHP文件来测试。在Apache2的Web根目录(通常是/var/www/html)中创建一个名为info.php的文件,并输入以下PHP代码:

<?php
phpinfo();
?>

 保存文件后,在浏览器中访问http://<服务器IP地址>/info.php,到这里,如果环境配置成功的话你应该会看到PHP的配置信息页面。如下图:

总结:

  1. 防火墙设置:确保你的防火墙允许HTTP和HTTPS流量通过。

  2. 安全更新:定期检查并更新系统、Apache2、数据库和PHP的安全补丁。

  3. 备份:定期备份数据库和Web内容,以防数据丢失。

  4. 日志监控:定期检查Apache2和数据库的日志文件,以监控服务器的运行状态和潜在的安全问题。

 恭喜你到这里,在Ubuntu 22.04上成功搭建一个功能完善的LAMP环境。接下来将在此基础上安装phpMyAdmin。欲知后事,且待下节。


http://www.ppmy.cn/server/149976.html

相关文章

websocket 服务 pinia 全局配置

websocket 方法类 // stores/webSocketStore.ts import { defineStore } from "pinia";interface WebSocketStoreState {ws: WebSocket | null; // WebSocket 实例callbacks: ((message: string) > void)[]; // 消息回调函数列表connected: boolean; // 连接状态…

Java面试题精选:设计模式(二)

1、装饰器模式与代理模式的区别 1&#xff09;代理模式(Proxy Design Pattern ) 原始定义是&#xff1a;让你能够提供对象的替代品或其占位符。代理控制着对于原对象的访问&#xff0c;并允许将请求提交给对象前后进行一些处理。 代理模式的适用场景 功能增强 当需要对一个对…

基于Spring Boot的电影院订票信息管理系统

目录 前言 一、技术栈 二、系统功能介绍 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 当今社会已经步入了科学技术进步和经济社会快速发展的新时期&#xff0c;国际信息和学术交流也不断加强&#xff0c;计算机技术对经济社会发展和人民生活改善的影响也…

漫画之家系统:Spring Boot框架下的漫画世界

2 系统开发环境 2.1 JAVA简介 JavaScript是一种网络脚本语言&#xff0c;广泛运用于web应用开发&#xff0c;可以用来添加网页的格式动态效果&#xff0c;该语言不用进行预编译就直接运行&#xff0c;可以直接嵌入HTML语言中&#xff0c;写成js语言&#xff0c;便于结构的分离&…

让PPT不再“难搞”:智能工具如何改变办公体验

PPT的世界是一场属于设计感与逻辑力的双重较量。那些字体配色的小心思&#xff0c;排版设计的大考验&#xff0c;无不让人抓耳挠腮。然而&#xff0c;科技的加持让这一切正悄然改变。比如&#xff0c;随着 ai生成ppt 工具的兴起&#xff0c;许多复杂操作正被重新定义&#xff0…

docker搭建elasticsearch服务

创建docker-compose.yml version: 1.0 # 服务配置 services:elasticsearch:container_name: es01image: docker.elastic.co/elasticsearch/elasticsearch:8.12.2restart: unless-stoppedenvironment:- "ES_JAVA_OPTS-Xms1024m -Xmx1024m"- "TZAsia/Shanghai&qu…

在2023idea中如何创建SpringBoot

目录 一.下载和安装 Maven 1.前往 https://maven.apache.org/download.cgi 下载最新版的 Maven 程序 2.将文件解压到D:Program FilesApachemaven目录 3.新建环境变量MAVEN_HOME&#xff0c;赋值D:Program FilesApachemaven 4.编辑环境变量Path&#xff0c;追加%MAVEN_HOME…

HTML和JavaScript实现简单OA系统

下面是一个包含登录页面和人事管理功能的简单OA系统示例。这个系统使用HTML和JavaScript实现。 1.页面展示 登录页面 首先&#xff0c;我们创建一个简单的登录页面。 OA系统页面 接下来是登录成功后的OA系统页面&#xff0c;包含新增、删除、修改公司人员的基本信息等功能…