zoukankan      html  css  js  c++  java
  • 实战---在Portainer中编排docker-compose.yml文件

    选择要部署容器的主机上,不用事先安装配置docker-compose

    官方示例文档地址,2.0版本的:https://docs.docker.com/compose/compose-file/compose-file-v2/




    使用这个功能创建的docker容器,使用的容器卷是在:/var/lib/docker/volumes路径下

    docker-compose.yml使用的镜像,优先查找本地,若本地有,则使用,没有则从Docker Hub上拉取,所以若想使用私有仓库的镜像,需要提前从私有仓库中把镜像给拉取到本地

    如上这个只是最简单的,通过在Portainer上的stack功能编写docker-compose.yml内容,使用自定义的eureka镜像,启动一个容器。

    使用docker命令查看

    完整操作

    先从私有仓库把镜像拉取到本地


    编写docker-compose.yml文件

    这里只给eureka服务映射端口

    • 默认网络使用的是bridge(桥接)
    • 容器的日志驱动是json-file
    version: "2.0"
    
    services:
        hkd-eureka:
            image: idocker.io/hkd-eureka:0.1
            ports:
                - "8761:8761"
            volumes:
                - /tmp
                - /opt/hkd-cloud/hkd-eureka/logs
        hkd-config:
            image: idocker.io/hkd-config:0.1
            volumes:
                - /tmp
                - /opt/hkd-cloud/hkd-config/logs
        hkd-gateway:
            image: idocker.io/hkd-gateway:0.1
            volumes:
                - /tmp
                - /opt/hkd-cloud/hkd-gateway/logs
        hkd-auth:
            image: idocker.io/hkd-auth:0.1
            volumes:
                - /tmp
                - /opt/hkd-cloud/hkd-auth/logs
        hkd-user:
            image: idocker.io/hkd-user:0.1
            volumes:
                - /tmp
                - /opt/hkd-cloud/hkd-user/logs       
        hkd-portal:
            image: idocker.io/hkd-portal:0.1
            volumes:
                - /tmp
                - /opt/hkd-cloud/hkd-portal/logs       
        hkd-custom:
            image: idocker.io/hkd-custom:0.1
            volumes:
                - /tmp
                - /opt/hkd-cloud/hkd-custom/logs 
        hkd-cash:
            image: idocker.io/hkd-cash:0.1
            volumes:
                - /tmp
                - /opt/hkd-cloud/hkd-cash/logs             
    




    问题

    1.有些服务是需要先启动的,也就是说有些服务是依赖其他服务的,需要做进一步的调整
    想上述那样的,只有eureka和config两个启动了,其余的启动后失败了,因为他们需要往eureka注册中心注册,但是eureka注册中心正在启动中,导致没法注册

    目前采取的办法是,等eureka启动后可以访问了,再把启动失败的服务手动再启动一次

    暂时没想到用啥办法解决这个依赖关系

    2.没有创建使用额外的网络空间,不过这个可以等服务都启动好了,再手动把服务添加到自定义的网络空间

    3.假若镜像更新了,服务如何更新

  • 相关阅读:
    暑假周进度总结(一)
    第十七周进度总结
    大二下学期软件工程概论总结
    第十六周进度总结
    程序员修炼之道读书笔记(三)
    程序员修炼之道读书笔记(二)
    《程序员修炼之道》读书笔记(一)
    第十五周进度总结
    python之路--day6---文件处理
    python之路--day6--字符编码
  • 原文地址:https://www.cnblogs.com/sanduzxcvbnm/p/13186532.html
Copyright © 2011-2022 走看看