在Linux服务器上部署LNMP(Linux, Nginx, MySQL, PHP)环境是一个常见的任务,以下是一个基本的步骤指南:
首先,确保你的系统是最新的。
sudo apt update
sudo apt upgrade -y
Nginx是一个高性能的HTTP和反向代理服务器。
sudo apt install nginx -y
安装完成后,启动Nginx并设置开机自启动。
sudo systemctl start nginx
sudo systemctl enable nginx
MySQL是一个流行的关系型数据库管理系统。
sudo apt install mysql-server -y
安装完成后,运行安全脚本以提高安全性。
sudo mysql_secure_installation
按照提示设置root密码,删除匿名用户,禁止root远程登录等。
PHP是一种广泛使用的服务器端脚本语言。
sudo apt install php-fpm php-mysql -y
安装完成后,启动PHP-FPM并设置开机自启动。
sudo systemctl start php7.4-fpm
sudo systemctl enable php7.4-fpm
编辑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
创建一个简单的PHP文件来测试你的设置。
sudo nano /var/www/html/index.php
添加以下内容:
<?php
phpinfo();
?>
保存并退出编辑器,然后在浏览器中访问你的服务器IP地址或域名,你应该能看到PHP信息页面。
如果你使用的是UFW(Uncomplicated Firewall),可以配置它以允许HTTP和HTTPS流量。
sudo ufw allow 'Nginx Full'
为了安全起见,建议安装SSL证书。你可以使用Let’s Encrypt免费获取SSL证书。
sudo apt install certbot python3-certbot-nginx -y
sudo certbot --nginx -d yourdomain.com
按照提示完成SSL证书的安装和配置。
完成以上步骤后,你就成功地在Linux服务器上部署了一个基本的LNMP环境。