首页主机资讯Debian上LNMP与MySQL数据库集成方法

Debian上LNMP与MySQL数据库集成方法

时间2025-11-03 13:17:03发布访客分类主机资讯浏览507
导读:Debian上LNMP与MySQL数据库集成方法 LNMP(Linux + Nginx + MySQL/MariaDB + PHP)是常见的Web服务架构,集成核心是将MySQL数据库与Nginx(Web服务器)、PHP(服务器端脚本)协同...

Debian上LNMP与MySQL数据库集成方法
LNMP(Linux + Nginx + MySQL/MariaDB + PHP)是常见的Web服务架构,集成核心是将MySQL数据库与Nginx(Web服务器)、PHP(服务器端脚本)协同工作,实现动态网站的数据存储与交互。以下是在Debian系统上的详细集成步骤:

1. 准备工作:更新系统

在开始前,确保系统软件包为最新版本,避免兼容性问题:

sudo apt update &
    &
 sudo apt upgrade -y

2. 安装Nginx(Web服务器)

Nginx作为前端Web服务器,负责处理HTTP请求并转发PHP请求至PHP-FPM:

sudo apt install nginx -y

安装完成后,启动Nginx并设置开机自启动:

sudo systemctl start nginx
sudo systemctl enable nginx

通过浏览器访问服务器IP,若看到Nginx欢迎页面,则说明安装成功。

3. 安装MySQL/MariaDB(数据库)

MySQL是关系型数据库管理系统,MariaDB为其分支(兼容MySQL)。推荐安装MariaDB(Debian默认仓库版本更新):

sudo apt install mariadb-server mariadb-client -y

安装过程中,系统会提示设置root用户密码(务必牢记)。安装完成后,启动MariaDB服务:

sudo systemctl start mariadb
sudo systemctl enable mariadb

安全加固:运行mysql_secure_installation脚本,完成以下操作:

  • 设置root密码强度;
  • 删除匿名用户;
  • 禁止root远程登录;
  • 删除测试数据库;
  • 重新加载权限表。

4. 安装PHP及必要扩展

PHP是服务器端脚本语言,需安装PHP-FPM(FastCGI进程管理器)及MySQL扩展,实现与MySQL的交互:

sudo apt install php-fpm php-mysql -y

配置PHP-FPM:编辑PHP-FPM池配置文件(路径随PHP版本变化,如/etc/php/8.2/fpm/pool.d/www.conf),确保listen指令指向Unix socket(默认路径为/run/php/php8.2-fpm.sock):

listen = /run/php/php8.2-fpm.sock

修改后,重启PHP-FPM服务:

sudo systemctl restart php8.2-fpm

5. 配置Nginx支持PHP

编辑Nginx默认站点配置文件(/etc/nginx/sites-available/default),添加PHP处理规则:

server {
    
    listen 80 default_server;
    
    listen [::]:80 default_server;
    
    root /var/www/html;
    
    index index.php index.html index.htm;


    location / {
    
        try_files $uri $uri/ =404;

    }


    # PHP处理规则
    location ~ \.php$ {
    
        include snippets/fastcgi-php.conf;
      # 引入FastCGI配置
        fastcgi_pass unix:/run/php/php8.2-fpm.sock;
      # 与PHP-FPM的listen路径一致
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
      # 传递脚本路径
        include fastcgi_params;
  # 包含通用FastCGI参数
    }


    # 禁止访问.htaccess文件
    location ~ /\.ht {
    
        deny all;

    }

}
    

保存后,测试Nginx配置语法是否正确:

sudo nginx -t

若无错误,重新加载Nginx:

sudo systemctl reload nginx

6. 集成MySQL与PHP:创建数据库与用户

登录MySQL,创建用于Web应用的数据库和用户,并授权:

sudo mysql -u root -p

在MySQL命令行中执行以下命令(替换mydatabasemyusermypassword为实际名称):

-- 创建数据库
CREATE DATABASE mydatabase;
    

-- 创建用户并设置密码
CREATE USER 'myuser'@'localhost' IDENTIFIED BY 'mypassword';
    

-- 授予用户对数据库的所有权限
GRANT ALL PRIVILEGES ON mydatabase.* TO 'myuser'@'localhost';
    

-- 刷新权限表(使授权立即生效)
FLUSH PRIVILEGES;
    

-- 退出MySQL
EXIT;
    

7. 测试LNMP与MySQL集成

在Nginx的默认文档根目录(/var/www/html)创建PHP测试文件(如info.php),内容如下:

<
    ?php
$servername = "localhost";
    
$username = "myuser";
    
$password = "mypassword";
    
$dbname = "mydatabase";
    

// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
    

// 检查连接
if ($conn->
connect_error) {
    
    die("Connection failed: " . $conn->
    connect_error);

}
    
echo "Connected successfully";
    
?>
    

保存后,在浏览器中访问服务器IP或域名(如http://your_server_ip/info.php)。若看到“Connected successfully”,则说明LNMP与MySQL集成成功。

8. 可选:配置防火墙与SSL

  • 允许HTTP/HTTPS流量:若使用UFW防火墙,运行以下命令:
    sudo ufw allow 'Nginx Full'
    
  • 安装SSL证书:使用Let’s Encrypt免费证书,运行:
    sudo apt install certbot python3-certbot-nginx -y
    sudo certbot --nginx -d yourdomain.com
    
    按提示完成证书安装,实现HTTPS加密。

通过以上步骤,Debian系统上的LNMP环境已完成与MySQL数据库的集成,可支持动态网站(如WordPress、Drupal等)的部署与运行。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: Debian上LNMP与MySQL数据库集成方法
本文地址: https://pptw.com/jishu/740745.html
Debian SSH如何生成SSH密钥对 Debian SSH支持哪些加密算法

游客 回复需填写必要信息