您的位置:首页 >php-fpm在ubuntu上如何实现高可用性
发布于2026-04-28 阅读(0)
扫一扫,手机访问

想让你的PHP应用在Ubuntu上坚如磐石,扛得住流量高峰,也经得起意外宕机?实现PHP-FPM的高可用性是关键一步。别担心,这事儿没想象中那么复杂,核心思路就是“别把鸡蛋放在一个篮子里”。下面这几种经过实战检验的方法,总有一款适合你的业务场景。
这是最直观的思路:让流量分摊。通过负载均衡器将用户的请求智能分发到后端的多个PHP-FPM实例上,不仅能提升整体处理能力,更重要的是,即使某个实例出问题,其他实例依然能提供服务,系统的可用性自然就上去了。
Nginx本身就是一个高性能的Web服务器和反向袋里,用它来做负载均衡,配置简单,效果显著。
安装Nginx:第一步,先把Nginx请到你的服务器上。
sudo apt update
sudo apt install nginx
配置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请求分发给它们。
重启Nginx:让配置生效。
sudo systemctl restart nginx
负载均衡器本身也可能成为单点故障。怎么办?这时候就需要Keepalived登场了。它的拿手好戏是提供“虚拟IP地址”(VIP)。简单来说,它让多台服务器共享一个IP,当主服务器健康时,VIP绑定在它身上;一旦主服务器宕机,VIP会在秒级内自动漂移到备用的服务器上,对用户来说几乎无感。
安装Keepalived:在两台(或多台)准备做高可用的服务器上都执行。
sudo apt update
sudo apt install keepalived
配置Keepalived:编辑配置文件 /etc/keepalived/keepalived.conf。主服务器和备用服务器的配置略有不同,主要体现在 state 和 priority 参数上。下面是一个主服务器的配置示例:
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
}
}
}
启动Keepalived:配置好后,启动并设置开机自启。
sudo systemctl start keepalived
sudo systemctl enable keepalived
如果你追求更现代的部署方式和极致的弹性,那么容器化方案值得考虑。使用Docker和Docker Compose,可以像搭积木一样轻松创建和管理多个独立的PHP-FPM实例,再配合负载均衡,架构清晰,管理方便。
安装Docker:
sudo apt update
sudo apt install docker.io
安装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.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-compose up -d
容器跑起来了,怎么把流量引进去?方法还是负载均衡。你可以参考本文第一部分“使用Nginx作为负载均衡器”的配置,但需要将 fastcgi_pass 指令指向Docker容器的服务名和端口(例如 php-fpm-1:9000),或者通过Docker网络内部DNS来访问。
好了,三种主流的实现路径都在这儿了。从简单的Nginx负载均衡,到保障入口高可用的Keepalived,再到灵活轻量的Docker容器化方案,每种方法都有其适用场景。关键在于,根据你的团队技术栈、业务规模和维护成本,做出最合适的选择。部署完成后,你的PHP应用就拥有了应对挑战的更强健骨架。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9