debian

Debian LNMP如何配置MySQL数据库

小樊
42
2025-05-14 05:16:04
栏目: 云计算

在Debian系统上配置LNMP(Linux, Nginx, MySQL/MariaDB, PHP)环境并设置MySQL数据库,可以按照以下步骤进行:

1. 更新系统包

首先,确保你的系统包是最新的:

sudo apt update
sudo apt upgrade -y

2. 安装Nginx

安装Nginx服务器:

sudo apt install nginx -y

启动并启用Nginx服务:

sudo systemctl start nginx
sudo systemctl enable nginx

3. 安装MySQL/MariaDB

你可以选择安装MySQL或MariaDB。这里以MariaDB为例:

sudo apt install mariadb-server -y

启动并启用MariaDB服务:

sudo systemctl start mariadb
sudo systemctl enable mariadb

4. 配置MariaDB

运行安全配置脚本以提高安全性:

sudo mysql_secure_installation

按照提示进行操作,包括设置root密码、删除匿名用户、禁止root远程登录等。

5. 创建数据库和用户

登录到MySQL/MariaDB:

sudo mysql -u root -p

创建一个新的数据库和用户,并授予该用户对数据库的权限:

CREATE DATABASE mydatabase;
CREATE USER 'myuser'@'localhost' IDENTIFIED BY 'mypassword';
GRANT ALL PRIVILEGES ON mydatabase.* TO 'myuser'@'localhost';
FLUSH PRIVILEGES;
EXIT;

6. 配置PHP

安装PHP及其常用扩展:

sudo apt install php-fpm php-mysql -y

编辑PHP-FPM配置文件(通常位于/etc/php/7.4/fpm/pool.d/www.conf),确保监听Unix socket:

listen = /run/php/php7.4-fpm.sock

重启PHP-FPM服务:

sudo systemctl restart php7.4-fpm

7. 配置Nginx以使用PHP

编辑Nginx站点配置文件(通常位于/etc/nginx/sites-available/default):

server {
    listen 80;
    server_name your_domain_or_ip;

    root /var/www/html;
    index index.php index.html index.htm;

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

    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/run/php/php7.4-fpm.sock;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
}

测试Nginx配置并重启服务:

sudo nginx -t
sudo systemctl restart nginx

8. 测试PHP连接MySQL

创建一个PHP文件(例如/var/www/html/index.php)来测试PHP连接MySQL:

<?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或域名,如果看到“Connected successfully”,则表示配置成功。

通过以上步骤,你已经成功在Debian系统上配置了LNMP环境并设置了MySQL数据库。

0
看了该问题的人还看了