在Debian系统上配置和管理LNMP(Linux, Nginx, MySQL/MariaDB, PHP)环境涉及多个步骤,包括安装和配置各个组件、管理数据库、优化性能以及确保安全性。以下是详细的指南:
首先,更新包列表并安装Nginx:
sudo apt update
sudo apt install nginx
启动Nginx并设置开机自启动:
sudo systemctl start nginx
sudo systemctl enable nginx
安装MySQL或MariaDB。这里以MariaDB为例:
sudo apt update
sudo apt install mariadb-server mariadb-client
启动MariaDB并设置开机自启动:
sudo systemctl start mariadb
sudo systemctl enable mariadb
运行安全脚本以提高安全性:
sudo mysql_secure_installation
按照提示设置root密码,删除匿名用户,禁止root远程登录,删除测试数据库等。
安装PHP及其常用扩展:
sudo apt update
sudo apt install php-fpm php-mysql
启动PHP-FPM并设置开机自启动:
sudo systemctl start php7.4-fpm
sudo systemctl enable php7.4-fpm
配置Nginx以使用PHP-FPM处理PHP文件。编辑Nginx默认站点配置文件:
sudo nano /etc/nginx/sites-available/default
在server块中添加以下内容:
server {
listen 80 default_server;
listen [::]:80 default_server;
root /var/www/html;
index index.php index.html index.htm index.nginx-debian.html;
server_name _;
location / {
try_files $uri $uri/ =404;
}
location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
}
location ~ /\.ht {
deny all;
}
}
保存并退出编辑器,然后测试Nginx配置并重启服务:
sudo nginx -t
sudo systemctl restart nginx
登录到MariaDB并创建数据库和用户:
sudo mysql -u root -p
在MySQL提示符下执行以下SQL命令:
CREATE DATABASE mydatabase;
CREATE USER 'myuser'@'localhost' IDENTIFIED BY 'mypassword';
GRANT ALL PRIVILEGES ON mydatabase.* TO 'myuser'@'localhost';
FLUSH PRIVILEGES;
EXIT;
创建一个PHP文件来测试数据库连接。例如,创建一个名为info.php的文件:
sudo nano /var/www/html/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";
$conn->close();
?>
保存并退出编辑器,然后在浏览器中访问http://your_server_ip/info.php,如果看到“Connected successfully”消息,说明数据库连接配置成功。
sudo ufw allow 'Nginx Full'
sudo ufw allow 'OpenSSH'
sudo ufw enable
修改MySQL配置:修改MySQL的默认口令,增强安全性。打开3306端口监听,如果需要远程访问。修改默认字符集,例如设置为简体中文。调整缓冲池大小(innodb_buffer_pool_size
),增加内存缓存。调整查询缓存(适用于早期版本的MySQL)。调整排序和分组操作的内存限制(sort_buffer_size
和 tmp_table_size
)。调整连接数限制和超时设置(max_connections
、wait_timeout
和 interactive_timeout
)。
索引优化:为经常用于查询条件的列添加索引。使用复合索引来优化多个查询条件。定期检查和维护索引,删除不再使用或重复的索引。
查询优化:使用 EXPLAIN
分析查询性能,找出瓶颈。避免在 WHERE
子句中使用 OR
,转而使用 UNION
。当可能的时候,使用 JOIN
代替子查询。只查询需要的列,而不是使用 SELECT *
。使用 LIMIT
限制返回的结果数量。
硬件升级:如果服务器硬件资源不足(如CPU、内存或磁盘空间),考虑升级硬件以提高性能。
监控和分析:使用慢查询日志(slow_query_log
)来记录慢查询。定期分析慢查询日志,找出需要优化的查询。考虑使用性能监控工具(如MySQL Enterprise Monitor或Prometheus + Grafana)来实时监控数据库性能。
通过以上步骤,你就可以在Debian系统上成功配置和管理LNMP环境中的数据库。