0

0

Linux Bottlerocket 的容器专用 OS 与 Kubernetes 集成优势

冷炫風刃

冷炫風刃

发布时间:2026-02-17 15:57:10

|

880人浏览过

|

来源于php中文网

原创

bottlerocket 不运行 systemd 等传统 init 系统,因其是专为容器设计的精简 os,移除非必要用户态服务以最小化攻击面、加速启动并实现原子更新;运维须通过 kubernetes api 或 apiclient,配置由 settings api 统一管理。

linux bottlerocket 的容器专用 os 与 kubernetes 集成优势

为什么 Bottlerocket 不直接运行 systemd 或传统 init 系统

Bottlerocket 本质是“只跑容器”的 OS,它砍掉了所有非必需的用户态服务——包括 systemdsshdbash(默认不带)、甚至 curlps。这不是为了炫技,而是让攻击面最小化、启动更快、更新更原子。

实际影响是:你不能用 systemctl restart kubelet,也不能 ssh 进去改配置;所有运维必须走 Kubernetes API 或 Bottlerocket 自带的 apiclient 工具。

  • 所有节点配置通过 settings API 控制,比如 host-containers.<container-name>.enabled</container-name>
  • kubelet 是唯一被允许直接管理容器的组件,其他容器必须通过 host-containers 声明式启用
  • 没有 /etc/systemd/system,也没有 /usr/bin 下的通用工具链——想调试?得用 apiclient 或临时启用 admin-container

如何在 Bottlerocket 上安全启用 admin-container 调试

官方明确不推荐长期开启 admin-container,但它确实是排查网络、证书、kubelet 启动失败等问题的唯一入口。关键不是“能不能开”,而是“怎么开才不破坏安全模型”。

它不是一个 shell,而是一个受限的、只读挂载了 host rootfs 的容器,镜像由 AWS 维护(如 public.ecr.aws/bottlerocket/admin-container:1.15.0),且默认禁用。

  • 启用方式只能通过节点启动时的 userdata(或 AMI 设置):设置 settings.host-containers.admin.enabled = true
  • 切勿在运行中用 apiclient 动态开启——这会触发 reboot,因为 settings 变更需原子更新
  • 进入后没有 sudo,不能写 host 文件系统;mountipnsenter 等工具存在但权限受限
  • 若看到 Failed to connect to api.bottlerocket.aws:8000,大概率是 kubelet 没起来或 CNI 未就绪,此时 admin-container 本身可能无法拉起

kubelet 配置差异:Bottlerocket 不支持 --config 文件路径

Bottlerocket 的 kubelet 启动参数完全由 OS 层控制,不读取 /var/lib/kubelet/config.yaml,也不接受 --config 参数。所有配置项映射为 settings 键值,例如:

Synthesys
Synthesys

Synthesys是一家领先的AI虚拟媒体平台,用户只需点击几下鼠标就可以制作专业的AI画外音和AI视频

下载

settings.kubernetes.cluster-dns = ["10.100.0.10"] → 对应传统 --cluster-dns

settings.kubernetes.node-labels = "node.kubernetes.io/lifecycle=spot" → 对应 --node-labels

  • 错误做法:往 /etc/kubernetes/kubelet.conf 写内容,或试图挂载自定义 configmap —— kubelet 启动时会忽略
  • 正确路径:所有配置必须通过 apiclient 提交,或在节点启动前固化进 userdata / Ignition config
  • 常见坑:settings.kubernetes.cluster-domain 默认是 cluster.local,但如果你的 CoreDNS 配置了不同 domain,这里不一致会导致 Service DNS 解析失败
  • 性能影响:每次 apiclient put 都触发 reboot,频繁调用等于频繁中断 workload —— 配置务必一次对齐

AMI 更新与 os-release 版本号怎么看

Bottlerocket 的版本不是靠 uname -rcat /etc/os-release 直观判断的。它的版本号结构是 1.15.0-9762c5a5,其中后缀是构建哈希,不是语义化版本的一部分。

真正决定兼容性的,是 AMI ID 和对应的 release-channel(如 stabletesting),而非表面数字。

  • 查当前版本:运行 apiclient get settings.os.version,返回类似 "1.15.0"
  • 查 AMI 是否匹配集群要求:Kubernetes 1.28 要求 Bottlerocket ≥ 1.14.0,但具体到 patch 版本,得看 GitHub Release 页面Supported Kubernetes Versions 表格
  • 升级不是 yum update,而是替换节点:新 AMI + 新 userdata + 滚动更新策略;旧节点上的容器不会自动迁移,必须靠控制器(如 Deployment)重建
  • 容易忽略的一点:settings.kernel.parameters 修改后,即使只是加一个 net.ipv4.ip_forward=1,也会导致 kernel 重启——因为 Bottlerocket 把 kernel 参数也纳入原子更新范围

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

452

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

181

2023.10.30

Golang channel原理
Golang channel原理

本专题整合了Golang channel通信相关介绍,阅读专题下面的文章了解更多详细内容。

256

2025.11.14

golang channel相关教程
golang channel相关教程

本专题整合了golang处理channel相关教程,阅读专题下面的文章了解更多详细内容。

349

2025.11.17

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

2416

2026.01.21

Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务
Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务

Golang云原生微服务Kubernetes (K8s) 是指 使用 Go 语言(Golang)编写的云原生微服务,并利用 Kubernetes 平台进行容器化部署、自动化管理、弹性伸缩和高效编排的一整套现代应用架构方案。

27

2025.12.22

Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务
Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务

Golang云原生微服务Kubernetes (K8s) 是指 使用 Go 语言(Golang)编写的云原生微服务,并利用 Kubernetes 平台进行容器化部署、自动化管理、弹性伸缩和高效编排的一整套现代应用架构方案。

27

2025.12.22

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1520

2023.06.21

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

283

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.3万人学习

Git 教程
Git 教程

共21课时 | 3.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号