Docker Swarm部署实操

大家好,我是升仔

引言

Docker Swarm 是 Docker 官方的集群管理工具,它将多个 Docker 主机转换为一个虚拟的 Docker 主机。Swarm 提供了容器编排、集群管理、服务发现等功能,非常适合生产环境的需要。

部署步骤

环境准备
  1. 准备至少三台安装了 Docker 的机器,用于构建 Swarm 集群。
  2. 选择一台机器作为 Swarm 管理节点(Manager Node),其他作为工作节点(Worker Nodes)。
初始化 Swarm 集群
  1. 在管理节点上执行 docker swarm init 命令初始化 Swarm 集群。

    复制代码
    docker swarm init --advertise-addr <MANAGER-IP>
    • <MANAGER-IP> 是管理节点的 IP 地址。
    • 这个命令会生成一个加入集群的 token。
  2. 在每个工作节点上执行下面的命令,加入 Swarm 集群。

    复制代码
    docker swarm join --token <TOKEN> <MANAGER-IP>:2377
    • <TOKEN> 是上一步生成的 token。
    • <MANAGER-IP>:2377 是管理节点的 IP 地址和端口。
创建服务
  1. 回到管理节点,部署服务。

    复制代码
    docker service create --replicas 3 --name myservice --publish published=8080,target=80 myapp:1.0
    • --replicas 3 指定了服务在集群中的副本数为 3。
    • --name myservice 为服务命名。
    • --publish published=8080,target=80 将容器的 80 端口映射到主机的 8080 端口。
    • myapp:1.0 是之前构建的 Docker 镜像。
管理和扩展服务
  • 查看服务状态:docker service ls
  • 扩展服务:docker service scale myservice=5(将副本数增加到 5)
网络配置
  • Swarm 集群默认使用 overlay 网络,支持跨多个 Docker 主机的容器互联。

集群管理

  • 使用 Docker CLI 或者 Docker Compose 文件来管理集群中的服务。
  • 可以配置滚动更新策略,实现服务的无缝更新。

监控和日志

  • 集成 Prometheus 和 Grafana 进行集群监控。
  • 使用 ELK Stack(Elasticsearch, Logstash, Kibana)进行日志管理。

安全性

  • 配置 TLS/SSL 来保证集群通信的安全。
  • 使用 Docker Secrets 管理敏感数据。

总结

使用 Docker Swarm 进行集群部署是一个高效且灵活的方法,特别适合处理大规模的容器化应用。通过 Swarm,可以轻松管理服务的部署、扩展和更新,同时也能保证服务的高可用性和负载均衡。当然,还有许多高级特性等待你去探索和实践。

最后说一句(求关注,求赞,别白嫖)

最近无意间获得一份阿里大佬写的刷题笔记,一下子打通了我的任督二脉,进大厂原来没那么难。

这是大佬写的,7701页的BAT大佬写的刷题笔记,让我offer拿到手软

本文已收录于我的技术网站,next-java.com, 有大厂完整面经,工作技术等经验分享

求一键三连:点赞、分享、收藏

点赞对我真的非常重要!在线求赞,加个关注非常感激

相关推荐
一水鉴天1 小时前
整体设计 逻辑系统程序 之18 Source 容器(Docker)承载 C/P/D 三式的完整设计与双闭环验证 之2
docker·架构·认知科学·公共逻辑
飞快的蜗牛3 小时前
利用linux系统自带的cron 定时备份数据库,不需要写代码了
java·docker
火星MARK3 小时前
k8s面试题
容器·面试·kubernetes
香吧香4 小时前
Docker Registry 使用总结
docker
赵渝强老师5 小时前
【赵渝强老师】Docker容器的资源管理机制
linux·docker·容器·kubernetes
haicome6 小时前
deepseek部署
docker·ragflow·deepseek 部署
乄bluefox6 小时前
保姆级docker部署nacos集群
java·docker·容器
每天进步一点_JL7 小时前
Docker 是什么?
后端·docker·容器
一叶飘零_sweeeet7 小时前
从 0 到 1 掌控云原生部署:Java 项目的 Docker 容器化与 K8s 集群实战指南
docker·云原生·kubernetes·项目部署
森林猿8 小时前
docker-compose-kafka 4.1.0
docker·容器·kafka