服务发现需PHP自行集成,核心是注册中心心跳保活与本地缓存查询;Consul因JSON/REST易用、Web UI友好,开发阶段优于etcd和ZooKeeper;网关不应替代服务自治发现。服务发现不是PHP自带的功能,它是微服务架构里“让服务自己找到彼此”的机制——PHP服务启动时告诉注册中心“我在哪儿、还活着”,其他服务要调用它时,就去注册中心查“谁在线、谁健康、谁可连”。 这事儿PHP不干,得你动手集成;不做服务发现,服务地址就得硬编码,一扩容、一重启就断。
很多新手用 Guzzle 调 /v1/agent/service/register 注册完就以为结束了,结果服务挂了注册中心还不知道,消费者还在往死节点发请求。
/v1/agent/check/pass/xxx),或启用 Consul 的 TTL 检查模式Check 字段,否则 Consul 默认认为“无健康检查=永远健康”Redis 缓存服务列表 + 后台脚本轮询刷新,别让每次请求都打 Consulcurl -X PUT http://consul:8500/v1/agent/service/register \
-d '{
"Name": "user-service",
"Address": "192.168.1.20",
"Port": 8080,
"Check": {
"HTTP": "http://192.168.1.20:8080/health",
"Interval": "10s",
"Timeout": "2s"
}
}'
每次调用前都 GET /v1/health/service/user-service?QPS 上千时 Consul 就成瓶颈了,而且网络抖动会导致返回空列表。
Swoole\Table 或 APCu 里,设置 5–10 秒 TTLStatus: "passing" 才算可用,"warning" 和 "critical" 必须剔除round-robin)适合均质节点,随机(random)更简单但可能不均,Swoole 协程下推荐用原子计数器实现线程安全轮询etcd 的 HTTP 接口是 v2/v3 双版本,PHP 里用 cURL 调 v3 需要 Protobuf 序列化,而 Consul 全是纯 JSON + REST,上手快、报错明、文档全。
curl 一行就能验证注册/查询逻辑zookeeper_connect() 在 PHP 8+ 已废弃用
Kong 或 Nginx + Lua 做网关统一转发,PHP 服务确实不用管发现逻辑了——但代价是:跨语言调用变麻烦、灰度发布难控制、故障定位绕三层(客户端 → 网关 → 服务)。