CI/CD docker compose 部署 humpback - single mode

news2024/9/24 15:29:21

最近想搭一搭个人服务器,其中有很多东西都是通过 docker 来管理,每次都手动输入命令比较麻烦,需要一个轻量级的容器管理工具来直观轻松的管理容器和镜像。于是便相中了 humpback。

Humpback

humpback 相关的详细介绍请自助传送

架构

在这里插入图片描述

主要组件

  • humpback website
    提供一个可视化界面,用户可以进行权限管理,容器管理,镜像管理,客户端节点管理(单机/集群),镜像地址
  • humpback agent
    在每个目标节点(需要管理容器/镜像的机器)上的一个客户端程序,用于接收来自 humpback website/humpback center 的命令并执行,需要管理容器或者镜像的机器都需要安装这个,镜像地址
  • humpback center
    集群中心(集群节点的发现和管理),主要是用于批量操作(创建,删除,修改,迁移)容器/镜像,镜像地址

通过 docker compose 部署

前置条件

机器都已经安装上 docker,docker compose

部署 Website

docker-compose.yml 如下:
其中的部分配置如 映射的到本机的目录列表/端口都可以改成自己想要的

version: "3.9"

services:
  humpback-web:
    image: humpbacks/humpback-web:1.3.0
    container_name: humpback-web
    volumes:
      - ./dbfiles:/humpback-web/dbFiles
    ports:
      - 8001:80
    restart: unless-stopped                                                                                                                                             

执行 docker compose up -d,在容器运行起来之后,我们访问绑定到本地的 8001 端口:
就会看到如下界面,输入默认的管理员账户和密码后即可进入系统

  • 账户:admin
  • 密码:123456
    在这里插入图片描述
    建议登陆之后就修改一次密码,入口在 Account >> Change Password,
    进入系统后如果需要新加用户可以通过 Manage >> Users >> Add User 完成,如下
    在这里插入图片描述

部署 Agent

docker-compose.yml 如下
其中的部分配置如 映射的到本机的目录列表都可以改成自己想要的

version: "3.9"
services:
  humpback-agent:
    image: humpbacks/humpback-agent:1.3.2
    container_name: humpback-agent
    volumes:
      - /var/run:/var/run/:rw
      - ./compose_files:/opt/app/humpback-agent/compose_files/
    environment:
      - DOCKER_CLUSTER_ENABLED=false
      - DOCKER_API_VERSION=v1.21
    restart: unless-stopped
    # 因为需要和宿主机共用网络,所以这里需要使用 host 模式
    network_mode: host

执行 docker compose up -d,在容器运行起来之后,我们可以继续下一步

在 Website 中添加对应节点

这一步之所以在部署 Agent 之后,是因为能够被扫描到的机器必须部署 Agent。
进入我们先前部署的 Website,
按照 Manage >> Groups >> Add Group 路径操作,如下
在这里插入图片描述
点击 Add Group 后,你会看到下面的界面:
在这里插入图片描述

  • Name: Group 的名称,这里可以按照你具体的分组名称来
  • Description:描述一下这个组是干什么的
  • Open to public:是否公开,如果这个 Enable,则即使不是这个 Group 的 Owner 也可以看到
  • Cluster Mode:是集群模式还是单机模式
  • Contact Info:联系信息,一般填写维护人员邮箱即可
  • Owners:在这里的都可以修改这个 Group(管理员账号即使不在也可以编辑)
  • Servers:Group 中的节点列表,可以增加对应的节点(也就是我们前面部署 Agent 的对应机器),
    1. name 可以随意填写,能够区分即可
    2. IP 就填写对应的机器内网 IP 即可

我这里填写完成后的如下:
在这里插入图片描述
点击 Save 保存成功后,我们去到 Group >> prod >> prod-1,即可看到对应机器上的容器,点击 Docker Images 即可查看/管理对应机器的镜像
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/32225.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【无线传感器】WSN 查找两个节点之间的最短路径并发送数据(Matlab代码实现)

👨‍🎓个人主页:研学社的博客 💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜…

前后端分离项目,vue+uni-app+php+mysql教室预约系统设计与实现(H5移动项目)

功能模块 【后台管理功能模块】 系统设置:设置关于我们、联系我们、加入我们、法律声明 广告管理:设置小程序首页轮播图广告和链接 留言列表:所有用户留言信息列表,支持删除 会员列表:查看所有注册会员信息&#xff0c…

【力扣】787. K 站中转内最便宜的航班加权——有向图最短路径

前言 我感觉这题比较有代表性,所以记录一下,这题是加权有向图中求最短路径的问题。 题目 787. K 站中转内最便宜的航班 动态规划 假设有一条路径是[src, i, ..., j, dst],解法一子问题的定义是[src, i, ..., j],解法二子问题…

面经汇总--校招--北京顺丰同城

文章目录🔥1.一面🔥2.二面🔥3. 三面🔥4. 结果🔥1.一面 你对Spring aop的理解 面向切面编程,可以对某个方法前后加入自己想执行的方法函数。底层是动态代理,默认jdk动态代理,没有实现…

Redis 通用命令(keys,help,mset,exists,expire,ttl,tab补全)

