商城首页欢迎来到中国正版软件门户

您的位置:首页 >php-fpm在ubuntu上如何实现高可用性

php-fpm在ubuntu上如何实现高可用性

  发布于2026-04-28 阅读(0)

扫一扫,手机访问

在Ubuntu上实现PHP-FPM的高可用性

php-fpm在ubuntu上如何实现高可用性

想让你的PHP应用在Ubuntu上坚如磐石,扛得住流量高峰,也经得起意外宕机?实现PHP-FPM的高可用性是关键一步。别担心,这事儿没想象中那么复杂,核心思路就是“别把鸡蛋放在一个篮子里”。下面这几种经过实战检验的方法,总有一款适合你的业务场景。

1. 使用负载均衡器

这是最直观的思路:让流量分摊。通过负载均衡器将用户的请求智能分发到后端的多个PHP-FPM实例上,不仅能提升整体处理能力,更重要的是,即使某个实例出问题,其他实例依然能提供服务,系统的可用性自然就上去了。

使用Nginx作为负载均衡器

Nginx本身就是一个高性能的Web服务器和反向袋里,用它来做负载均衡,配置简单,效果显著。

  1. 安装Nginx:第一步,先把Nginx请到你的服务器上。

    sudo apt update
    sudo apt install nginx
  2. 配置Nginx:接下来是核心步骤,编辑Nginx的配置文件(通常是 /etc/nginx/sites-a vailable/default),加入负载均衡的逻辑。看好了,关键在这里:

    upstream php_fpm {
        server unix:/var/run/php/php7.4-fpm.sock;
        server unix:/var/run/php/php7.5-fpm.sock;
        # 你可以在这里继续添加更多的PHP-FPM实例
    }
    
    server {
        listen 80;
        server_name example.com;
        root /var/www/html;
        index index.php index.html index.htm;
    
        location ~ \.php$ {
            fastcgi_pass php_fpm; # 注意,这里指向了上面定义的upstream组
            fastcgi_index index.php;
            include fastcgi_params;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            fastcgi_param PATH_INFO $fastcgi_path_info;
        }
    }

    这个配置定义了一个名为 php_fpm 的后端服务器组,里面包含了两个通过Unix Socket通信的PHP-FPM实例。Nginx会自动将PHP请求分发给它们。

  3. 重启Nginx:让配置生效。

    sudo systemctl restart nginx

2. 使用Keepalived实现高可用性

负载均衡器本身也可能成为单点故障。怎么办?这时候就需要Keepalived登场了。它的拿手好戏是提供“虚拟IP地址”(VIP)。简单来说,它让多台服务器共享一个IP,当主服务器健康时,VIP绑定在它身上;一旦主服务器宕机,VIP会在秒级内自动漂移到备用的服务器上,对用户来说几乎无感。

安装Keepalived

  1. 安装Keepalived:在两台(或多台)准备做高可用的服务器上都执行。

    sudo apt update
    sudo apt install keepalived
  2. 配置Keepalived:编辑配置文件 /etc/keepalived/keepalived.conf。主服务器和备用服务器的配置略有不同,主要体现在 statepriority 参数上。下面是一个主服务器的配置示例:

    vrrp_instance VI_1 {
        state MASTER          # 备用服务器上改为 BACKUP
        interface eth0        # 修改为你的实际网卡名称
        virtual_router_id 51  # 同一组VRRP实例的ID必须相同
        priority 100          # 优先级,备用服务器可设为更低值,如90
        advert_int 1
        authentication {
            auth_type PASS
            auth_pass 42      # 自定义的认证密码,主备需一致
        }
        virtual_ipaddress {
            192.168.1.100     # 这就是要对外提供的虚拟IP(VIP)
        }
    }
    
    virtual_server 192.168.1.100 80 {
        delay_loop 6
        lb_algo rr            # 负载均衡算法,rr表示轮询
        lb_kind DR            # 直接路由模式,性能高
        nat_mask 255.255.255.0
        persistence_timeout 50
        protocol TCP
    
        real_server 192.168.1.1 80 { # 第一台真实后端服务器的IP
            weight 1
            TCP_CHECK {
                connect_timeout 10
                connect_port 80
            }
        }
        real_server 192.168.1.2 80 { # 第二台真实后端服务器的IP
            weight 1
            TCP_CHECK {
                connect_timeout 10
                connect_port 80
            }
        }
    }
  3. 启动Keepalived:配置好后,启动并设置开机自启。

    sudo systemctl start keepalived
    sudo systemctl enable keepalived

3. 使用Docker和Docker Compose

如果你追求更现代的部署方式和极致的弹性,那么容器化方案值得考虑。使用Docker和Docker Compose,可以像搭积木一样轻松创建和管理多个独立的PHP-FPM实例,再配合负载均衡,架构清晰,管理方便。

安装Docker和Docker Compose

  1. 安装Docker

    sudo apt update
    sudo apt install docker.io
  2. 安装Docker Compose:这是一个用于定义和运行多容器Docker应用的工具。

    sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
    sudo chmod +x /usr/local/bin/docker-compose

创建Docker Compose文件

在项目目录下创建一个名为 docker-compose.yml 的文件,用它来定义我们的服务栈。比如,我们可以启动两个不同版本的PHP-FPM容器:

version: '3'
services:
  php-fpm-1:
    image: php:7.4-fpm
    volumes:
      - ./php-fpm-1:/var/www/html # 将本地目录挂载到容器中
    networks:
      - php-network

  php-fpm-2:
    image: php:7.5-fpm
    volumes:
      - ./php-fpm-2:/var/www/html
    networks:
      - php-network

networks:
  php-network:
    driver: bridge

启动Docker容器

一行命令,所有定义好的服务就会在后台运行起来:

docker-compose up -d

配置Nginx负载均衡

容器跑起来了,怎么把流量引进去?方法还是负载均衡。你可以参考本文第一部分“使用Nginx作为负载均衡器”的配置,但需要将 fastcgi_pass 指令指向Docker容器的服务名和端口(例如 php-fpm-1:9000),或者通过Docker网络内部DNS来访问。

好了,三种主流的实现路径都在这儿了。从简单的Nginx负载均衡,到保障入口高可用的Keepalived,再到灵活轻量的Docker容器化方案,每种方法都有其适用场景。关键在于,根据你的团队技术栈、业务规模和维护成本,做出最合适的选择。部署完成后,你的PHP应用就拥有了应对挑战的更强健骨架。

本文转载于:https://www.yisu.com/ask/3004529.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注