在Debian系統上部署LNMP(Linux, Nginx, MySQL/MariaDB, PHP)環境是一個相對直接的過程。以下是詳細的步驟:
首先,確保你的系統是最新的:
sudo apt update && sudo apt upgrade -y
安裝Nginx并啟動它,同時設置為開機自啟動:
sudo apt install nginx -y
sudo systemctl start nginx
sudo systemctl enable nginx
驗證Nginx是否安裝成功,可以在瀏覽器中訪問你的服務器IP地址。
你可以選擇安裝MySQL或MariaDB。這里以MariaDB為例:
sudo apt install mariadb-server mariadb-client -y
sudo systemctl start mariadb
sudo systemctl enable mariadb
為了安全起見,運行以下命令進行安全配置:
sudo mysql_secure_installation
安裝PHP以及必要的擴展:
sudo apt install php-fpm php-mysql -y
啟動PHP-FPM并設置開機自啟動:
sudo systemctl start php7.4-fpm
sudo systemctl enable php7.4-fpm
檢查PHP是否安裝成功,可以創建一個 info.php
文件:
<?php
phpinfo();
?>
將該文件放置在Nginx的默認網站根目錄(通常是 /var/www/html
),然后通過瀏覽器訪問你的服務器IP地址加上 /info.php
來驗證。
編輯Nginx的默認配置文件:
sudo nano /etc/nginx/sites-available/default
找到以下部分并修改:
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:/run/php/php7.4-fpm.sock;
}
location ~ /\.ht {
deny all;
}
}
保存并退出編輯器,然后測試Nginx配置是否正確:
sudo nginx -t
如果沒有錯誤,重新加載Nginx:
sudo systemctl reload nginx
如果你使用的是UFW防火墻,可以允許HTTP和HTTPS流量:
sudo ufw allow 'Nginx Full'
你可以使用Let’s Encrypt來安裝免費的SSL證書:
sudo apt install certbot python3-certbot-nginx -y
sudo certbot --nginx -d yourdomain.com
按照提示完成證書的安裝和配置。
完成以上步驟后,你就成功在Debian上配置了一個基本的LNMP環境。如果有任何問題,可以參考相應服務的日志文件進行排查。