使用单个 docker 文件启动多个 docker 容器
Use a single dockerfile to start many docker containers
我有一个名为 testapps 的 docker 图像,这个图像有 5 个微型网络应用程序,现在我们将它们称为应用程序 A 到 E。我想部署这个图像并创建一个 docker为每个应用程序实例化一个容器的文件,这样当我 运行:
docker build -t apps .
我希望有 5 个容器,每个容器 运行 一个不同的应用程序。
我的第一个问题是,如何在 docker 文件中引用本地存储的图像(使用命令 docker save pesky_perk -o testapps
保存)?
其次,我如何使用引用的 docker 图像基于一个图像实例化 5 个容器,每个容器都有自己的入口点,例如:
#Container 1
ENTRYPOINT ["java", "-jar", "/A.jar"]
#Container 2
ENTRYPOINT ["java", "-jar", "/B.jar"]
#Container 3
ENTRYPOINT ["java", "-jar", "/C.jar"]
#Container 4
ENTRYPOINT ["java", "-jar", "/D.jar"]
#Container 5
ENTRYPOINT ["java", "-jar", "/E.jar"]
Docker文件不实例化容器。它只是构建图像。如果你想对运行多个应用使用相同的图像,只需在docker run
命令行中包含相关命令:
docker run --name app_A myimage /A.jar
docker run --name app_B myimage /B.jar
docker run --name app_C myimage /C.jar
docker run --name app_D myimage /D.jar
docker run --name app_E myimage /E.jar
这假设您的 Docker 文件包含:
ENTRYPOINT ["java", "-jar"]
Docker文件中的FROM
行总是引用本地图像:如果本地不存在,则从远程存储库。但是,如果它与可用的本地图像相匹配,则一切就绪。
如果您有 docker save
的输出,您需要先 docker load
它以便您的本地 Docker 守护程序知道它。
我有一个名为 testapps 的 docker 图像,这个图像有 5 个微型网络应用程序,现在我们将它们称为应用程序 A 到 E。我想部署这个图像并创建一个 docker为每个应用程序实例化一个容器的文件,这样当我 运行:
docker build -t apps .
我希望有 5 个容器,每个容器 运行 一个不同的应用程序。
我的第一个问题是,如何在 docker 文件中引用本地存储的图像(使用命令 docker save pesky_perk -o testapps
保存)?
其次,我如何使用引用的 docker 图像基于一个图像实例化 5 个容器,每个容器都有自己的入口点,例如:
#Container 1
ENTRYPOINT ["java", "-jar", "/A.jar"]
#Container 2
ENTRYPOINT ["java", "-jar", "/B.jar"]
#Container 3
ENTRYPOINT ["java", "-jar", "/C.jar"]
#Container 4
ENTRYPOINT ["java", "-jar", "/D.jar"]
#Container 5
ENTRYPOINT ["java", "-jar", "/E.jar"]
Docker文件不实例化容器。它只是构建图像。如果你想对运行多个应用使用相同的图像,只需在docker run
命令行中包含相关命令:
docker run --name app_A myimage /A.jar
docker run --name app_B myimage /B.jar
docker run --name app_C myimage /C.jar
docker run --name app_D myimage /D.jar
docker run --name app_E myimage /E.jar
这假设您的 Docker 文件包含:
ENTRYPOINT ["java", "-jar"]
Docker文件中的FROM
行总是引用本地图像:如果本地不存在,则从远程存储库。但是,如果它与可用的本地图像相匹配,则一切就绪。
如果您有 docker save
的输出,您需要先 docker load
它以便您的本地 Docker 守护程序知道它。