1
brader 319 天前
一个月才膨胀到 1G 内存,可以不用理。看下开启一下多少个请求就重启的配置应该就行了
|
2
996635 319 天前
FPM 直接设置 max_requests 低一些, 会自动销毁并新建。
|
3
phpfpm 319 天前
你们一个月不上线?
|
4
ZeekChatCom 319 天前
@phpfpm 上线也不一定要重启啊
|
5
well775397252 OP @996635 感觉没解决根本问题,想排查一下原因
|
6
well775397252 OP @brader 每个 worker 大到 200m ,按道理几十 M 才正常吧
|
7
ben1024 319 天前
. 排查:
如果知道是哪个业务线, 就用 Xdebug 逐步看执行内存情况, 主要在于静态或内存变量相互依赖 如果不知道用 Tideways 试试 . 直接点 max_requests 设置小一些, 精神压力小很多 |
8
markgor 319 天前
如果没使用到 fastcgi_finish_request 理论上不会有代码级别的内存泄漏问题。
至于 php-fpm ,我记得申请后的内存就算使用完,也不会放出给系统,避免下次使用重新申请, 另外还有第三方扩展等的原因 |
9
brader 319 天前
@well775397252 这个不一定,看业务的,二三十 M 比较常见,几百 M 可能是有些接口有大数组,或者像 excel 导入导出之类的业务
|
10
ucando 319 天前
其实我更想知道要怎么操作才会内存泄漏?
|
11
well775397252 OP |
12
well775397252 OP @ben1024 哎,都试试吧,先压测一下瞧瞧
|
13
QlanQ 319 天前
不认为你这存在内存泄露,如果是有问题,1 个月才到 1G ?流量多一点,分分钟都能爆了吧
|
14
Logtous 319 天前
xhprof 分析看看
|
15
woshicixide 319 天前
你这问题有点问的有点不清不楚,这 1 个多 G 是单个 worker 还是全部加起来,另外 fpm 大概率不会有这种问题,可以看看你装的扩展有没有可能
|
16
encro 319 天前
yii2 的 10 年老用户了。。。
修改 fpm 配置,跑完 1000 个请求就销毁,永远不会有问题的。。。 你首先得找到是那个进程的问题。内存持续增加,那么是命令行程序? |
17
encro 319 天前
@well775397252
每个 work200m ,可能是因为你 php 装了一些没用的扩展。开启了没必要的缓存。 |
18
encro 319 天前
很可能是你开启了 xdebug
|
19
well775397252 OP @encro #16 php-fpm,现在没开启自动重启进程那个配置
|
20
well775397252 OP @woshicixide 全部加起来,平均每个进程 200 多 M
|
21
encro 319 天前
php 开启了 xdebug ,结巴词库,ip 地址库之类,为了提高性能,有些程序会将字典之类的加载的内存,很正常。
|
22
zhangqilin 319 天前 1
内存满了不一定不会回收,你放到一台内存小点的机器上或者 pod 上,
比如 1 个月 1g ,你放到 500m 的上,然后压测看会不会 OOM 说不定内存占用过多了就会回收了 |
23
coderzhangsan 319 天前
@well775397252 #20 平均每个进程 200 多 M ,fpm 配置里 pm.max_requests 设置的多少,如果设置的比较大,那有可能会增长到这个两级,把这个值适当降低就可以了;正常来讲 fpm 进程很难会内存溢出,除非一些占用内存的比较大的场景才会,例如大数据的导入和导出,又或者开启了 debug 等扩展,静态内存占用较大。
|
24
hahamy 319 天前
每个 fpm 进程 200 多兆,200 多兆看的是哪个值? top 命令的内存有几个指标
|
25
Rorysky 319 天前
不是什么关键业务就定时重启,有时间关注现实生活
|
26
NjcyNzMzNDQ3 319 天前
xhprof +1 , 这个工具用堆栈排查每个方法占用内存大小、耗时、cpu 用量,我之前有 curl_util 忘记 close 就用的他
|
27
yc8332 319 天前
要看你怎么重启 fpm 的,一直开着的话,如果你的请求中有需要大内存的,很正常。
|
28
lairdnote 319 天前
xhprof. 或者跟踪进程 xstrace
|
29
alex8 318 天前 via iPhone
Php 被发明时就有内存泄漏,7 以后已经好很多了。需要 max request 参数定期杀进程,不然多大的内存都能慢慢吃完
|