Docker

作者: tzktzk1 | 来源:发表于2023-10-29 00:18 被阅读0次

    Docker容器端口号:(记录一下,防止冲突!)

    禅道 8089
    MySQL 3306
    Tomcat 8080
    Nginx 8000
    Redis 6379
    GitLab 80
    Jenkins 8090
    SonarQube 9000
    postgres/db 5432
    InfluxDB 8086
    Grafana 3000
    node-exporter 9100
    Prometheus 9090
    fireshare 2480
    handbrake 5800


    一、安装Docker

    apt安装
        sudo apt update
        sudo apt install docker.io
        sudo systemctl status docker
    
    配置镜像加速
        vim /etc/docker/daemon.json
    
        {
          "registry-mirrors": ["https://registry.docker-cn.com","https://hmdsd139.mirror.aliyuncs.com","https://docker.mirrors.ustc.edu.cn"],
          "log-driver":"json-file",
          "log-opts": {"max-size":"500m", "max-file":"3","compress": "true"}
        }
    重启docker守护进程
        systemctl daemon-reload
        systemctl restart docker
    
    查看docker版本,验证是否验证成功
        docker -v
    

    二、docker架构

    1.镜像(Image) : Docker镜像(lmage),就相当于是一个root文件系统。
                比如官方镜像ubuntu:16.04就包含了完整的一套Ubuntu16.04最小系统的root文件系统。
    2.容器(Container) :镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和对象一样,
                镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
    3.仓库(Repository) :仓库可看成一个代码控制中心,用来保存镜像。
    

    三、配置镜像加速器

    默认情况下,从docker hub (https://hub.docker.com/) 上下载docker镜像太慢。一般都会配置镜像加速器:
        USTC:中科大镜像加速器(https://docker.mirrors.ustc.edu.cn)
        阿里云:https://asmpc6kh.mirror.aliyuncs.com(去阿里云申请)
    
    1.安装/升级Docker客户端
        推荐安装1.10.0以上版本的Docker客户端,参考文档docker-ce
    2.配置镜像加速器
        针对Docker客户端版本大于1.10.0的用户
        您可以通过修改daemon配置文件/etc/docker/daemon.json来使用加速器
    
        sudo mkdir -p /etc/docker
        sudo tee /etc/docker/daemon.json <<-'EOF'
        {
            "registry-mirrors”: ["https://asmpc6kh.mirror.aliyuncs.com”]
        }
        EOF
        sudo systemctl daemon-reload
        sudo systemctl restart docker
    
        安装后可以查看本地的镜像地址:
            cat /etc/docker/daemon.json
    

    四、Docker服务相关命令

    启动docker服务      systemctl start docker
    停止docker服务      systemctl stop docker
    重启docker服务      systemctl restart docker
    查看docker服务状态    systemctl status docker
    开机启动docker服务    systemctl enable docker     (以后每次一开机就开启docker了)
    

    五、Docker镜像相关命令

    Docker命令大全: http://www.runoob.com/docker/docker-command-manual.html
    
    查看本地镜像  docker images
    搜索镜像    docker search redis     (搜索 redis 镜像)
    拉取镜像    docker pull redis:3.2   (拉取3.2版本的redis,不写版本号默认拉取最新的)
    删除镜像    docker rmi le25a81a5a0b (IMAGE ID 方式指定要删除的镜像)
    删除镜像    docker rmi redis:latest (REPOSITORY:TAG 方式指定要删除的镜像)
    
    查看所有镜像列表    docker images -q (会列出所有镜像的IMAGE ID)
    删除容器内所有镜像   docker rmi 'docker images -q' (谨慎使用!)
    
    删除重名镜像(构建了新镜像 之前重名的老镜像的名字会显示为<none> 即重复镜像)
        docker image prune -f   # 删除重名的 <none> 镜像
        docker images   # 查看是否已经删除
    

    六、Docker容器相关命令

    参数说明:
        -i:保持容器运行。通常与-t同时使用。加入it这两个参数后,容器创建后自动进入容器中,退出容器后,容器自动关闭。
        -t:为容器重新分配一个伪输入终端,通常与-i同时使用。
        -d:以守护(后台)模式运行容器。创建一个容器在后台运行,需要使用docker exec进入容器。退出后,容器不会关闭。
        -it创建的容器一般称为交互式容器,
        -id创建的容器一般称为守护式容器。
        --name:为创建的容器命名。
    
    
    查看容器(正在运行的)     docker ps
    查看容器(所有的)               docker ps -a
    
    创建容器(创建后立即进入容器)     docker run -it --name=c1 centos:7 /bin/bash     
                                                (/bin/bash 进入容器的初始化指令,可以不写)
    创建容器(退出后容器自动关闭)     docker run -it --name c2 centos:7 /bin/bash     
                                                (不写/bin/bash 进入容器的初始化指令也是这个)
    创建容器(创建后不会立即进入容器)   docker run -id --name c3 centos:7
    创建容器(退出后容器不会自动关闭)   docker run -id --name c4 centos:7
    
    进入容器    docker exec -it c3 /bin/bash
    退出容器    exit        (退出容器,容器不会关闭)
    启动容器    docker start c2
    停止容器    docker stop c2
    
    删除容器    docker rm c1            (c1 容器名称方式指定要删除的容器)
    删除容器    docker rm 49d89942bda   (CONTAINER ID 方式指定要删除的容器)
                        (删除容器:如果容器是运行状态则删除失败,需要停止容器才能删除)
    
    查看所有容器的ID   docker ps -aq
    删除所有容器      docker rm 'docker ps -aq'   (正在运行中的容器不能被删除)
    
    查看容器信息  docker inspect c2   (c2 容器名称方式指定要查看的容器)
    
    容器状态STATUS      Up 正在运行的容器   Exited 退出状态的容器
    
    开启容器自动启动    docker update --restart always <container_id>
    关闭容器自动启动    docker update --restart=no <container_id>
    

    七、数据卷概念及作用

    数据卷概念及作用
        思考:
            Docker容器删除后,在容器中产生的数据也会随之销毁吗? --》 不会,数据在宿主机内有(持久化)
            Docker容器和外部机器可以直接交换文件吗? --》不能,但是可以通过数据卷实现
            容器之间想要进行数据交互? --》 一个数据卷可以同时绑定多个容器
            
        数据卷:
            数据卷是宿主机中的一个目录或文件
            当容器目录和数据卷目录绑定后,对方的修改会立即同步
            一个数据卷可以被多个容器同时挂载
            一个容器也可以被挂载多个数据卷
    
        数据卷作用:
            容器数据持久化
            外部机器和容器间接通信
            容器之间数据交换
    
    配置数据卷
        创建启动容器时,使用→-v参数设置数据卷
            docker run ...-v宿主机目录(文件):容器内目录(文件)...  (宿主机目录 称为数据卷)
            例如:docker run -it --name=cl -v /home/centos7/data:/root/data_container centos:7 /bin/bash
                        (/bin/bash可以省略,数据卷目录 /home/centos7/data  和 容器内目录/root/data_container 内部的数据会保持一致,即映射关系一一对应)
                docker run -it --name=c1 -v /home/centos7/data:/root/data_container centos:7    (宿主机内可以用~,容器内不行)
    
        注意事项:
            1.目录必须是绝对路径
            2.如果目录不存在,会自动创建
            3.可以挂载多个数据卷
    
    配置 数据卷容器
        1.创建启动c3数据卷容器,使用-v参数设置数据卷
            docker run -it --name=c3 -v /volume centos:7 /bin/bash (Docker会自动为容器分配一个目录当做数据卷)
        
        2.创建启动c1 c2容器,使用--volumes-from参数设置数据卷
            docker run -it --name=c1 --volumes-from c3 centos:7 /bin/bash
            docker run -it --name=e2 --volumes-from c3 centos:7 /bin/bash
    
    数据卷小结
        1.数据卷概念
            宿主机的一个目录或文件
        2.数据卷作用
            容器数据持久化
            客户端和容器数据交换
            容器间数据交换
        3.数据卷容器
            创建一个容器,挂载一个目录,让其他容器继承自该容器(--volumes-from)。
            通过简单方式实现数据卷配置
    

    相关文章

      网友评论

          本文标题:Docker

          本文链接:https://www.haomeiwen.com/subject/jenmidtx.html