Docker run 子命令与运行优化相关的参数

Docker run 子命令与运行优化相关的参数

Docker run 命令有许多参数可以优化容器性能和资源使用。以下是与运行优化相关的重要参数:

资源限制参数

  1. CPU 资源控制

    • --cpus=<value>: 限制容器可以使用的 CPU 数量(Docker 1.13+)
    • --cpu-shares/-c: 设置 CPU 共享权重(默认 1024)
    • --cpuset-cpus: 指定容器可以运行的 CPU 核心(如 "0-3" 或 "0,1")
  2. 内存限制

    • --memory/-m: 设置内存限制(如 "512m" 或 "2g")
    • --memory-swap: 设置内存+交换分区总限制
    • --memory-reservation: 设置内存软限制
  3. I/O 限制

    • --blkio-weight: 设置块 IO 权重(10-1000)
    • --device-read-bps: 限制设备的读取速率(如 "/dev/sda:1mb")
    • --device-write-bps: 限制设备的写入速率

性能优化参数

  1. 文件系统优化

    • --tmpfs: 挂载 tmpfs 文件系统(内存文件系统)
    • --mount: 更灵活的挂载选项(替代 -v
    • --volumes-from: 重用其他容器的卷
  2. 网络优化

    • --network: 指定网络模式(host/bridge/none 等)
    • --dns: 自定义 DNS 服务器
    • --dns-search: 设置 DNS 搜索域
  3. 进程管理

    • --ulimit: 设置 ulimit 选项
    • --oom-kill-disable: 禁用 OOM Killer
    • --pids-limit: 限制容器内的进程数

启动优化参数

  1. 容器初始化

    • --init: 使用 init 进程作为 PID 1(处理僵尸进程)
    • --cap-add/--cap-drop: 添加/删除 Linux 能力
  2. 重启策略

    • --restart: 设置容器退出时的重启策略(no/on-failure/always/unless-stopped)
  3. 安全优化

    • --security-opt: 设置安全选项(如 seccomp 或 SELinux)
    • --userns: 使用用户命名空间

使用示例

bash 复制代码
# 限制 CPU 和内存使用
docker run -it --cpus=1.5 --memory=2g --memory-swap=3g nginx

# 使用 tmpfs 提高临时文件访问速度
docker run --tmpfs /tmp:rw,size=512m nginx

# 优化 IO 性能
docker run --device-read-bps /dev/sda:1mb --device-write-bps /dev/sda:1mb mysql

# 使用 init 系统处理僵尸进程
docker run --init -d my_app

这些参数可以根据具体应用场景进行组合使用,以达到最佳的性能和资源利用率。

相关推荐
mseaspring12 分钟前
一款用于监控跨多台主机 Docker 容器的实时终端
运维·docker·容器
heimeiyingwang1 小时前
【架构实战】Kubernetes日志收集:EFK/Loki架构
容器·架构·kubernetes
SPC的存折4 小时前
6、Docker常用配置
运维·docker·容器
图图玩ai5 小时前
SSH 命令管理工具怎么选?从命令收藏到批量执行一次讲清
linux·nginx·docker·ai·程序员·ssh·可视化·gmssh·批量命令执行
SPC的存折6 小时前
4、Docker私有仓库
运维·docker·容器
齐潇宇7 小时前
Docker概述与安装
linux·运维·docker·容器
SilentSamsara7 小时前
存储卷体系:EmptyDir/HostPath/PV/PVC/StorageClass 的选型决策树
服务器·微服务·云原生·容器·架构·kubernetes·k8s
亚空间仓鼠8 小时前
Docker 容器技术入门与实践 (二):Dockerfile文件
运维·docker·容器
亚空间仓鼠8 小时前
Docker 容器技术入门与实践 (一):命令与镜像、容器管理
运维·docker·容器
王的宝库8 小时前
【K8s】集群安全机制(二):授权(Authorization)详解与实战
学习·云原生·容器·kubernetes