在Debian上部署LNMP集群可參考以下步驟,分為基礎環境搭建和集群配置兩部分:
更新系統
sudo apt update && sudo apt upgrade -y
安裝Nginx
sudo apt install nginx
sudo systemctl start nginx && sudo systemctl enable nginx
安裝MariaDB/MySQL
sudo apt install mariadb-server
sudo mysql_secure_installation # 設置root密碼及安全選項
sudo systemctl start mariadb && sudo systemctl enable mariadb
安裝PHP及擴展
sudo apt install php-fpm php-mysql php-gd php-curl php-mbstring
sudo systemctl start php7.4-fpm && sudo systemctl enable php7.4-fpm
配置Nginx支持PHP
編輯配置文件 /etc/nginx/sites-available/default
,添加以下內容:
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;
}
測試并重啟Nginx:
sudo nginx -t && sudo systemctl reload nginx
在負載均衡節點安裝Nginx,編輯配置文件 /etc/nginx/nginx.conf
,添加上游服務器組:
http {
upstream backend {
server 192.168.1.101:80; # 主節點IP
server 192.168.1.102:80; # 從節點IP
}
server {
location / {
proxy_pass http://backend;
}
}
}
重啟Nginx:
sudo systemctl reload nginx
主節點配置:修改 /etc/mysql/mariadb.conf.d/50-server.cnf
,設置 server-id=1
,啟用二進制日志:
[mysqld]
server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = your_database
重啟MySQL并創建復制用戶:
CREATE USER 'replicator'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'replicator'@'%';
FLUSH PRIVILEGES;
從節點配置:修改 /etc/mysql/mariadb.conf.d/50-server.cnf
,設置 server-id=2
,指向主節點:
[mysqld]
server-id = 2
relay_log = /var/log/mysql/mysql-relay-bin.log
read_only = 1
執行復制命令:
CHANGE MASTER TO
MASTER_HOST='主節點IP',
MASTER_USER='replicator',
MASTER_PASSWORD='password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=107;
START SLAVE;
注意事項: