amazon-web-services – 带有Docker和EBS卷的EC2,在init期间在容器内安装EBS卷

前端之家收集整理的这篇文章主要介绍了amazon-web-services – 带有Docker和EBS卷的EC2,在init期间在容器内安装EBS卷前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我实际上试图用Docker实现一些东西但是我被卡住了,这是我的问题.

我的容器托管在EC2上,里面有我的网络应用程序.我的webapp用作数据库JCR存储库,它基本上是一个存储在你想要的文件.因此,每次我的Web应用程序启动时,如果存储库不存在,它将创建它,否则它将使用现有的存储库.

我当前的docker文件看起来像这个https://gist.github.com/agonist/7cab7358379e9dd6e812 ./chameleon.sh start刚启动我的webapp.在这个应用程序中,我配置了存储库文件所在的位置.

现在我创建了一个附加并安装在我的EC2实例中的EBS卷.该卷将专用于存储存储库.所以基本上在我的应用程序中我将我的存储库路径配置为/ mnt / repository /,其中repository是包含我的web应用程序创建的存储库文件的目录.
但是我不知道如何在Dockefile中的./chameleon.sh开始之前将这个卷安装到我的容器中.正如我在研究中看到的那样

  1. docker run -v /mnt/repository:/mnt/repository aws_beanstalk/current-app

不能从Dockefile执行.

我还发现了一些关于数据的容器,它与另一个容器共享一个卷,但如果我必须运行仍然是同样的问题

  1. sudo docker run -d --volumes-from dbdata

我的容器开始后

最佳答案
简短版本:这不是一个答案,只是对它的一点帮助,澄清了Docker的工作原理.

没有直接关系,但你的Dockerfile可能看起来像这样:

  1. FROM dockerfile/java:oracle-java8
  2. # Expose the port 9000
  3. EXPOSE 9000
  4. # Volumes
  5. VOLUME /root/wisdom/logs
  6. VOLUME /root/wisdom/application
  7. # Change workdir.
  8. WORKDIR /root/wisdom
  9. RUN touch /root/wisdom.log
  10. # Add the wisdom distribution
  11. ADD . /root/wisdom
  12. # For easier handling,we dump the log,so `docker logs containerId` displays
  13. # the log.
  14. CMD ./chameleon.sh start && tail -F logs/wisdom.log

这样,ADD之前的所有图层都会被缓存.而在此之前,如果您更改目录中的任何内容,则会重新创建所有图层.
你chameleon.sh应该是你的本地目录上的chmod,而不是在运行时. ADD保留权限.
停止是没有必要的,因为当您启动容器时,您没有进程正在运行.

-v确实不能从Dockerfile中执行.这是预期的,因为Dockerfile是可移植的.如果将其绑定到本地计算机,则会丢失此功能.

当您执行docker run -v / mnt / repository:/ mnt / repository aws_beanstalk / current-app时,将在执行命令之前完成安装.您可以通过运行docker run -v / mnt / repository来仔细检查:/ mnt / repository aws_beanstalk / current-app mount

使用–volumes-from时,它是一回事.在执行命令之前安装卷.

为什么它会失败?我不确定,检查安装结果并使用您的EBS进行一些手动测试会很有趣.我有一些容器安装EBS卷,它工作正常.

猜你在找的Docker相关文章