本文最后更新于 2024-07-19,

若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益, 请联系我 删除。

本站只有Telegram群组为唯一交流群组, 点击加入

文章内容有误?申请成为本站文章修订者或作者? 向站长提出申请

前言

docker是一个用Go语言实现的开源项目,可以让我们方便的创建和使用容器,docker将程序以及程序所有的依赖都打包到docker container,这样你的程序可以在任何环境都会有一致的表现,这里程序运行的依赖也就是容器就好比集装箱,容器所处的操作系统环境就好比货船或港口,程序的表现只和集装箱有关系(容器),和集装箱放在哪个货船或者哪个港口(操作系统)没有关系

因此我们可以看到docker可以屏蔽环境差异,也就是说,只要你的程序打包到了docker中,那么无论运行在什么环境下程序的行为都是一致的,程序员再也无法施展表演才华了,不会再有“在我的环境上可以运行”,真正实现“build once, run everywhere”。

此外docker的另一个好处就是快速部署,这是当前互联网公司最常见的一个应用场景,一个原因在于容器启动速度非常快,另一个原因在于只要确保一个容器中的程序正确运行,那么你就能确信无论在生产环境部署多少都能正确运行。

官方网站:https://www.docker.com/

官方手册:https://docs.docker.com/

docker项目市场:https://hub.docker.com/

非Ubuntu系统请参考该手册(官方):https://docs.docker.com/engine/install/

Ubuntu Server 22

非大陆服务器

更新包索引

sudo apt-get update

安装必备的软件包以允许apt通过 HTTPS

sudo apt-get install ca-certificates curl gnupg lsb-release

添加Docker官方版本库的GPG密钥:

sudo mkdir -p /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg

使用以下命令设置存储库:

echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

更新apt包索引,安装最新版本的Docker Engine、containerd 和 Docker Compose:

sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin

验证Docker是否安装成功

docker version

大陆服务器

添加阿里云的GPG密钥

curl -fsSL http://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

使用以下命令设置存储库

sudo add-apt-repository "deb [arch=amd64] http://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"

更新apt包索引,安装最新版本的Docker Engine、containerd 和 Docker Compose:

sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin

验证Docker是否安装成功

docker version

Debian 12

国外服务器

更新包索引

sudo apt update
sudo apt upgrade -y

安装必要的依赖

sudo apt install -y apt-transport-https ca-certificates curl software-properties-common

添加Docker官方版本库的GPG密钥:

curl -fsSL https://download.docker.com/linux/debian/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

使用以下命令设置存储库:

echo "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/debian $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

更新apt包索引,安装最新版本的Docker Engine、containerd 和 Docker Compose:

sudo apt-get update
sudo apt install -y docker-ce docker-ce-cli containerd.io

启动并启用Docker服务

sudo systemctl start docker
sudo systemctl enable docker

验证Docker是否安装成功

docker version

国内服务器

sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL http://mirrors.cloud.aliyuncs.com/docker-ce/linux/debian/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc

Centos

国外服务器

卸载旧版本(如果有)

sudo yum remove docker \
                docker-client \
                docker-client-latest \
                docker-common \
                docker-latest \
                docker-latest-logrotate \
                docker-logrotate \
                docker-engine

安装必要的依赖

sudo yum install -y yum-utils device-mapper-persistent-data lvm2

添加Docker官方版本库:

sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

更新包索引,安装最新版本的Docker Engine、containerd 和 Docker Compose:

sudo yum update
sudo apt install -y docker-ce docker-ce-cli containerd.io

启动并启用Docker服务

sudo systemctl start docker
sudo systemctl enable docker

验证Docker是否安装成功

docker version

国内服务器

  1. 运行以下命令,下载docker-ce的yum源。

    sudo wget -O /etc/yum.repos.d/docker-ce.repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    
  2. 运行以下命令,安装Docker。

    sudo yum -y install docker-ce
    

开启Docker IPV6功能以及限制日志文件大小(可选)

cat > /etc/docker/daemon.json <<EOF
{
    "log-driver": "json-file",
    "log-opts": {
        "max-size": "20m",
        "max-file": "3"
    },
    "ipv6": true,
    "fixed-cidr-v6": "fd00:dead:beef:c0::/80",
    "experimental":true,
    "ip6tables":true
}
EOF

修改完重启Docker服务

systemctl restart docker

Docker-compose安装

Docker Compose是一个用来定义和运行复杂应用的Docker工具。一个使用Docker容器的应用,通常由多个容器组成。使用Docker Compose不再需要使用shell脚本来启动容器。
Compose 通过一个配置文件来管理多个Docker容器,在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器,非常适合组合使用多个容器进行开发的场景。

国外服务器

curl -SL https://github.com/docker/compose/releases/download/v2.28.1/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose

国内服务器

curl -SL -k https://mirror.ghproxy.com/https://github.com/docker/compose/releases/download/v2.28.1/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose

Docker-compose官方页面

https://docs.docker.com/compose/install/standalone/

验证Docker-compose是否安装成功

docker-compose version

若出现报错:docker-compose: Permission denied

