gre*_*rge 2 amazon-web-services amazon-ecs docker
因此,我正在更新 cloudformation 模板,以便它使用针对 ECS 优化的 Amazon Linux 2 AMI [amzn2-ami-ecs-hvm-2.0.20190709-x86_64-ebs (ami-0fac5486e4cff37f4)]。以前我使用的是 ami-00129b193dc81bc31,它是一个 Amazon Linux 1 容器。
我最初发现,简单地更改 AMI 意味着 EC2 实例不再加入我的 ECS 集群。经过大量挖掘(确保权限、子网、VPC、IAM 都没有问题),我发现 docker 守护进程崩溃了。原因可以追溯到我对用户数据所做的事情。我把它贴在下面:
"UserData": { "Fn::Base64" : { "Fn::Join" : ["", [
"Content-Type: multipart/mixed; boundary=\"==BOUNDARY==\"\n",
"MIME-Version: 1.0\n",
"--==BOUNDARY==\n",
"Content-Type: text/cloud-boothook; charset=\"us-ascii\"\n",
"#!/bin/bash\n",
"# Set Docker daemon options\n",
"cloud-init-per once docker_debug echo 'OPTIONS=\"${OPTIONS} --storage-opt dm.basesize=10G\"' >> /etc/sysconfig/docker\n",
"--==BOUNDARY==\n",
"Content-Type: text/x-shellscript; charset=\"us-ascii\"\n",
"#!/bin/bash -xe\n",
"echo \"ECS_CLUSTER=",
{ "Ref" : "NovaProductionEcsCluster"},
"\" >> /etc/ecs/ecs.config\n",
"sudo mkdir /efs\n",
"sudo mkdir /efs/nova_files\n",
"sudo useradd -u 33 www-data\n",
"sudo chown -R www-data /efs/nova_files/\n",
"printf \"\nfunction novarun {\n docker exec -ti \\\"\\$(docker ps -qf name=ApacheTask)\\\" \\\"\\$([ \\$# -ne 1 ] && echo \\\"bash\\\" || echo \\\"\\$1\\\")\\\" \n}\n\" >> /home/ec2-user/.bashrc\n",
"--==BOUNDARY==--"
]]}}
}
Run Code Online (Sandbox Code Playgroud)
基本上,这结合了这个(https://docs.aws.amazon.com/AmazonECS/latest/developerguide/bootstrap_container_instance.html)和这个(https://aws.amazon.com/premiumsupport/knowledge-center/increase-default -ecs-docker-limit/ ) 以增加docker容器可用的磁盘空间。这与旧 AMI 完美配合,但新 AMICannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?在我运行docker ps -a.
如果我跑sudo journalctl -u docker得到错误Error starting daemon: error initializing graphdriver: overlay2: unknown option dm.basesize。
谁能告诉我这种方法有什么问题?有没有办法用 ECS 修复这个标志,或者用不同的方法来扩大 docker 映像可用的磁盘空间量?
谢谢
您可以完全删除该 Docker 配置行;您的(较新的)Docker 守护进程可以使用挂载在任何分区中的所有可用空间/var/lib/docker。
Docker 可以使用多种不同的系统(存储驱动程序)来存储图像和容器数据。最初 Docker 使用devicemapper——您选择的“dm”——它不需要特殊的 Linux 内核支持,但确实为所有 Docker 内容分配了固定大小的存储空间。(Devicemapper 也很慢,而且有一些问题;更好的使用方法是给它一个专用的磁盘分区,而不仅仅是一个文件。)大多数较新的 Docker 安装使用overlay2,它确实需要特殊的内核支持,但现在这也相当主流,overlay2避免了devicemapper的大部分问题。
简而言之:
overlay2)。dm.*选项使用不同的存储后端,因此您的错误消息。overlay2比devicemapper无需配置即可本地使用所有主机系统磁盘更好。| 归档时间: |
|
| 查看次数: |
750 次 |
| 最近记录: |