在Debian上搭建LNMP(Linux, Nginx, MySQL, PHP)集群是一个复杂的过程,涉及到多个组件的安装和配置。以下是一个基本的步骤指南,帮助你在Debian系统上搭建一个简单的LNMP集群。
首先,确保你的Debian系统是最新的:
sudo apt update
sudo apt upgrade -y
在所有节点上安装Nginx:
sudo apt install nginx -y
启动并启用Nginx服务:
sudo systemctl start nginx
sudo systemctl enable nginx
在所有节点上安装MySQL或MariaDB:
sudo apt install mysql-server -y # 或者 mariadb-server
启动并启用MySQL/MariaDB服务:
sudo systemctl start mysql # 或者 mariadb
sudo systemctl enable mysql # 或者 mariadb
运行安全脚本以设置root密码和其他安全选项:
sudo mysql_secure_installation
在所有节点上安装PHP及其常用扩展:
sudo apt install php-fpm php-mysql -y
启动并启用PHP-FPM服务:
sudo systemctl start php7.4-fpm # 根据你的PHP版本调整
sudo systemctl enable php7.4-fpm # 根据你的PHP版本调整
编辑Nginx配置文件(通常位于/etc/nginx/sites-available/default
),添加或修改以下内容:
server {
listen 80;
server_name your_domain.com;
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; # 根据你的PHP版本调整
}
location ~ /\.ht {
deny all;
}
}
测试Nginx配置并重启服务:
sudo nginx -t
sudo systemctl restart nginx
确保MySQL/MariaDB在所有节点上都能正常运行,并且可以从其他节点访问。你可以编辑/etc/mysql/mysql.conf.d/mysqld.cnf
(或/etc/mysql/mariadb.conf.d/50-server.cnf
)文件,添加以下内容以允许远程连接:
bind-address = 0.0.0.0
重启MySQL/MariaDB服务:
sudo systemctl restart mysql # 或者 mariadb
你可以使用Nginx作为反向代理和负载均衡器。编辑Nginx配置文件(通常位于/etc/nginx/nginx.conf
),添加以下内容:
http {
upstream backend {
server node1_ip:80;
server node2_ip:80;
# 添加更多节点
}
server {
listen 80;
server_name your_domain.com;
location / {
proxy_pass http://backend;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
}
测试Nginx配置并重启服务:
sudo nginx -t
sudo systemctl restart nginx
确保你的防火墙允许HTTP(80)和HTTPS(443)流量:
sudo ufw allow 'Nginx Full'
在浏览器中访问你的域名,确保所有节点都能正常工作并且负载均衡生效。
这个指南提供了一个基本的框架,但实际部署可能需要根据具体需求进行调整。