这个是因为docker compose在当前用户组没有权限导致的

需要执行以下代码

sudo chmod +x /usr/local/bin/docker-compose

Docker 命令指南

  • Docker启动停止容器

    docker start [OPTIONS] CONTAINER [CONTAINER...] 启动已被停止的容器
    docker stop [OPTIONS] CONTAINER [CONTAINER...] 停止运行中的容器
    docker restart [OPTIONS] CONTAINER [CONTAINER...] 重启容器
    docker kill [OPTIONS] CONTAINER [CONTAINER...] 强制停止运行中的容器
    
  • Docker查看容器

    docker ps 查看正在运行的容器
    docker ps -a 查看所有容 包括停止的容器
    docker inspect  查看容器详细信息
    
  • Docker容器进程

    docker top [CONTAINER...]
    top支持 ps 命令参数,格式:docker top [OPTIONS] CONTAINER [ps OPTIONS]
    for i in  `docker ps |grep Up|awk '{print $1}'`;do echo \ &&docker top $i; done
    查看所有运行容器的进程信息
    
  • Docker容器日志

    docker logs [CONTAINER...] 查看容器日志
    -f  跟踪日志输出
    -t   显示时间戳
    --tail  仅列出最新N条容器日志
    docker logs -f -t --tail=20 redis
    
  • Docker执行容器SHELL

    docker exec -it demo1 /bin/sh 进入容器
    
  • Docker删除容器

    docker rm [CONTAINER...] 删除一个已经停止运行的容器
    docker rm -f [CONTAINER...] 强制删除正在运行的容器
    
  • Docker导入、导出容器

    docker export container > container.tar 将容器导出为镜像
    docker import container.tar xxx/demo 导入镜像
    
  • Docker镜像操作

    docker pull [CONTAINER...] 拉取镜像
    docker rmi [CONTAINER...] 删除镜像
    docker search [CONTAINER...] 删除镜像
    docker images 列出本地镜像
    docker commit -a="your name" -m="my container" [容器ID]  mycontainer:v版本号
    基于当前容器创建一个新的镜像:
    -a 提交的镜像作者
    -c 使用Dockerfile指令来创建镜像
    -m :提交时的说明文字
    -p :在commit时,将容器暂停
    

