百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

kubecon 2023丨阿里云原生专题分享学习笔记

liuian 2025-06-08 22:35 30 浏览

公主号链接,欢迎关注:
https://mp.weixin.qq.com/s/M5DST_SmrWdxIsrt4tBNzA

本文整理自 kubecon 2023 阿里云原生相关主题分享,原文可参考
https://developer.aliyun.com/article/1338251

  • 前四分享偏细节和干货
  • 后三分享偏务虚

《智能运维下的生产环境容器网络排障实践》

概述

端到端网络诊断数据链路工具,卖点是 “数据全” + "自动化 (导致排查问题快)"

内容

  • 容器网络运维复杂原因
    • 概念复杂:service / network-policy / ingress ...
    • 实现复杂 (定位困难):压测环境 -> 多处抓包 -> 定位丢包点 -> 分析配置 (iptables / kernel conf / vendor ...)
  • 容器网络诊断
    • 接入、连通性、深度网络异常 (下图,最终透出 abnormal metrics、log、event)
  • 案例:部分请求超时
    • 原因:节点 VPN 软件网段与下游 Pod 所在节点网段重叠,数据包路由到错误的网络设备
    • 优势:自动诊断排查时间从传统定位手段 1h 减少到 5min
  • 案例:upstream 偶发 499/504
    • 原因:JVM GC 导致服务关闭连接过慢,upstream 连接队列溢出导致 ingress 处理时间久,客户端超时关闭
    • 过程:安装 exporter 观察 TCP 连接数突涨,且同时 ListenDrops 和 ListenOverflow 均大于 0

《尚游网络基于 OpenKruise Game 游戏云原生化实践》

概述

针对有状态服务定制新的编排模型 GameServerSet,卖点是 "场景定制"

内容

  • 背景:尚游 全面微服务后的痛点
    • 响应延迟:有高响应延时要求的业务应该使用异步模型 -> 自研框架
    • 有状态:抽象 Entity 作为有状态载体 (重点解决的问题)
      • Entity = 小型 Service,可动态加载和销毁,并可在有状态 pod 中转移和负载均衡
    • 多服务/集群:配置管理复杂
  • OpenKruise:
    • GameServerSet 在游戏场景下增强 StatefulSet:70% 字段相同 (迁移平滑)
    • 优势
      • 固定 IP:节约 proxy 成本 (以及对应的路由开销)
      • 自动扩缩:StatefulSet 只能从大到小缩容,GameServerSet 可指定回收某个 pod (根据负载)

《基于 Fluid 加速 AIGC 模型推理服务的技术解析和优化》

概述

针对数据密集性应用 (eg. AIGC) 提供数据编排模型 Fluid,卖点是缓存管理 "自动化" (客户端配合优化)

内容

  • 背景
    • AIGC 模型推理最大问题:“数据” 高延迟+高带宽
    • 预估:从对象存储中加载 Bloom-175B 模型 (约 340GB),耗时约4300s
      • 对象存储 I/O 吞吐 = 100MB/s~500MB/s,非容器化本地 SSD I/O 吞吐 = 1~2GB/s
    • 可选项:cache,但仍然会带来 cache 管理的工程问题 (重点解决的问题)
  • Fluid
    • 概述:帮助用户管理和运维缓存、简化系统部署和访问、编排数据消费流程
    • 优势
      • 数据抽象:Dataset、Runtime、Data Operations 分别描述 数据源、缓存运行时、缓存操作
      • 缓存弹性
        • 带宽弹性:可用带宽正比于分布式缓存的节点规格和数量
        • 回收策略:根据不同业务的特点定制不同的缓存副本弹性策略
      • 异构兼容
      • 数据编排:自动化
  • 优化
    • "多线程读" 和 "预读" 等手段优化客户端模型加载

《费芮互动使用 Higress 作为 Kubernetes Ingress 实现稳定性和性能提升》

概述

基于 Higress 解决 nginx 网关的若干痛点问题,卖点是 "纯系统" 的 扩展、稳定、性能 ...

内容

  • 费芮互动:集成多平台/渠道实现用户串联
  • 痛点:nginx ingress
    • 稳定性
      • ingress 共享 controller,单个配置变更会导致 reload 太频繁 (影响长链接)
      • 连接过多,导致健康检查容易超时
    • 性能:控制面/数据面共享 Pod,开启 ModSecurity 模块性能下降 10 倍 ...
    • 功能:限流策略不够灵活
    • 运维
      • 独立节点部署:资源隔离;ExternalTrafficPolicy 设置为 Local 模式内部服务无法正常访问 Ingress
      • daemon 部署:资源干扰;ExternalTrafficPolicy 设置为 Local 模式可减少一次 NAT
  • 解法:Higress
    • 稳定性
      • 控制面/数据面 分离
      • 配置变更后不需要 reload 数据面
    • 性能
      • 定时扩缩容
      • 数据面直连后端 POD (不经过 NodePort 转发):这块我理解的点在于网络定制
    • 功能
      • 集成 Sentinel 全局限流
      • 自建认证鉴权服务
      • 对接阿里云安全产品
      • ...
    • 运维
  • 开源
    • 不和 K8S 生态完全绑定,但同时满足 高集成、标准化、易扩展、热更新 等各种能力

