参考资料:
https://www.caseylabs.com/remove-the-aws-marketplace-code-from-a-centos-ami/
http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/storage_expand_partition.html
背景介绍:
在AWS EC2中,从Marketplace里面可以很方便的选择最新的CentOS6的官方Minimal版本的AMI,来创建Instance。
但是这里面却埋了一个大坑,那就是,所有基于Marketplace里面的AMI所创建的Instance,都会带有一个Marketplace code。
它会导致你无法通过为现有根分区所在的EBS Volume创建Snapshot和新的Volume的方式来对其扩容。
在Detach了现有的根分区所在的Volume后,将无法再次将其Attach到Instance当中,在Attach新的Volume时也会遇到相同的报错:
1 | Client.OperationNotPermitted: |
2 | 'vol-xxxxxxx' with Marketplace codes may not be attached as a secondary device. |
这个Marketplace code,顾名思义,应该就是为了保护一些付费的AMI不被随意的克隆,但不知道为什么没有对费用为$0的CentOS6 AMI做单独的处理。
上面的限制,主要影响到的是,默认创建好的CentOS6 Instance的EBS Volume只有8G,即使在创建时指定了50G的EBS Volume,创建后的根分区空间也只有8G。这样的大小是无法满足线上需求的,只能对其进行扩容,而因为有上面的Marketplace code的限制,又使扩容变得很艰难。
还好最终我通过参考上面的两篇文章,从官方的CentOS6 AMI中移除了Marketplace code,并成功的对根分区进行了扩容并创建了相应的AMI。
具体步骤:
1. 从现有的CentOS6 AMI中移除Marketplace code
1.1 从AWS的Marketplace搜索CentOS6 AMI,并创建一个根分区所在的EBS Volume为8G(默认大小)的Instance;
1.2 在AWS EC2 web console中,再创建一个新的大小为8G的EBS Volume;
1.3 将新创建的EBS Volume Attach到Instance上,通常会默认识别为/dev/xvdj(HVM版本的AMI会识别为/dev/xvdf);
1.4 通过SSH登陆到Instance,并通过dd克隆根分区所在的EBS Volume(HVM版本的AMI会将根目录所在的EBS Volume识别为/dev/xvda):
1 | dd bs=65536 if=/dev/xvde of=/dev/xvdj |
1.5 当克隆完成以后,关闭Instance;
1.6 Detach现有根分区所在的EBS Volume;
1.7 Detach新创建的EBS Volume,并重新Attach到Instance,作为/dev/sda(HVM版本的AMI需要指定为/dev/sda1);
1.8 启动Instance;
1.9 在确认Instance正常启动后,在EC2 web console中右键点击Instance,并选择Create Image,即可创建一个新的不含Marketplace code的CentOS6 AMI了,我一般将其命名为official_centos6_x86_64_minimal_ebs8g。
2. 将现有的AMI根分区所在的EBS Volume扩容为50G,并创建新的AMI official_centos6_x86_64_minimal_ebs50g
2.1 基于AMI official_centos6_x86_64_minimal_ebs8g创建一个Instance;
2.2 为Instance所在的EBS Volume创建一个Snapshot;
2.3 创建一个新的大小为50G的Volume,并包含刚刚创建的Snapshot;
2.4 将新创建的Volume Attach到Instance,作为第二块EBS Volume,默认会识别为/dev/xvdj(HVM版本的AMI会识别为/dev/xvdf);
2.5 在Instance上对第二块EBS Volume进行扩容,详细步骤如下(HVM版本的AMI会将根目录所在的EBS Volume识别为/dev/xvda):
01 | [root@ip-172-17-4-12 ~]# parted /dev/xvdj |
04 | Welcome to GNU Parted! Type 'help' to view a list of commands. |
07 | Model: Xen Virtual Block Device (xvd) |
08 | Disk /dev/xvdj: 104857600s |
09 | Sector size (logical/physical): 512B/512B |
12 | Number Start End Size Type File system Flags |
13 | 1 2048s 16777215s 16775168s primary ext4 boot |
16 | (parted) mkpart primary 2048s 100% |
18 | Model: Xen Virtual Block Device (xvd) |
19 | Disk /dev/xvdj: 104857600s |
20 | Sector size (logical/physical): 512B/512B |
23 | Number Start End Size Type File system Flags |
24 | 1 2048s 104857599s 104855552s primary ext4 |
28 | Model: Xen Virtual Block Device (xvd) |
29 | Disk /dev/xvdj: 104857600s |
30 | Sector size (logical/physical): 512B/512B |
33 | Number Start End Size Type File system Flags |
34 | 1 2048s 104857599s 104855552s primary ext4 boot |
37 | Information: You may need to update /etc/fstab. |
39 | [root@ip-172-17-4-12 ~]# e2fsck -f /dev/xvdj1 |
40 | e2fsck 1.41.12 (17-May-2010) |
41 | Superblock needs_recovery flag is clear, but journal has data. |
42 | Run journal anyway<y>? yes |
44 | /dev/xvdj1: recovering journal |
45 | Pass 1: Checking inodes, blocks, and sizes |
46 | Pass 2: Checking directory structure |
47 | Pass 3: Checking directory connectivity |
48 | Pass 4: Checking reference counts |
49 | Pass 5: Checking group summary information |
51 | /dev/xvdj1: ***** FILE SYSTEM WAS MODIFIED ***** |
52 | /dev/xvdj1: 18425/524288 files (0.2% non-contiguous), 243772/2096896 blocks |
54 | [root@ip-172-17-4-12 ~]# lsblk |
55 | NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT |
57 | └─xvde1 202:1 0 8G 0 part / |
58 | xvdj 202:80 0 50G 0 disk |
59 | └─xvdj1 202: 0 50G 0 part |
61 | [root@ip-172-17-4-12 ~]# resize2fs /dev/xvdj1 |
62 | resize2fs 1.41.12 (17-May-2010) |
63 | Resizing the filesystem on /dev/xvdj1 to 13106944 (4k) blocks. |
64 | The filesystem on /dev/xvdj1 is now 13106944 blocks long. |
2.6 关闭Instance;
2.7 Detach现有根分区所在的EBS Volume;
2.8 Detach扩容后的第二块EBS Volume,并重新Attach到Instance,作为/dev/sda(HVM版本的AMI需要指定为/dev/sda1);
2.9 启动Instance;
2.10 在确认Instance正常启动后,在EC2 web console中右键点击Instance,并选择Create Image,即可创建一个新的根分区大小为50G的CentOS6 AMI了,我一般将其命名为official_centos6_x86_64_minimal_ebs50g。
来源:http://heylinux.com/archives/3434.html