docker compose dns 缓存_Docker服务

1. Docker服务

作为一名后端攻城狮,对“服务”这个概念一定不陌生。比如,我们做一个会员系统,它可能会需要数据库、缓存、消息队列,这些都是中间件服务,除此以外可能还需要依赖其它的Dubbo服务。

在Docker中,服务就是用于生产环境的容器(“containers in production”)。我们可以这样来理解这句话,当我们运行某个镜像时,其实就产生了一个镜像实例,这个实例我们把它叫做容器,接下来我们对它做个升级,比如一些配置负载均衡,配置域名解析映射等,最终它以web服务的形式运行,那么这个升级版的容器就是Docker服务。可以设想一下开发一个Java应用程序是怎样的过程,首先建一个工程,然后编写代码,打成jar包,在内网运行,配置nginx,配置告警及监控,经过这一系列操作后,客户端才能通过公网访问到这个服务。(PS:类比Java的话,镜像就是类,容器就是对象,服务就是一个成型的APP产品,或者叫服务)

一个服务只运行一个映像,但是它将镜像运行的方式进行了编码,比如应该使用什么端口,应该运行多少个容器副本,以便服务具有所需的能力,等等。可以通过改变运行该软件的容器实例的数量来对服务进行扩容,从而为流程中的服务分配更多的计算资源。

幸运的是,使用Docker平台很容易定义、运行和扩容服务。只需要写一个docker-compose.yml文件即可。

2. 第一个docker-compose.yml文件

创建一个文件,文件命名为docker-compose.yml,将下列内容粘贴到文件中,保存9d867943d8ac300e96b0f1daa3f33b85.png

一个docker-compose.yml文件是一个YAML文件,它定义了Docker容器在生产环境中的行为。

这个docker-compose.yml文件告诉Docker要做以下事情:

从注册中心上pull(拉取)镜像以web服务的形式运行该映像的5个实例,限制每个实例最多只能使用CPU单个内核时间的10%(也可以是“1.5”,表示每个实例只能使用1.5个内核)和50MB内存如果一个容器失败,立即重启它将主机上的4000端口映射到web的80端口指示web容器通过叫webnet的负载均衡网络共享80端口用默认设置定义webnet网络

3. 运行新的负载均衡的APP

首先,运行

4a96bb2a23a9f3ecbf61ab088153aaa2.png

接下来,给APP起个名字,比如叫getstartedlab9411b80f752955ff3ea08b8d1c6af85e.png

我们的单个服务堆栈在一台主机上运行了5个容器实例,让我们来看一看

5af2e97fdda3fecdf84b95c2f6292ac1.png

除了“docker service ls”,我们还可以通过“docker stack services”来查看

38fe0bab1dbde87ddeace28caa60d183.png

还可以通过修改docker-compose.yml来动态的扩展app,修改为后需要再执行一次

0cafed2dca1f3c0e880ac2413565780b.png

完整的演示

057dfd89b75e530be73705c70ffa9ca4.png

  1. 备忘单

    94e7b6e79313c38f6757393f4cc155f2.png

※部分文章来源于网络,如有侵权请联系删除;更多文章和资料|点击后方文字直达 ↓↓↓100GPython自学资料包阿里云K8s实战手册 [阿里云CDN排坑指南]CDN ECS运维指南 DevOps实践手册 Hadoop大数据实战手册 Knative云原生应用开发指南 OSS 运维实战手册云原生架构白皮书Zabbix企业级分布式监控系统源码文档10G大厂面试题戳领

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值