《基于 eBPF 构建下一代智能可观测系统》

本分享相对比较水,没有什么干货,下图分别是 eBPF 字节码示意图 和 “网络栈接收数据包" 的概览图

《Serverless 研发平台—极简上云体验》

同样没有什么干货,比较像介绍 SAE 的软文

  • 云优势
    • 效率:全链路栈
    • 降本:弹性;多类型业务整合利用率
    • 稳定:容灾
  • serverless 应用 (生态)
    • 流量托管:南北 (多租路由)、东西 (注册中心)
    • 弹性伸缩
    • 数据库:支持对接 自建、RDS
    • 文件存储:对接阿里云 NAS、OSS ...
    • 监控:ARMS ...
    • 日志:推荐 Kafak / SLS,不推荐本地
    • ......

《Apache RocketMQ 5.0 的 Serverless 化之路》

同样没有什么干货,重点介绍 RocketMQ “存算分离” 支持云原生化

  • 存算分离
    • 轻量级 SDK
    • 无状态代理层
    • 无主化的存储节点 Broker
    • 云原生基础设施

相关推荐

Javascript中的字符串拼接(js字符串拼接效率)

字符串拼接是所有程序设计语言都需要的操作。当拼接结果较长时,如何保证效率就成为一个很重要的问题。本文介绍的是Javascript中的字符串拼接,希望对你有帮助,一起来看。consticon=&#...

C#-字符串常用方法(2) 104(c#字符串处理函数)

IndexOf()查找某字符或字符串在要查找字符串中第一次出现的下标,与数组相同从零开始,如果没有找到对应的数据,则返回-1LastIndexOf()查找某字符或字符串在要查找字符串中最后一次出现...

C#拼接字符串及简单性能比较(c# 如何高效拼接字符串)

在C#编程中拼接字符串应该是最常见的场景之一,假如现在有几个变量需要转换成字符串并按格式拼接,常用的几种方法:inta=1;charb='c';doublec=1...

C# 字符串连接方式有哪些?各自有什么特点?

在C#中,有几种方式可以连接字符串,每种方式都有其特点和适用场景。以下是常见的几种方式:使用连接符"+":使用加号"+"可以简单地将两个字符串连接起来。这种方式简...

字符串也可以比较大小?C语言的strcmp函数

在C语言中,因为字符串没有被封装成对象,所以直接用==、!=比较。C语言提供了一个用于字符串比较的函数类型strcmp。注意,字符串和字符完全不同,因为不同的编译器实现问题,返回值的情况也有所变化...

JavaScript 常用功能总结(javascript的功能)

编吐血整理加上翻译,太辛苦了~求赞!本文主要总结了JavaScript常用功能总结,如一些常用的额JS对象,基本数据结构,功能函数等,还有一些常用的设计模式。目录:众所周知,JavaScript是...

C++20 新特性(16):三路比较运算符()一统浆糊

C++语言的比较操作符有很多,包括:==、!=、>、>=、<、<=等,如果要实现对象的大小比较功能,需要实现这些函数,比较繁琐,而且如果实现不好,这些...

C++中重载运算符的使用(c++重载操作符)

C++中重载运算符的使用:用户定义的类型,如:字符串,日期,复数,联合体以及文件常常重载二元+操作符以实现对象的连接,附加或合并机制。但是要正确实现+操作符会给设计,实现和性能带来一定的挑战。...

《学习C++》基本概念之标识符(c++标识符的定义)

标识符(identifier)是C++基本词法单元(即令牌token)之一,由字母(letter)、数字(digit)、下划线(underscore)组成,但是首字符必须为字母或下换线。标识符的用途主...

Java判断Integer相等-应该这么这样用

先看下这段代码,然后猜下结果:Integeri1=50;Integeri2=50;Integeri3=128;Integeri4=128;System.out.prin...

C语言模拟实现字符串操作函数(c语言模拟实现字符串操作函数是什么)

1.strlenstrlen是用来求字符串长度的函数,字符串长度就是字符串中包含的字符的个数,但是不包含字符串结尾的‘\0’实现strlen有三种方法:(1)定义一个计数器size_t ...

C++ 知识小结(c++知识总结)

C语言typedef与#define比较https://www.runoob.com/note/24230野指针和悬空指针区别?野指针:指的是没有被初始化过的指针。解决方法:指针变量未及时...

Python字符串比较的隐藏法则:Unicode对决、内存地址暗战!

字符串比较的底层规则核心原理:字符逐个对比,基于Unicode值一决胜负!#规则演示:从首字符开始逐位比较print("apple">"app")...

在C++中,如何避免出现Bug?(c++防止闪退)

C++中的主要问题之一是存在大量行为未定义或对程序员来说意外的构造。我们在使用静态分析器检查各种项目时经常会遇到这些问题。但正如我们所知,最佳做法是在编译阶段尽早检测错误。让我们来看看现代C++中的一...

harmony-utils之StrUtil,字符串工具类

harmony-utils简介与说明harmony-utils一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备...