New handbook section - resizing/growing disks
Allan Jude
freebsd at allanjude.com
Sun Feb 2 08:16:13 UTC 2014
The question of how to resize a disk partition/file system has come up a
number of times on IRC and elsewhere.
A user writing a raspberry pi image to an SD card that is larger than
the image and wanting to grow the file system to use the rest of the SSD
Creating a live USB system
A user who rented a VPS and then paid to grow the disk from 20GB to 80GB
but the default install had the swap partition at the end.
So, I wrote this section for the handbook that describes how to deal
with those issues.
--
Allan Jude
-------------- next part --------------
Index: disks/chapter.xml
===================================================================
--- disks/chapter.xml (revision 43726)
+++ disks/chapter.xml (working copy)
@@ -252,6 +252,143 @@
<screen>&prompt.root; <userinput>mount /newdisk</userinput></screen>
</sect1>
+ <sect1 xml:id="disks-growing">
+ <info>
+ <title>Resizing and Growing Disks</title>
+
+ <authorgroup>
+ <author>
+ <personname>
+ <firstname>Allan</firstname>
+ <surname>Jude</surname>
+ </personname>
+ <contrib>Originally contributed by </contrib>
+ </author>
+ </authorgroup>
+ </info>
+
+ <indexterm>
+ <primary>disks</primary>
+ <secondary>resizing</secondary>
+ </indexterm>
+
+ <para>This section describes how to resize (grow) an existing disk
+ in &os;. This procedure is most common with virtual machines,
+ but can also apply to images written to USB devices or other
+ cases where the partitions written to a disk do not match the
+ actual size of the disk.</para>
+
+ <para>Determine the device name of the disk that needs to be
+ resized by inspecting <filename>/var/run/dmesg.boot</filename>.
+ In this example, there is only one <acronym>SATA</acronym> disk
+ in the system, so the drive will appear as
+ <filename>ada0</filename>.</para>
+
+ <indexterm><primary>partitions</primary></indexterm>
+ <indexterm>
+ <primary><command>gpart</command></primary>
+ </indexterm>
+
+ <para>List the partitions on the disk to determine what needs to
+ be done to resize the desired partition:</para>
+
+ <screen>&prompt.root; <userinput>gpart show ada0</userinput>
+=> 34 83886013 ada0 GPT (48G) [CORRUPT]
+ 34 128 1 freebsd-boot (64k)
+ 162 79691648 2 freebsd-ufs (38G)
+ 79691810 4194236 3 freebsd-swap (2G)
+ 83886046 1 - free - (512B)</screen>
+
+ <note>
+ <para>If the disk was formatted with the <link
+ xlink:href="http://en.wikipedia.org/wiki/GUID_Partition_Table">
+ <acronym>GPT</acronym></link> partitioning scheme, it may show
+ as corrupted because <acronym>GPT</acronym> stores a backup
+ of the partition table at the end of the drive, which has now
+ moved.</para>
+
+ <screen>&prompt.root; <userinput>gpart recover ada0</userinput>
+ada0 recovered</screen>
+ </note>
+
+ <para>Now the additional space on the disk is available:</para>
+
+ <screen>&prompt.root; <userinput>gpart show ada0</userinput>
+=> 34 102399933 ada0 GPT (48G)
+ 34 128 1 freebsd-boot (64k)
+ 162 79691648 2 freebsd-ufs (38G)
+ 79691810 4194236 3 freebsd-swap (2G)
+ 83886046 18513921 - free - (8.8G)</screen>
+
+ <para>It is only possible to resize a partition into contiguous
+ free space, however the last partition on the disk is the swap
+ partition, rather than the partition to be resized. Since swap
+ does not contain any non-volatile data, it can safely be deleted
+ and recreated after.</para>
+
+ <screen>&prompt.root; <userinput>swapoff /dev/ada0p3</userinput>
+&prompt.root; <userinput>gpart delete -i 3 ada0</userinput>
+ada0p3 deleted
+&prompt.root; <userinput>gpart show ada0</userinput>
+=> 34 102399933 ada0 GPT (48G)
+ 34 128 1 freebsd-boot (64k)
+ 162 79691648 2 freebsd-ufs (38G)
+ 79691810 22708157 - free - (10G)</screen>
+
+ <para>Next resize the partition, leaving room to recreate a swap
+ partition of the desired size.</para>
+
+ <note>
+ <para>There is risk involved with modifying a live file system,
+ it is best to perform the following steps while running off of
+ a live CD or USB device. However it can be done on a live
+ system with the following work around:
+
+ <screen>&prompt.root; <userinput>sysctl kern.geom.debugflags=16</userinput></screen>
+ </para>
+ </note>
+
+ <screen>&prompt.root; <userinput>gpart resize -i 2 -s 47G ada0</userinput>
+ada0p2 resized
+&prompt.root; <userinput>gpart show ada0</userinput>
+=> 34 102399933 ada0 GPT (48G)
+ 34 128 1 freebsd-boot (64k)
+ 162 98566144 2 freebsd-ufs (47G)
+ 98566306 3833661 - free - (1.8G)</screen>
+
+ <para>Next, recreate the swap partition:</para>
+
+ <screen>&prompt.root; <userinput>gpart add -t freebsd-swap ada0</userinput>
+ada0p3 added
+&prompt.root; <userinput>gpart show ada0</userinput>
+=> 34 102399933 ada0 GPT (48G)
+ 34 128 1 freebsd-boot (64k)
+ 162 98566144 2 freebsd-ufs (47G)
+ 98566306 3833661 3 freebsd-swap (1.8G)
+&prompt.root; <userinput>swapon /dev/ada0p3</userinput></screen>
+
+ <para>Finally, grow the UFS file system on the resized
+ partition:</para>
+
+ <note>
+ <para>growing a live UFS file system is only possible in &os;
+ 10.0-RELEASE and later, for earlier versions, the file system
+ must not be mounted.</para>
+ </note>
+
+ <screen>&prompt.root; <userinput>growfs /dev/ada0p2</userinput>
+Device is mounted read-write; resizing will result in temporary write suspension for /.
+It's strongly recommended to make a backup before growing the file system.
+OK to grow filesystem on /dev/ada0p2, mounted on /, from 38GB to 47GB? [Yes/No] <userinput>Yes</userinput>
+super-block backups (for fsck -b #) at:
+ 80781312, 82063552, 83345792, 84628032, 85910272, 87192512, 88474752,
+ 89756992, 91039232, 92321472, 93603712, 94885952, 96168192, 97450432</screen>
+
+ <para>The partition has now been resized to make use of all
+ available space on the disk.</para>
+
+ </sect1>
+
<sect1 xml:id="usb-disks">
<info>
<title>USB Storage Devices</title>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 899 bytes
Desc: OpenPGP digital signature
URL: <http://lists.freebsd.org/pipermail/freebsd-doc/attachments/20140202/1baa071a/attachment.sig>
More information about the freebsd-doc
mailing list