码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Containerd 如何配置 Proxy?


    前言

    在某些 air gap 场景中,往往需要离线或使用代理 (Proxy), 例如:

    1. 需要通过 Proxy pull 容器镜像:
      1. Docker Hub: docker.io
      2. Quay: quay.io
      3. GCR: gcr.io
      4. GitHub 镜像库:ghcr.io
    2. 在某些企业环境中,需要通过代理访问外部服务

    Docker 如何配置代理想必大家都很清楚,但是自从 Kubernetes 1.20 版本以后开始弃用 Docker, containerd 逐渐成为主流 CRI.
    所以我们下面介绍一下如何配置 contaienrd 的 Proxy.

    📝Notes:

    还有一种场景需要 containerd 配置 proxy, 就是将 Dragonfly 和 containerd 结合使用 的时候。

    Containerd 配置 Proxy 步骤

    这里以通过 systemd 安装的 containerd 为例。

    containerd 的配置一般位于 /etc/containerd/config.toml 下,service 文件位于:/etc/systemd/system/containerd.service
    配置 Proxy 可以通过 service 环境变量方式配置,具体如下:

    创建或编辑文件:/etc/systemd/system/containerd.service.d/http-proxy.conf

    内容如下:

    [Service]
    Environment="HTTP_PROXY=http://127.0.0.1:7890"
    Environment="HTTPS_PROXY=http://127.0.0.1:7890"
    Environment="NO_PROXY=localhost"
    

    配置后保存重启即可:

    systemctl restart containerd.service
    

    最佳实践:Proxy 中 NO_PROXY 的推荐配置

    在配置 Proxy 时要特别注意,哪些要走 Proxy, 哪些不走 Proxy 要非常明确,避免出现网络访问异常甚至业务异常。

    这里有个推荐 NO_PROXY 配置:

    1. 本地地址和网段:localhost 和 127.0.0.1 或 127.0.0.0/8
    2. Kubernetes 的默认域名后缀:.svc 和 .cluster.local
    3. Kubernetes Node 的网段甚至所有应该不用 proxy 访问的 node 网段:
    4. APIServer 的内部 URL:
    5. Service Network:
    6. (如有)etcd 的 Discovery Domain:
    7. Cluster Network:
    8. 其他特定平台相关网段(如 DevOps, Git/制品仓库。..):
    9. 其他特定 NO_PROXY 网段:
    10. 常用内网网段:
      1. 10.0.0.0/8
      2. 172.16.0.0/12
      3. 192.168.0.0/16

    最终配置如下:

    [Service]
    Environment="HTTP_PROXY=http://127.0.0.1:7890"
    Environment="HTTPS_PROXY=http://127.0.0.1:7890"
    Environment="NO_PROXY=localhost,127.0.0.0/8,10.0.0.0/8,172.16.0.0/12,192.168.0.0/16,.svc,.cluster.local,.ewhisper.cn,,,,,,,"
    

    🎉🎉🎉

    总结

    Kubernetes 1.20 以上,企业 air gap 场景下可能会需要用到 containerd 配置 Proxy.
    本文介绍了其配置方法,以及配置过程中 NO_PROXY 的最佳实践。

    本文由东风微鸣技术博客 EWhisper.cn 编写!

  • 相关阅读:
    ubuntu xrdp远程登录一直弹出Authentication required. System policy prevents WiFi scans
    基于CentOS 7.6安装及配置APISIX 3.0环境
    java中Collection.stream()流用法详解
    要闻 | 自然资源部实景三维建设与城市精细化治理工程技术创新中心揭牌仪式暨第二季度工作推进会顺利召开
    JS-(14)表单验证
    从设备树(dtb格式数据)中解析出bootargs
    笔记41:关于CIAC_PNC_4选用控制器的一些感悟
    Java序列化和反序列化
    1-k8s1.23.6-底座搭建-基于docker
    mysql各个锁的区别
  • 原文地址:https://www.cnblogs.com/east4ming/p/16898399.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号