在Ubuntu上搭建LNMP(Linux, Nginx, MySQL, PHP)集群是一个复杂的过程,涉及到多个组件的安装和配置。以下是一个基本的步骤指南,帮助你在Ubuntu上搭建一个简单的LNMP集群。
在两台服务器上安装Nginx:
sudo apt update
sudo apt install nginx
在两台服务器上安装MySQL:
sudo apt update
sudo apt install mysql-server
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
[mysqld]
部分添加以下内容:server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = your_database_name
sudo systemctl restart mysql
CREATE USER 'replicator'@'%' IDENTIFIED BY 'your_password';
GRANT REPLICATION SLAVE ON *.* TO 'replicator'@'%';
FLUSH PRIVILEGES;
SHOW MASTER STATUS;
记下File
和Position
的值。
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
[mysqld]
部分添加以下内容:server-id = 2
relay_log = /var/log/mysql/mysql-relay-bin.log
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = your_database_name
read_only = 1
sudo systemctl restart mysql
CHANGE MASTER TO
MASTER_HOST='master_ip_address',
MASTER_USER='replicator',
MASTER_PASSWORD='your_password',
MASTER_LOG_FILE='recorded_log_file_name',
MASTER_LOG_POS=recorded_log_position;
START SLAVE;
SHOW SLAVE STATUS\G
确保Slave_IO_Running
和Slave_SQL_Running
都是Yes
。
在两台服务器上安装PHP及其常用扩展:
sudo apt update
sudo apt install php-fpm php-mysql
编辑Nginx配置文件:
sudo nano /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;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
重启Nginx服务:
sudo systemctl restart nginx
在主服务器上创建一个PHP文件,例如info.php
:
<?php
phpinfo();
?>
访问http://your_domain.com/info.php
,确保页面显示PHP信息。然后在从服务器上访问相同的页面,确保数据同步。
如果你需要更高的可用性和性能,可以考虑使用Nginx作为负载均衡器。
在两台服务器上安装HAProxy:
sudo apt update
sudo apt install haproxy
编辑HAProxy配置文件:
sudo nano /etc/haproxy/haproxy.cfg
添加以下内容:
global
log /dev/log local0
log /dev/log local1 notice
daemon
defaults
log global
mode http
option httplog
option dontlognull
timeout connect 5000ms
timeout client 50000ms
timeout server 50000ms
frontend http_front
bind *:80
default_backend http_back
backend http_back
balance roundrobin
server server1 master_ip_address:80 check
server server2 slave_ip_address:80 check
重启HAProxy服务:
sudo systemctl restart haproxy
现在,你的LNMP集群已经搭建完成,并且可以通过HAProxy进行负载均衡。
请注意,这只是一个基本的指南,实际生产环境中可能需要更多的配置和优化。