使用docker-compose 部署flink集群 并映射数据目录 暴漏端口
时间: 2023-09-09 17:13:14 浏览: 264
以下是一个使用docker-compose部署Flink集群并映射数据目录和暴露端口的示例:
```
version: '3'
services:
jobmanager:
image: flink:1.13.0-scala_2.11
expose:
- "6123"
ports:
- "8081:8081"
command: jobmanager
volumes:
- ./data:/data
environment:
- JOB_MANAGER_RPC_ADDRESS=jobmanager
- FLINK_PROPERTIES=jobmanager.rpc.address: jobmanager
taskmanager:
image: flink:1.13.0-scala_2.11
expose:
- "6121"
- "6122"
depends_on:
- jobmanager
command: taskmanager
volumes:
- ./data:/data
environment:
- JOB_MANAGER_RPC_ADDRESS=jobmanager
- FLINK_PROPERTIES=jobmanager.rpc.address: jobmanager
```
在上面的示例中,我们使用Flink 1.13.0的官方Docker镜像。我们定义了两个服务:`jobmanager`和`taskmanager`。`jobmanager`服务暴露了Flink的默认RPC端口6123,并将Web UI端口8081映射到主机的8081端口,以便我们可以在Web浏览器中访问它。`taskmanager`服务暴露了两个端口:6121和6122。
我们还将`./data`目录映射到容器内部的`/data`目录中,以便我们可以在主机上访问Flink的数据目录。最后,我们在`jobmanager`和`taskmanager`服务的环境变量中设置了`JOB_MANAGER_RPC_ADDRESS`和`FLINK_PROPERTIES`,以确保它们正确连接到Flink集群。
要启动Flink集群,请使用以下命令:
```
docker-compose up -d
```
这将启动`jobmanager`和`taskmanager`服务,并将它们连接成一个Flink集群。要停止Flink集群,请使用以下命令:
```
docker-compose down
```
这将停止并删除所有Flink容器和网络。
阅读全文