安装完成Docker之后配置修改相关的内核参数

配置内核参数与开启包转发功能

1. 加载 br_netfilter 模块
  • 作用

    • br_netfilter 模块用于将桥接的网络流量转发至 iptables,从而让 Docker 的网络通信更顺畅。
  • 加载模块

    |-------------------------|
    | modprobe br_netfilter |
    | |

  • 验证模块是否加载成功

    |-----------------------------|
    | lsmod | grep br_netfilter |

    如果出现 br_netfilterbridge,说明加载成功。

  • 设置开机自动加载模块

    1. 创建文件 /etc/sysconfig/modules/br_netfilter.modules

      |--------------------------------------------------|
      | vi /etc/sysconfig/modules/br_netfilter.modules |

    2. 写入以下内容:

      |-------------------------------|
      | #!/bin/bash |
      | /sbin/modprobe br_netfilter |

    3. 赋予执行权限:

      |--------------------------------------------------------|
      | chmod +x /etc/sysconfig/modules/br_netfilter.modules |


2. 修改内核参数
  • 创建配置文件

    |--------------------------------|
    | vi /etc/sysctl.d/docker.conf |

  • 写入以下内容

    |-------------------------------------------|
    | net.bridge.bridge-nf-call-iptables = 1 |
    | net.bridge.bridge-nf-call-ip6tables = 1 |
    | net.ipv4.ip_forward = 1 |

    • net.bridge.bridge-nf-call-iptables:允许桥接流量通过 iptables
    • net.bridge.bridge-nf-call-ip6tables:允许桥接流量通过 ip6tables
    • net.ipv4.ip_forward:启用 IPv4 数据包转发功能。
  • 加载内核参数使其生效

    |---------------------------------------|
    | sysctl -p /etc/sysctl.d/docker.conf |

    确保不会报错,否则需要检查是否提前加载了 br_netfilter 模块。


3. 为什么需要这些参数
  • 如果未开启 net.bridge.bridge-nf-call-iptablesnet.bridge.bridge-nf-call-ip6tables,在安装 Docker 后可能会遇到如下报错:

    |---------------------------------------|
    | bridge-nf-call-iptables is disabled |

    这会导致 Docker 的容器之间无法正常通信。

  • 如果未开启 net.ipv4.ip_forward,当 Linux 主机有多个网卡时,数据包无法在不同网卡之间转发,也可能无法从外部访问 Docker 容器。


验证配置

1. 验证内核参数
  • 查看内核参数是否生效:

    |--------------------------------------|
    | sysctl -a | grep 'bridge\|forward' |

  • 检查关键参数是否为 1

    |-------------------------------------------|
    | net.bridge.bridge-nf-call-iptables = 1 |
    | net.bridge.bridge-nf-call-ip6tables = 1 |
    | net.ipv4.ip_forward = 1 |

2. 重启 Docker 并检查状态
  • 重启 Docker 服务:

    |----------------------------|
    | systemctl restart docker |

  • 检查 Docker 状态是否正常:

    |---------------------------|
    | systemctl status docker |

    如果状态为 Active (Running),说明正常。


配置永久加载模块

1. 开机自动加载模块
  • /etc/modules-load.d 下创建文件:

    |--------------------------------------------|
    | vi /etc/modules-load.d/br_netfilter.conf |

  • 写入模块名称:

    |----------------|
    | br_netfilter |
    | |

  • 保存后,重启主机时该模块会自动加载。

2. 设置自动生效的内核参数
  • 内核参数已写入 /etc/sysctl.d/docker.conf 文件,重启时会自动加载。

配置镜像加速器

1. 原因
  • 默认情况下,Docker 从官方 Docker Hub 拉取镜像,但由于网络原因,速度可能非常慢。
  • 配置国内镜像加速器(如阿里云)可以大幅提升拉取镜像的速度。
2. 步骤
  • 创建或编辑文件 /etc/docker/daemon.json

    |------------------------------|
    | vi /etc/docker/daemon.json |

  • 写入以下内容(示例使用阿里云镜像加速器):

    |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
    | "registry-mirrors": [ "https://docker.m.daocloud.io", "https://gallery.ecr.aws", "https://docker.lmirror.top", "https://atomhub.openatom.cn", "https://docker.m.daocloud.io/", "https://huecker.io/", "https://dockerhub.timeweb.cloud", "https://noohub.ru/", "https://dockerproxy.com", "https://docker.mirrors.ustc.edu.cn", "https://docker.nju.edu.cn", "https://xx4bwyg2.mirror.aliyuncs.com", "http://f1361db2.m.daocloud.io", "https://registry.docker-cn.com", "http://hub-mirror.c.163.com" ], |

  • 重启 Docker 服务:

    |----------------------------|
    | systemctl restart docker |


总结

  1. 关键命令

    • 加载 br_netfilter 模块:

      |-------------------------|
      | modprobe br_netfilter |
      | |

    • 修改内核参数:

      |---------------------------------------|
      | sysctl -p /etc/sysctl.d/docker.conf |

    • 验证模块加载和内核参数:

      |--------------------------------------|
      | lsmod | grep br_netfilter |
      | sysctl -a | grep 'bridge\|forward' |

    • 配置镜像加速器:

      |---------------------------------------------|
      | { |
      | "registry-mirrors": ["https://<你的加速器地址>"] |
      | } |

  2. 注意事项

    • 在加载内核参数之前,必须先加载 br_netfilter 模块,否则会报错。
    • 修改内核参数后需要重启 Docker 服务,确保配置生效。
    • 配置镜像加速器后建议测试镜像拉取速度。
相关推荐
.柒宇.3 小时前
RedHat10-Ansible部署Docker操作
docker·eureka·ansible
木雷坞4 小时前
内网模型服务启动链路分层实践
docker·容器·gpu
江湖有缘4 小时前
保姆级教程:Docker 部署 Portracker 端口监控工具
jvm·docker·容器
jinanwuhuaguo6 小时前
(第三十六篇)OpenClaw 去中心化的秩序——从“中心调度”到“网格自治”的治理革命
java·大数据·开发语言·网络·docker·去中心化·github
摇滚侠18 小时前
Docker 如何查询挂载的目录
运维·docker·容器
头发够用的程序员18 小时前
C++和Python面试经典算法汇总(一)
开发语言·c++·python·算法·容器·面试
胡小禾1 天前
K8S常识-如何指定只更新一个deployment中的某一个实例
云原生·容器·kubernetes
江湖有缘1 天前
基于Ubuntu系统Docker部署Note Mark:从安装到配置全流程
linux·ubuntu·docker
呆萌的代Ma1 天前
docker内的n8n配置Code节点运行python代码
python·docker·容器
菜鸟分享录1 天前
OpenClaw Docker一键部署(轻松实现多容器隔离)
docker·ai·openclaw·小龙虾