zoukankan      html  css  js  c++  java
  • Docker的安装和使用

    Docker架构

    Docker安装

    1. 去官网下载repo
    2. 更改为国内镜像baseurl=https://download.docker.com/linux/
    3. 有可能需要安装依赖包 yum install -y http://mirror.centos.org/centos/7/extras/x86_64/Packages/container-selinux-2.66-1.el7.noarch.rpm
    4.  yum install docker-ce
    

    Docker配置

    1. /etc/docker/daemon.json
        {
            "registry-mirrors": ["https://registry.docker-cn.com"]
        }
        Docker镜像加速
    2. 启动
    # systemctl start docker
    3. 查看 
    # docker help
    # docker info
    4. Docker常用
    # docker image --help
    # docker search nginx  (https://hub.docker.com/)
        nginx 顶级仓库
        jwilder/nginx-proxy 私有仓库
    # docker image pull nginx:1.14-alpine (下载alpine image, alpine是一个体积特别小的Nginx版本,没有任何调试工具,在实际工作中,根据自已的需要生成image)
    # docker pull quay.io/coreos/flannel:v0.10.0-amd64 (到quay.io网站下载镜像,这个网站是常用的第三方镜像)
    # docker image pull busybox:latest
    # docker image ls (显示下载的image)
    # docker image ls --no-trunc (显示详细信息)
    # docker container --help
    # docker container ls (显示容器)
    # docker container ps (显示容器)
    # docker container run --help
    # docker network list (网络查询)
        docker0: 默认是NAT的网桥
    # docker run --name b1 -it busybox:latest (以b1的名字运行image busybox,并且是交互式界面)
        / # ls (进入到busybox容器的shell)
        mkdir /data/html -p
        vim /data/html/index.html (在容器里生成主页)
        httpd -f -h /data/html (启动b1容器里和httpd)
    # docker inspect b1 (在host上查看b1容器的IP)
    # curl 172.17.0.2 (访问b1容器的网页)
        在容器里exit,退出容器
    # docker ps -a (显示所有容器,运行的和停止的)
    # docker container start -i -a b1 (启动容器)
    #  docker kill b1 (强制停止容器)
    # docker rm b1 (永久删除容器b1)
    # docker run --name web1 -d nginx:1.14-alpine (启动nginx容器,如果本地没有下载nginx image,只要repo指定为hub.docker.com, 会自动下载,在容器中的进程不能运行在后台,因为是唯一进程,是支撑一个容器的骨架)
    # docker run --name kdvsor1 -d redis:4-alpine (运行redis容器)
    # docker exec -it kdvsor1 /bin/sh 
        # redis-cli
    # docker logs web1 (在host中查看web1容器的日志)
    

    Docker event state

    Docker image

    Docker镜像含有启动容器所需要的文件系统及其内容,因此,其主要作用创建并启动docker容器。
    

    Docker分层机制

    1. bootfs:用于系统引导的文件系统,包括bootloader和kernel,容器启动完成后会被卸载以节约内存资源。
    2. rootfs:位于bootfs之上,表现为docker容器的根文件系统。rootfs由内核挂载为只读模式,而后通过联合挂载技术额外挂载一个可写层;
                    位于下层的镜像称为父镜像,最底层的称为基础镜像
                    最上层为可读写层,基下层均为只读层
    

    Docker Registry

    启动容器时,Docker Daemon会试图从本地获取相关的镜像,本地镜像不存在时,其将从Registry中下载该镜像并保存到本地
    

    分类

    Registry用于保存docker镜像,包括镜像的层次结构和元数据:
    1. Sponsor Registry:第三方的registry,供客户和Docker社区使用
    2. Mirror Registry:第三方的registry,只让客户使用
    3. Vendor Registry:由发布Docker镜像的供应商提供的registry
    4. Private Registry:通过设有防火墙和额外的安全层的私有实体提供的registry
    注意:每个仓库可以包含多个Tag,但是每一个Tag只能属于一个仓库
    

    Docker生产流程

    Docker Registry中的镜像通常由研发人员制作,而后推送至公共或私有Registry上保存,供其他人员使用,然后部署到生产环境
    


    1. Dockerfile
    2. 基于容器制作
    3. Docker Hub automated builds

    基于容器制作镜像的实例

    #  docker run --name b1 -it busybox
        # / # mkdir -p /data/html
        # / # vi /data/html//index.html
    # docker commit -p b1 (制作image,此镜像还是以bysybox的sh启动)
    # docker tag 542b72efce7e linuxdevops/httpd:v1.0-1 (给镜像标签)
    # docker tag linuxdevops/httpd:v1.0-1 linuxdevops/httpd:latest (加另一个标签)
    # docker run --name t1  -it linuxdevops/httpd:v1.0-1 (启动做的镜像)
        # / # ls /data/html/index.html 
    #  docker commit -a "evanliang" -c 'CMD ["/bin/httpd","-f","-h","/data/html"]' -p b1 linuxdevops/httpd:v1.0-2
    #  docker run --name t2  -it linuxdevops/httpd:v1.0-2
    # curl 172.17.0.4 (新做的linuxdevops/httpd:v1.0-2能直接启动httpd)
    4. 在dockerhub上创建账户
        # docker tag f43e5c3f987c liangjindong/httpd (tag名字一定要和dockerhub上创建的REPOSITORY名字一致)
        # docker login -u liangjindong (登录dockerhub)
            Password:
            WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
            Configure a credential helper to remove this warning. See
            https://docs.docker.com/engine/reference/commandline/login/#credentials-store
            Login Succeeded
        # docker push liangjindong/httpd (如果不带tag,所有image孝会上传到dockerhub)
        # 在dockerhub上,可以看到
    


    # 同时,可以用国内阿里云的镜像服务dev.aliyun.com
    # 配置镜像加速:
    针对Docker客户端版本大于 1.10.0 的用户
    您可以通过修改daemon配置文件/etc/docker/daemon.json来使用加速器
    sudo mkdir -p /etc/docker
    sudo tee /etc/docker/daemon.json <<-'EOF'
    {
    "registry-mirrors": ["https://sah48iqf.mirror.aliyuncs.com"]
    }
    EOF
    sudo systemctl daemon-reload
    sudo systemctl restart docker
    同时,可以在阿里云上创建镜像仓库,上传:
    # sudo docker tag 0dfafbbae68a registry.cn-beijing.aliyuncs.com/liangjindong/httpd:latest (用阿里云指定的tag)
    # sudo docker login --username=liangjindong registry.cn-beijing.aliyuncs.com (登录)
    # sudo docker push registry.cn-beijing.aliyuncs.com/liangjindong/httpd (上传镜像)
    在阿里云上检查,成功

    5. docker镜像打包分发
    # docker save -o myimages.gz liangjindong/httpd:latest liangjindong/httpd:v1.0
    # docker load -i myimages.gz 把myimages.gz copy到另外一台docker服务器
    镜像打包分发需要提前把image本地准备好,否则运行docker run时还会去dockerhub默认的Registry下载。

    Docker Hub

    集中存储各种Docker镜像
    Github他Docker hub来实现镜像的Automated Builds
    

  • 相关阅读:
    How to implement long running flows, sagas, business processes or similar
    What are long running processes?
    The Microservices Workflow Automation Cheat Sheet
    cget cmake 包管理工具
    buckaroo 试用
    buckaroo 去中心化的c++包管理工具
    What's New In Zeebe: Scaling Zeebe, New Client APIs, Faster Requests, Timestamps, NodeJS Client, and Default Topic is Back!
    Benchmarking Zeebe: An Intro to How Zeebe Scales Horizontally and How We Measure It
    Architecture options to run a workflow engine
    camunda 开源的bpm系统
  • 原文地址:https://www.cnblogs.com/liangjindong/p/9398556.html
Copyright © 2011-2022 走看看