05 Docker集群/基础设施 - DevOps之路
05 Docker集群/基础设施 - DevOps之路
文章Github地址,欢迎
start
:https://github.com/li-keli/DevOps-WiKi
Docker的集群目前主流的方案:
Docker Swarm 集群
是用Swarm集群来部署一个无状态的服务:
目前有三台物理机node01、node02、node03,在node01上初始化Swarm:
docker swarm init --advertise-addr 192.168.0.10 # 你的IP地址
这个时候会创建一个swarm的manage节点,并输出一段join的命令样例。在其他的docker机器上运行上面输出的docker swarm join
命令就可以加入集群了。
docker swarm join \
--token SWMTKN-1-2apg79ozshm0x9hgqgm7v3qo4ks6qcgqzqir5z03g6y90qolf8-***************** \
192.168.0.10:2377
若是忘记了init输出的密码和令牌,可以通过命令docker swarm join-token worker
查看。
创建服务
在manager node上执行命令:
docker service create --name web_server --publish 8080:80 --replicas=2 192.168.0.10:60000/test/api:1.0
命令是在集群中创建一个叫做web_server的服务,并暴露8080端口出来
通过docker service ls
可以查看目前集群中所有的服务
通过ocker service ps [服务名]
可以查看指定的服务的所有容器[副本] 运行情况
服务的网络
默认情况下,如下创建的服务:
docker service create --name web_server --replicas=2 192.168.0.10:60000/test/api:1.0
此种创建的服务,只能在容器内访问,并不能在外部访问
若是新创建服务,加上 --publish 8080:80
则会映射并暴露8080到外部。
若是已经创建的服务,则执行:
docker service update --publish-add 8080:80 web_server
弹性伸缩service
若是我们要做负载均衡,就需要很多的节点,那么在swarm-manager执行:
docker service scale web_server=5
这样就可以将service中的副本数量增加且恒定到5个的数量
默认配置下 manager node 也是 worker node,所以 swarm-manager 上也运行了副本。如果不希望在 manager 上运行 service,可以执行如下命令:
docker node update --availability drain swarm-manager
不希望在 manager 上运行 service
默认配置下 manager node 也是 worker node,所以 swarm-manager 上也运行了副本。如果不希望在 manager 上运行 service,可以执行如下命令:
docker node update --availability drain swarm-manager
另外由于作者本身知识有限,都是摸索着来的,所以不一定所有的做法都对,或者某些实践会有更好的方案,望各位读者不吝指正,有任何疑问,请留 issues
作者:Li keli
出处:https://www.cnblogs.com/likeli/p/8967646.html
本站使用「署名 4.0 国际」创作共享协议,转载请在文章明显位置注明作者及出处。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?