目录 1.help【command】 2.tab自动补全 3. KEYS pattern(模板)(不建议再生产环境上使用) 4.del 删除指定的key,value也会删除(也可以批量删除) 5.MSET(批量插入键值对&#xf…

【C语言】反序加密(非文件)

《算法集训传送门》 👉引言 铭记于心🎉✨🎉我唯一知道的,便是我一无所知🎉✨🎉💖 ❄️我们的算法之路❄️💖众所周知,作为一名合格的程序员,算法 能力 是不可…

Python OpenCV实现鼠标绘制矩形框和多边形

Python OpenCV实现鼠标绘制矩形框和多边形 目录 Python OpenCV实现鼠标绘制矩形框和多边形 1. OpenCV鼠标事件操作说明 (1)setMouseCallback函数说明 (2)回调函数onMouse说明 (3)event 具体说明&…

Flutter高仿微信-第24篇-隐私政策

Flutter高仿微信系列共59篇,从Flutter客户端、Kotlin客户端、Web服务器、数据库表结构、Xmpp即时通讯服务器、视频通话服务器、腾讯云服务器全面讲解。 详情请查看 效果图: 实现代码: /*** 显示服务条款、隐私政策对话框*/ static void show…

如何修复老照片?这三个方法建议收藏

当你在图书馆查阅一些资料时,会发现里面有许多的老照片,通过这些老照片我们能大概了解到那个时期的建筑特色、人们的穿衣特色等等。但由于那个时候的照片只有黑白,再加上时间悠久,老照片已经过于模糊了,影响到我们进行…

线性回归的梯度下降法——机器学习

一、实验内容 理解单变量线性回归问题;理解最小二乘法;理解并掌握梯度下降法的数学原理;利用python对梯度下降法进行代码实现; 二、实验过程 1、算法思想 梯度下降法是一阶最优化算法。 要使用梯度下降法找到一个函数的局部极小值…

Docker学习(3)—— 将容器转化为新的镜像,并将新镜像发布到阿里云公共仓库或私有仓库

一. 将容器转化为镜像 使用docker pull命令从远程仓库下载的镜像为base镜像,只具有最小的内核。我们可以在base镜像上安装其他工具,将其生成为一个新的镜像。相当于可以在原始的基础镜像上一层一层添加。 例如:下载一个centos的镜像&#x…

kibana 操作elasticsearch索引

前言 使用kibana可以很方便的对es进行各种操作,比如创建索引,删除索引,查询文档等,本篇先演示如何基于kibana 对es的索引进行常见的操作。 环境准备 请提前安装好es和kibana,可以参考 docker搭建es kibana操作es索引…

进销存商城前几名的运营方法|三招提高微信商城用户黏性

你有没有感到奇怪,明明是差不多装修,为什么有的微信商城只能和用户做成“单次消费行为”,但有的微信商城能让用户在他家复购一次两次三次? 这其实都跟用户忠诚度有关。进入存量时代后,维护好老用户就成为门店经营不可…

如何配置 ESXi 主机管理网络?

配置 ESXi 主机管理网络 VMware ESXi管理网络提供ESXi主机和客户端之间的通信。在服务器上安装 ESXi 虚拟机监控程序后,将通过动态主机配置协议(DHCP)获得ESXi管理IP。你可能需要配置ESXi主机的静态管理IP和主机名。按照以下指南配置ESXi管理网络,以便你可以通过域名而不是…

Apache ShenYu ModifyResponse插件使用

Apache ShenYu网关使用手册1 介绍1.1 概念1.2 特性1.3 架构图2 运行2.1 运行先决条件2.1 本地运行3 插件使用3.1 ModifyResponse插件3.1.1 插件名称3.1.2 适用场景3.1.3 插件功能3.1.4 插件代码3.1.5 如何使用插件3.1.5.1 插件使用流程图3.1.5.2 接入SpringBoot应用改造3.1.5.3…

kali没有wlan0

kali没有wlan0解决方案 第一步ifconfig发现没有wlan0 使用wget下载无线设备 命令如下: wget https://mirror2.openwrt.org/sources/compat-wireless-2010-06-28.tar.bz2 3. 解压刚才下载的压缩包: tar -xjvf compat-wireless-2010-06-28.tar.bz2 进…

【Leetcode】拿捏链表(三)——CM11 链表分割(牛客)、OR36 链表的回文结构(牛客)

作者:一个喜欢猫咪的的程序员 专栏:《Leetcode》 喜欢的话:世间因为少年的挺身而出,而更加瑰丽。 ——《人民日报》 目录 CM11 链表分割 OR36 链表的回文结构 CM11 链表分割 链表分割_牛客题霸…

【Linux】线程概念与线程控制

认识线程 线程是一个执行流(运行代码,处理数据) ​ 1.操作系统使用pcb来描述一个程序的运行-------pcb就是进程 ​ 2.linux下通过pcb模拟实现线程,因此linux下的线程是一个轻量级进程 ​ 3.这个轻量级进程因为公用大部分进程资…

Python编程 字典创建map与Zip

作者简介:一名在校计算机学生、每天分享Python的学习经验、和学习笔记。 座右铭:低头赶路,敬事如仪 个人主页:网络豆的主页​​​​​​ 目录 前言 字典(dict) 字典创建(拓展) 拓展: 前言 本章将会扩展Python…

IP 地址详解(IPv4、IPv6)

文章目录1 概述2 IP 地址结构2.1 IPv4 地址结构2.2 IPv6 地址结构3 IP 地址管理3.1 地址分类策略:A、B、C、D、E 类3.2 无分类策略:CIDR3.3 地址分类策略 和 无分类策略 相结合1 概述 IP地址:Internet Protocol Address(互联网协…