Docker-compose 命令指南

  • Docker-Compose 基本参数

    docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...]
    -f,–file FILE指定Compose模板文件,默认为docker-compose.yml,可以多次指定。 
    -p,–project-name NAME指定项目名称,默认将使用所在目录名称作为项目名。 
    -x-network-driver 使用Docker的可拔插网络后端特性(需要Docker 1.9+版本) 
    -x-network-driver DRIVER指定网络后端的驱动,默认为bridge(需要Docker 1.9+版本) 
    -verbose输出更多调试信息 
    -v,–version打印版本并退出
    
  • Docker-Compose 查看帮助

    docker-compose -h 查看帮助
    
  • Docker-Compose 查看日志

    docker-compose logs [options] [SERVICE...] 查看服务容器的输出。
    默认情况下,docker-compose将对不同的服务输出使用不同的颜色来区分。可以通过–no-color来关闭颜色。 
    docker-compose logs 查看服务容器的输出
    
  • Docker-Compose 构建容器

    docker-compose build [options] [--build-arg key=val...] [SERVICE...] 构建(重新构建)项目中的服务容器。
    –compress 通过gzip压缩构建上下环境 
    –force-rm 删除构建过程中的临时容器 
    –no-cache 构建镜像过程中不使用缓存 
    –pull 始终尝试通过拉取操作来获取更新版本的镜像 
    -m, –memory MEM为构建的容器设置内存大小 
    –build-arg key=val为服务设置build-time变量 服务容器一旦构建后,将会带上一个标记名。可以随时在项目目录下运行docker-compose build来重新构建服务
    
  • Docker-Compose 创建容器

    docker-compose create [options] [SERVICE...] 为服务创建容器。
    –force-recreate:重新创建容器,即使配置和镜像没有改变,不兼容–no-recreate参数 
    –no-recreate:如果容器已经存在,不需要重新创建,不兼容–force-recreate参数 
    –no-build:不创建镜像,即使缺失 
    –build:创建容器前,生成镜像
    
  • Docker-Compose 拉取镜像

    docker-compose pull [options] [SERVICE...] 拉取服务依赖的镜像。
    –ignore-pull-failures,忽略拉取镜像过程中的错误 
    –parallel,多个镜像同时拉取 
    –quiet,拉取镜像过程中不打印进度信息 
    docker-compose pull 拉取服务依赖的镜像
    
  • Docker-Compose 部署容器

    docker-compose up [options] [--scale SERVICE=NUM...] [SERVICE...]
    -d 在后台运行服务容器 
    –no-color 不使用颜色来区分不同的服务的控制输出 
    –no-deps 不启动服务所链接的容器 
    –force-recreate 强制重新创建容器,不能与–no-recreate同时使用 
    –no-recreate 如果容器已经存在,则不重新创建,不能与–force-recreate同时使用 
    –no-build 不自动构建缺失的服务镜像 
    –build 在启动容器前构建服务镜像 
    –abort-on-container-exit 停止所有容器,如果任何一个容器被停止,不能与-d同时使用 
    -t, –timeout TIMEOUT 停止容器时候的超时(默认为10秒) 
    –remove-orphans 删除服务中没有在compose文件中定义的容器 
    –scale SERVICE=NUM 设置服务运行容器的个数,将覆盖在compose中通过scale指定的参数 
    docker-compose up 启动所有服务 
    docker-compose up -d 在后台所有启动服务 
    -f 指定使用的Compose模板文件,默认为docker-compose.yml,可以多次指定。 
    例:docker-compose -f docker-compose.yml up -d
    
  • Docker-Compose 列出容器

    docker-compose ps [options] [SERVICE...] docker-compose ps 列出项目中目前的所有容器
    
  • Docker-Compose 重启容器

    docker-compose restart [options] [SERVICE...] 重启项目中的服务。
    -t, –timeout TIMEOUT,指定重启前停止容器的超时(默认为10秒) 
    docker-compose restart 重启项目中的服务
    
  • Docker-Compose 停止并删除包含所有网络(但不是卷)的容器

    docker-compose down [options] 停止和删除容器、网络、卷、镜像。
    –rmi type,删除镜像,类型必须是:all,删除compose文件中定义的所有镜像;local,删除镜像名为空的镜像 
    -v, –volumes,删除已经在compose文件中定义的和匿名的附在容器上的数据卷 
    –remove-orphans,删除服务中没有在compose中定义的容器 
    docker-compose down 停用移除所有容器以及网络相关
    
  • Docker-Compose 仅删除已停止的容器,而不是正在运行的容器

    docker-compose rm [options] [SERVICE...] 删除所有(停止状态的)服务容器。
    –f, –force,强制直接删除,包括非停止状态的容器 
    -v,删除容器所挂载的数据卷 
    `docker-compose rm` 删除所有(停止状态的)服务容器。
    推荐先执行docker-compose stop命令来停止容器。
    
  • Docker-Compose 启动容器

    docker-compose start [SERVICE...] docker-compose start 启动已经存在的服务容器。
    
  • Docker-Compose 停止容器

    docker-compose stop docker-compose stop [options] [SERVICE...] 
    -t, –timeout TIMEOUT 停止容器时候的超时(默认为10秒) 
    docker-compose stop 停止正在运行的容器,可以通过docker-compose start 再次启动
    
  • Docker-Compose 强制停止容器

    docker-compose kill [options] [SERVICE...] 通过发送SIGKILL信号来强制停止服务容器。  
    支持通过-s参数来指定发送的信号,例如通过如下指令发送SIGINT信号: 
    docker-compose kill -s SIGINT
    
  • Docker-Compose 指定服务执行命令

    docker-compose run [options] [-v VOLUME...] [-p PORT...] [-e KEY=VAL...] SERVICE [COMMAND] [ARGS...] 
    在指定服务上执行一个命令。 
    docker-compose run ubuntu ping www.baidu.com 在指定容器上执行一个ping命令。
    
  • Docker-Compose 指定服务容器数量

    docker-compose scale web=3 db=2 设置指定服务运行的容器个数。通过service=num的参数来设置数量
    
  • Docker-Compose 暂停容器

    docker-compose pause [SERVICE...] 暂停一个服务容器
    
  • Docker-Compose 恢复暂停中的容器

    docker-compose unpause [SERVICE...] 恢复处于暂停状态中的服务。
    
  • Docker-Compose 验证yaml文件配置

    docker-compose config [options] 验证并查看compose文件配置。
    –resolve-image-digests 将镜像标签标记为摘要 
    -q, –quiet 只验证配置,不输出。 当配置正确时,不输出任何内容,当文件配置错误,输出错误信息 
    –services 打印服务名,一行一个 
    –volumes 打印数据卷名,一行一个
    
  • Docker-Compose 执行容器SHELL

    docker-compose exec [options] SERVICE COMMAND [ARGS...]
    -d 分离模式,后台运行命令。 
    –privileged 获取特权。 
    –user USER 指定运行的用户。 
    -T 禁用分配TTY,默认docker-compose exec分配TTY。 
    –index=index,当一个服务拥有多个容器时,可通过该参数登陆到该服务下的任何服务
    例如:docker-compose exec –index=1 web /bin/bash ,web服务中包含多个容器
    
  • Docker-Compose 显示容器端口

    docker-compose port [options] SERVICE PRIVATE_PORT 显示某个容器端口所映射的公共端口。 
    –protocol=proto,指定端口协议,TCP(默认值)或者UDP –index=index,如果同一服务存在多个容器,指定命令对象容器的序号(默认为1)
    
  • Docker-Compose 推送镜像

    docker-compose push [options] [SERVICE...] 推送服务[SERVICE...]的镜像。
    –ignore-push-failures 忽略推送镜像过程中的错误
    
  • Docker-Compose 显示容器进程状况

    docker-compose stop [options] [SERVICE...] 显示各个容器运行的进程情况。