<divclass="cardback"><DOCUMENT_FRAGMENT><divclass="mw-parser-output"><divclass="thumb tright"><divclass="thumbinner"style="width:152px;"><aclass="image"href="https://pzwiki.wdka.nl/mw-mediadesign/images/thumb/0/03/USB_drives_as_libraries.jpeg/720px-USB_drives_as_libraries.jpeg"><imgalt=""class="thumbimage"decoding="async"src="https://pzwiki.wdka.nl/mw-mediadesign/images/thumb/0/03/USB_drives_as_libraries.jpeg/320px-USB_drives_as_libraries.jpeg"></a><divclass="thumbcaption"><divclass="magnify"><aclass="internal"href="File:USB_drives_as_libraries.jpeg.html"title="Enlarge"></a></div>USB drives as libraries</div></div></div>
<liclass="toclevel-1"><ahref="#Auto-mount_an_external_drive_on_boot"><spanclass="tocnumber">1</span><spanclass="toctext">Auto-mount an external drive on boot</span></a>
<ul>
<liclass="toclevel-2"><ahref="#Step_1_.E2.80.93_Plug_In_The_Device"><spanclass="tocnumber">1.1</span><spanclass="toctext">Step 1 – Plug In The Device</span></a></li>
<liclass="toclevel-2"><ahref="#Step_2_.E2.80.93_Identify_The_Device.27s_Unique_ID"><spanclass="tocnumber">1.2</span><spanclass="toctext">Step 2 – Identify The Device's Unique ID</span></a></li>
<liclass="toclevel-2"><ahref="#Step_3_.E2.80.93_Create_a_Mount_Point"><spanclass="tocnumber">1.3</span><spanclass="toctext">Step 3 – Create a Mount Point</span></a></li>
<liclass="toclevel-2"><ahref="#Step_4_.E2.80.93_Manually_Mount_The_Drive"><spanclass="tocnumber">1.4</span><spanclass="toctext">Step 4 – Manually Mount The Drive</span></a></li>
<liclass="toclevel-2"><ahref="#Step_5_.E2.80.93_Un-mounting_The_Drive"><spanclass="tocnumber">1.5</span><spanclass="toctext">Step 5 – Un-mounting The Drive</span></a></li>
<liclass="toclevel-2"><ahref="#Step_6_.E2.80.93_Auto_Mount"><spanclass="tocnumber">1.6</span><spanclass="toctext">Step 6 – Auto Mount</span></a></li>
<liclass="toclevel-2"><ahref="#An_Extra_Note_About_File_Systems"><spanclass="tocnumber">1.7</span><spanclass="toctext">An Extra Note About File Systems</span></a></li>
<h3><spanclass="mw-headline"id="Auto-mount_an_external_drive_on_boot">Auto-mount an external drive on boot</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/mw-mediadesign/index.php?title=User:Simon/Trim4/prototypes/automount_a_drive_on_boot&action=edit&section=T-1"title="Edit section: ">edit</a><spanclass="mw-editsection-bracket">]</span></span></h3>
<h4><spanid="Step_1_–_Plug_In_The_Device"></span><spanclass="mw-headline"id="Step_1_.E2.80.93_Plug_In_The_Device">Step 1 – Plug In The Device</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/mw-mediadesign/index.php?title=User:Simon/Trim4/prototypes/automount_a_drive_on_boot&action=edit&section=T-2"title="Edit section: ">edit</a><spanclass="mw-editsection-bracket">]</span></span></h4>
<h4><spanid="Step_2_–_Identify_The_Device's_Unique_ID"></span><spanclass="mw-headline"id="Step_2_.E2.80.93_Identify_The_Device.27s_Unique_ID">Step 2 – Identify The Device's Unique ID</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/mw-mediadesign/index.php?title=User:Simon/Trim4/prototypes/automount_a_drive_on_boot&action=edit&section=T-3"title="Edit section: ">edit</a><spanclass="mw-editsection-bracket">]</span></span></h4>
<p>In order to find the unique reference (UUID) for your drive run the following command in the terminal:
</p><p><code>ls -l /dev/disk/by-uuid/</code>
</p><p>This will give you an output that should list your drive:
</p><p>The line will usually refer to “/sda” and in this example it is “sda1”. My ID is “989B-E900”. Note down yours.
You would need to repeat this step if you wanted to use a different device as the UUID would be different.
</p>
<h4><spanid="Step_3_–_Create_a_Mount_Point"></span><spanclass="mw-headline"id="Step_3_.E2.80.93_Create_a_Mount_Point">Step 3 – Create a Mount Point</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/mw-mediadesign/index.php?title=User:Simon/Trim4/prototypes/automount_a_drive_on_boot&action=edit&section=T-4"title="Edit section: ">edit</a><spanclass="mw-editsection-bracket">]</span></span></h4>
<p>A mount point is a directory that will point to the contents of your flash drive. Create a suitable folder:
</p><p><code>sudo mkdir /media/usb</code>
</p><p>I’m using “usb” but you can give it whatever name you like. Keep it short as it saves typing later on. Now we need to make sure the Pi user owns this folder:
<h4><spanid="Step_4_–_Manually_Mount_The_Drive"></span><spanclass="mw-headline"id="Step_4_.E2.80.93_Manually_Mount_The_Drive">Step 4 – Manually Mount The Drive</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/mw-mediadesign/index.php?title=User:Simon/Trim4/prototypes/automount_a_drive_on_boot&action=edit&section=T-5"title="Edit section: ">edit</a><spanclass="mw-editsection-bracket">]</span></span></h4>
<p>To manually mount the drive use the following command:
</p><p><code>sudo mount /dev/sda1 /media/usb -o uid=pi,gid=pi</code>
</p><p><br>
This will mount the drive so that the ordinary Pi user can write to it. Omitting the “-o uid=pi,gid=pi” would mean you could only write to it using “sudo”.
Now you can read, write and delete files using “/media/usb” as a destination or source without needing to use sudo.
</p>
<h4><spanid="Step_5_–_Un-mounting_The_Drive"></span><spanclass="mw-headline"id="Step_5_.E2.80.93_Un-mounting_The_Drive">Step 5 – Un-mounting The Drive</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/mw-mediadesign/index.php?title=User:Simon/Trim4/prototypes/automount_a_drive_on_boot&action=edit&section=T-6"title="Edit section: ">edit</a><spanclass="mw-editsection-bracket">]</span></span></h4>
<p>You don’t need to manually un-mount if you shutdown your Pi but if you need to remove the drive at any other time you should un-mount it first. Only the user that mounted the drive can un-mount it.
</p><p><code>umount /media/usb</code>
</p><p>If you used the fstab file to auto-mount it you will need to use:
</p><p><code>sudo umount /media/usb</code>
</p><p>If you are paying attention you will notice the command is “<i>u</i>mount” NOT “<i>un</i>mount”!
</p>
<h4><spanid="Step_6_–_Auto_Mount"></span><spanclass="mw-headline"id="Step_6_.E2.80.93_Auto_Mount">Step 6 – Auto Mount</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/mw-mediadesign/index.php?title=User:Simon/Trim4/prototypes/automount_a_drive_on_boot&action=edit&section=T-7"title="Edit section: ">edit</a><spanclass="mw-editsection-bracket">]</span></span></h4>
<p>When you restart your Pi your mounts will be lost and you will need to repeat Step 4. If you want your USB drive to be mounted when the system starts you can edit the fstab file:
</p><p>The “nofail” option allows the boot process to proceed if the drive is not plugged in. The “noatime” option stops the file access time being updated every time a file is read from the USB stick. This helps improve performance.
</p><p>Make sure you set the correct UUID. Use CTRL-X followed by Y to save and exit the nano editor.
</p><p>Now reboot:
</p><p><code>sudo reboot</code>
</p><p>Your USB drive should be auto-mounted and available as “/media/usb”.
</p>
<h4><spanclass="mw-headline"id="An_Extra_Note_About_File_Systems">An Extra Note About File Systems</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/mw-mediadesign/index.php?title=User:Simon/Trim4/prototypes/automount_a_drive_on_boot&action=edit&section=T-8"title="Edit section: ">edit</a><spanclass="mw-editsection-bracket">]</span></span></h4>
<p>In the examples above I specified “vfat” as the file system of the device as it was formatted as FAT32. If you need to change the file system replace references of “vfat” with “ntfs-3g”, “ext3” or “ext4”.
If you are using NTFS you will also need to install the following package:
<p>This technique suits my applications but the main disadvantage is that it is specific to a known USB device given we are using the device ID. However if you created a few mount points in advance you could manually mount a new device to a spare mount point without worrying about updating the fstab file.