K8s docker-compose基础语法

本文详细介绍了如何使用DockerCompose进行服务部署,包括镜像管理、构建、启动配置(如命令、entrypoint),以及网络模式、端口映射、容器链接和日志配置。此外,还涉及了Kafka的安装、生产和消费,以及Spring框架的整合应用实例。
摘要由CSDN通过智能技术生成

image


指定服务的镜像名称或镜像id,如果镜像在本地存在,就会使用本地的镜像,如果不存在,compose就会自动去尝试拉取这个镜像

image: nginx

image: httpd:v0.1

image: tutum/influxdb

image: example-registry.com:4000/postgresql

image: a4bc65fd

build


基于dockerfile,在使用up启动的时候会自动执行构建任务,可以指定dockerfile所在的文件夹的路径,compose会将他自动构建这个镜像,让后使用这个镜像启动服务容器

build: /tmp/httpd/Dockerfile

也可以是相对路径,只要上下文确定就可以读取到 Dockerfile。

build: ./dir

command


使用command可以覆盖容器启动后默认执行的命令的命令,跟dockerfile中的CMD一样,当dockerfile定义了entry point的时候,docker-compose.yml定义的command会被覆盖

version: ‘3’

services:

web:

build: ./

command: env

entry point


可以覆盖dockerfile中定义的entry point命令

//entrypoint没有执行启动server的命令,而是echo hello world, 那么在docker-compose up的过程中不会打印出hello worl, docker logs 查看容器才能看到hello world

version: ‘3’

services:

httpd:

build: ./

entrypoint:

  • echo

  • hello world

[root@localhost ~]# docker logs composetest_web_1

hello world

ports


将容器端口映射到宿主机上

ports:

  • “8080:80”

  • “127.0.0.1:8080:80”

expose


与dockerfile中的expose一样,是用来暴露指定的端口号

expose:

  • “80”

  • “8080”

links


容器的连接,会连接到其它服务中的容器

links:

  • db

  • db:database

  • redis

//如果使用的别名将会自动在服务容器中的/etc/hosts里创建

192.168.129.135 db

192.168.129.136 database

192.168.129.250 redis

logging


这个标签用于配置日志服务。

logging:

driver: syslog

options:

syslog-address: “tcp://192.168.129.135:80”

stop_signal


设置另一个信号来停止容器。在默认情况下使用的是SIGTERM停止容器。设置另一个信号可以使用stop_signal标签。

stop_signal: SIGUSR1

network_mode


网络模式,与Docker client的–net参数类似,只是相对多了一个service:[service name]的格式。

network_mode: “bridge”

network_mode: “host”

Kafka实战笔记

关于这份笔记,为了不影响大家的阅读体验,我只能在文章中展示部分的章节内容和核心截图

image.png

  • Kafka入门
  • 为什么选择Kafka
  • Karka的安装、管理和配置

image.png

  • Kafka的集群
  • 第一个Kafka程序
  • image.png

afka的生产者

image.png

  • Kafka的消费者
  • 深入理解Kafka
  • 可靠的数据传递

image.png

image.png

  • Spring和Kalka的整合
  • Sprinboot和Kafka的整合
  • Kafka实战之削峰填谷
  • 数据管道和流式处理(了解即可)

image.png

  • Kafka实战之削峰填谷

image.png

可靠的数据传递

[外链图片转存中…(img-ddEC1W4Q-1714409907962)]

[外链图片转存中…(img-7sZ3CLTT-1714409907962)]

  • Spring和Kalka的整合
  • Sprinboot和Kafka的整合
  • Kafka实战之削峰填谷
  • 数据管道和流式处理(了解即可)

[外链图片转存中…(img-LCHihCRQ-1714409907962)]

  • Kafka实战之削峰填谷

[外链图片转存中…(img-o3Uj86W4-1714409907962)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 16
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: docker-compose是一个用于定义和管理多个Docker容器的工具。它使用YAML(YAML Ain't Markup Language)格式的docker-compose.yml文件来描述应用程序的服务、网络和卷等配置。 docker-compose.yml文件由多个部分组成,包括版本、服务、网络和卷。 版本部分用来指定docker-compose所使用的格式版本,例如: ``` version: '3' ``` 服务部分是docker-compose.yml文件中最重要的部分,用来定义需要运行的容器,包括镜像名称、容器名称、端口映射、环境变量等,例如: ``` services: web: image: nginx:latest ports: - "80:80" environment: - DEBUG=true ``` 网络部分用来定义容器之间的网络连接,例如: ``` networks: mynetwork: ``` 卷部分用来定义数据持久化的方式,例如: ``` volumes: myvolume: ``` 通过docker-compose.yml文件中定义的服务、网络和卷等配置,可以方便地启动、停止、管理多个Docker容器。 除了上述基本语法外,docker-compose.yml文件还支持其他更高级的功能,如环境变量引用、扩展字段、容器依赖关系等。 总之,docker-compose.yml语法是用来描述和管理多个Docker容器的工具,可以通过定义版本、服务、网络和卷等配置来实现容器的启动、停止和管理。它使用YAML格式,具有简洁和易读性强的特点,方便开发者进行使用和维护。 ### 回答2: Docker Compose是一个用于定义和运行多个Docker容器的工具。它使用yml(YAML)语法来描述容器之间的关系、所需的映像、环境变量、端口绑定等信息。 在Docker Compose的yml文件中,我们可以定义多个服务(services),每个服务对应一个容器。每个服务可以指定一个映像(image),即使用的基础镜像以及所需的标签或版本号。 除了映像,我们可以为每个服务指定容器名称(container_name)、挂载的卷(volumes)、环境变量(environment)、端口映射(ports)等。 在yml文件中,可以使用"services"关键字来定义多个服务,每个服务都包括一个唯一的名称,以及下面的属性: - image: 指定使用的映像 - container_name: 指定容器的名称 - volumes: 指定挂载的卷 - environment: 指定环境变量 - ports: 指定端口映射 此外,我们还可以使用其他关键字来定义全局的配置选项,例如版本(version)、网络(networks)等。 版本指定了使用的Docker Compose yml文件的版本,可以使用1、2或3等不同版本。 网络定义了在Compose文件中使用的网络配置,可以指定网络模式为bridge、host或user-defined。 除了上述基本的语法,还可以使用一些高级特性如依赖关系、资源限制、扩展等。 总之,Docker Compose yml语法提供了一种简洁且易于理解的方式来定义和管理多个Docker容器,使得我们能够轻松地创建和运行多个容器化的应用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值