docker集群软件之fleet安装

简介:

前几天给大家介绍了docker的集群存储软件etcd的安装(地址http://dl528888.blog.51cto.com/2382721/1623746),今天就再给大家介绍集群的控制软件fleet安装。

fleet的介绍,info里复制的

1
fleet 是一个通过 Systemd对CoreOS 集群中进行控制和管理的工具。fleet 与 Systemd 之间通过 D-Bus API 进行交互,每个 fleet agent 之间通过 etcd 服务来注册和同步数据。fleet 提供的功能非常丰富,包括查看集群中服务器的状态、启动或终止 Docker container、读取日志内容等。

简单来说,我搭建docker集群,使用etcd作为信息存储,fleet连接与控制所有节点服务器的systemd,然后通过想用的命令创建或者消灭节点里docker容器。

下面是我自己画的一个fleet的架构图

wKioL1UTXgmTDweuAAHFbUQTfA4044.jpgfleet与etcd都是coreos开发,内置到coreos系统里,但我后来在弄docker集群的时候,在centos7系统里部署与使用这2个软件,使用起来很方便。

下面是安装

1、安装go

1
yum  install  go -y

2、下载fleet

1
2
cd  /tmp/
git clone https: //github .com /coreos/fleet .git

3、安装fleet

1
2
cd  fleet
. /build

4、负责可执行程序

1
2
cp  bin /fleetd  /usr/local/bin/
cp  bin /fleetctl  /usr/local/bin/

5、配置fleet

在某一个节点里编辑与配置/etc/fleet/fleet.conf

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
09:15:02  # cat /etc/fleet/fleet.conf
# This config file is INI-formatted
 
# Lower the logging threshold. Acceptable values are 0, 1, and 2. A higher
# value corresponds to a lower logging threshold.
# verbosity=0
 
# Provide a custom set of etcd endpoints. The default value is determined
# by the underlying go-etcd library.
#etcd_servers=["http://192.168.65.2:4001"]
 
# Amount of time in seconds to allow a single etcd request before considering it failed.
# etcd_request_timeout=1.0
 
# Provide TLS configuration when SSL certificate authentication is enabled in etcd endpoints
# etcd_cafile=/path/to/CAfile
# etcd_keyfile=/path/to/keyfile
# etcd_certfile=/path/to/certfile
 
# IP address that should be published with any socket information. By default,
# no IP address is published.
public_ip= "10.10.27.221"
 
# Comma-delimited key/value pairs that are published to the fleet registry.
# This data can be referenced in unit files to affect scheduling descisions.
# An example could look like: metadata="region=us-west,az=us-west-1"
metadata= "region=cn-core-02"
 
# An Agent will be considered dead if it exceeds this amount of time to
# communicate with the Registry. The agent will attempt a heartbeat at half
# of this value.
# agent_ttl="30s"
 
# Interval at which the engine should reconcile the cluster schedule in etcd.
# engine_reconcile_interval=2

基本只需要修改public_ip与metadata

6、配置启动脚本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
09:16:14  # cat /usr/lib/systemd/system/fleet.service;
[Unit]
Description=Fleet
Documentation=https: //github .com /coreos/fleet
 
[Service]
Type=simple
EnvironmentFile=- /etc/fleet/fleet .conf
ExecStart= /usr/local/bin/fleetd  -config  /etc/fleet/fleet .conf
ExecStop= /usr/bin/killall  -9 fleetd
Restart=on-failure
RestartSec=5s
[Install]
WantedBy=multi-user.target

7、启动fleet

1
systemctl start fleet

8、查看集群状态

我目前已经创建好了集群,并且有了4个节点

1
2
3
4
5
6
09:15:06  # fleetctl list-machines -l
MACHINE                 IP      METADATA
1a1b60030aaef2f1d8d0468f0000002d    10.10.21.199    region=cn-core-01
6d832c54a40fe752dba35d0b00000024    10.10.27.221    region=cn-core-02
893b160e363b4ec7834719a7f06e67cf    10.10.17.3  region=cn-core-04
cce83e1dd55b46f6a543b49a6b59586a    10.10.17.3  region=cn-core-03

其中machine是一个主机唯一的标示,ip是之前配置fleet.conf里的public_ip项,metadata是fleet.conf里metadata的。

目前已经建立好集群,请直接安装fleet前一定要先在每个节点安装etcd,否则fleet无法工作的,之后给大家整体介绍一个docker集群的真实案例。






 本文转自 reinxu 51CTO博客,原文链接:http://blog.51cto.com/dl528888/1624481,如需转载请自行联系原作者

相关文章
|
8月前
|
关系型数据库 应用服务中间件 nginx
Docker一键安装中间件(RocketMq、Nginx、MySql、Minio、Jenkins、Redis)
本系列脚本提供RocketMQ、Nginx、MySQL、MinIO、Jenkins和Redis的Docker一键安装与配置方案,适用于快速部署微服务基础环境。
|
6月前
|
关系型数据库 数据库 PostgreSQL
docker 安装 Postgres 17.6
本文介绍如何通过Docker安装和配置PostgreSQL 17.6。内容包括拉取镜像、导出配置文件、运行容器并挂载数据与配置文件目录,以及进入容器使用psql操作数据库的完整步骤,便于持久化管理和自定义配置。
814 3
docker 安装 Postgres 17.6
|
5月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
671 6
|
5月前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
501 2
|
10月前
|
Prometheus 监控 Cloud Native
除了Prometheus,还有哪些工具可以监控Docker Swarm集群的资源使用情况?
除了Prometheus,还有哪些工具可以监控Docker Swarm集群的资源使用情况?
796 79
|
9月前
|
存储 NoSQL MongoDB
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
1039 4
|
7月前
|
安全 持续交付 Docker
Docker:重塑现代软件交付的容器引擎
Docker:重塑现代软件交付的容器引擎
|
8月前
|
Linux Docker Windows
windows docker安装报错适用于 Linux 的 Windows 子系统必须更新到最新版本才能继续。可通过运行 “wsl.exe --update” 进行更新。
适用于 Linux 的 Windows 子系统需更新至最新版本(如 wsl.2.4.11.0.x64.msi)以解决 2025 年 Windows 更新后可能出现的兼容性问题。用户可通过运行 “wsl.exe --update” 或访问提供的链接下载升级包进行更新。
3102 0