如何精确调整业务服务的资源 request 和 limit? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
yyttrr

如何精确调整业务服务的资源 request 和 limit?

  •  
  •   yyttrr 2023 年 7 月 31 日 1929 次点击
    这是一个创建于 999 天前的主题,其中的信息可能已经有所发展或是发生改变。

    两个月前为了降本增效,按照实际使用量 95%最大值的 1.35 倍给了 request ,3 倍给了 limit

    完成之后的确释放了一波节点,月成本有下降

    经过两个月的业务需求上线,很多 deployment 的 hpa 要么不伸缩,要么时不时的打到上限

    看了看业务代码,有些是加了个全局 map 导致内存增大,有些是拆出去一个新微服务导致老微服务使用率很低,还有突然上线一个活动导致一个 deployment oom 了

    几百个无状态微服务,我自己手动调整太累,让研发调整不太现实

    7 条回复    2023-08-25 16:21:53 +08:00
    isno
        1
    isno  
       2023 年 7 月 31 日   1
    我之前代码分析过 1000 多个服务,手动不现实,运维最多把资源大盘搞出来,把成本分析发给各个业务部门,降本增效得联合开发一起搞。还有 limit 是你设置的,OOM 影响业务了,你没背锅?

    说说我的想法:
    把降本的 KPI 丢给研发,确定百万用户/成本,每万请求多少钱之类的指标,核算出一个业务的上限预算。
    和业务部门确定服务分级,预估资源。 分配不同的 namespace ,通过 namespace 设置资源限制,再弄个预警机制,超限了让研发确认原因,核心服务不要限死 limit ,服务挂了被大锅。
    pc10201
        2
    pc10201  
       2023 年 7 月 31 日
    自己学写程序,调用 api 调整
    yyttrr
        3
    yyttrr  
    OP
       2023 年 7 月 31 日
    @isno 有个保底的自动扩容程序在,一个 pod oom 了自动扩 pod 到 hpa max 的 2 倍,说是网络波动搪塞过去了
    我们一个组 20 几个后端研发,对 k8s 有概念的不超过 3 个,让他们自己接手资源调整和 hpa 调整得培训几次,不知道领导会不会觉得我在甩锅~
    yyttrr
        4
    yyttrr  
    OP
       2023 年 7 月 31 日
    @pc10201 我举了几个例子,一个微服务业务上什么时候变得重要了,资源消耗多了少了我是无法知道的,也无法预测,滞后的调整为了稳定性得留下大量冗余,要么资源使用率上不去,要么稳定性受到影响
    RatioPattern
        5
    RatioPattern  
       2023 年 8 月 1 日
    这么点研发上 limit ,折腾人,你们公司要裁员了吧
    julyclyde
        6
    julyclyde  
       2023 年 8 月 2 日
    主要看这活是不是你的职责了
    如果是你的职责,那你就做好,并计入工作成绩,别推脱太累
    如果不是你的职责,你给个大概参考意见就行了
    caicaiwoshishui
        7
    caicaiwoshishui  
       2023 年 8 月 25 日
    你这个明显要区分活动中的 deployment 和平时 deployment 的流量
    搞活动需要提前扩容呀,扩容完就缩回去。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2901 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 44ms UTC 03:25 PVG 11:25 LAX 20:25 JFK 23:25
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86