ubuntu

如何在Ubuntu上搭建LNMP集群

小樊
39
2025-08-11 09:53:27
栏目: 智能运维

在Ubuntu上搭建LNMP(Linux, Nginx, MySQL, PHP)集群是一个复杂的过程,涉及到多个组件的安装和配置。以下是一个基本的步骤指南,帮助你在Ubuntu上搭建一个简单的LNMP集群。

1. 准备工作

2. 安装Nginx

在两台服务器上安装Nginx:

sudo apt update
sudo apt install nginx

3. 安装MySQL

在两台服务器上安装MySQL:

sudo apt update
sudo apt install mysql-server

4. 配置MySQL主从复制

主服务器配置

  1. 编辑MySQL配置文件:
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
  1. [mysqld]部分添加以下内容:
server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = your_database_name
  1. 重启MySQL服务:
sudo systemctl restart mysql
  1. 创建一个用于复制的用户:
CREATE USER 'replicator'@'%' IDENTIFIED BY 'your_password';
GRANT REPLICATION SLAVE ON *.* TO 'replicator'@'%';
FLUSH PRIVILEGES;
  1. 查看主服务器的二进制日志位置:
SHOW MASTER STATUS;

记下FilePosition的值。

从服务器配置

  1. 编辑MySQL配置文件:
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
  1. [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
  1. 重启MySQL服务:
sudo systemctl restart mysql
  1. 配置从服务器连接到主服务器:
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;
  1. 启动从服务器复制:
START SLAVE;
  1. 检查从服务器状态:
SHOW SLAVE STATUS\G

确保Slave_IO_RunningSlave_SQL_Running都是Yes

5. 安装PHP

在两台服务器上安装PHP及其常用扩展:

sudo apt update
sudo apt install php-fpm php-mysql

6. 配置Nginx处理PHP请求

编辑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

7. 测试集群

在主服务器上创建一个PHP文件,例如info.php

<?php
phpinfo();
?>

访问http://your_domain.com/info.php,确保页面显示PHP信息。然后在从服务器上访问相同的页面,确保数据同步。

8. 配置负载均衡(可选)

如果你需要更高的可用性和性能,可以考虑使用Nginx作为负载均衡器。

安装和配置HAProxy

在两台服务器上安装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进行负载均衡。

请注意,这只是一个基本的指南,实际生产环境中可能需要更多的配置和优化。

0
看了该问题的人还看了