I have a NTFS drive for Storage, which is shared between Win 11.
I want to change the location of (or replace) ~/Downloads
, ~/Music
, etc…,.
Note that the link to made is between NTFS and EXT4.
I found two ways while searching.
1.Creating **Symlinks** in `~` with target pointed to folders in NTFS drive.
2. **Mounting** the NTFS folders **directly** to`~/Downloads`, `~/Music`, etc..,.
Which one should I do? Which one is more beneficial?
Also how to mount folders to other folders (option 2) ? (I would really appreciate a GUI way)
I know this is not that important of a thing to post on Main Linux Community, but I already asked 2 linux4noobs community, and they are empty.
This is a continuation to my previous discussion, where most of the people said,
-
It doesn’t matter where I mount.
-
Mount certain folders directly into home other. (like mounting
/mnt/data/music
to~/music
)
Hey man, I think this is a perfectly valid question to ask here. Also I was one of the people who replied on the other thread as well.
So, let’s start with the why. I imagine you want to have
~/Downloads
be inside your large disk so files get automatically downloaded there, I imagine~/Documents
is to have access to the same documenta on both OSs. If that’s not the why or there’s something else let me know as I’ll be basing my answer on this assumption.Last time we told you about how you can mount things wherever you want to, I imagine by now you have an entry on your fstab that automatically mounts that NTFS drive somewhere. I’ll call that somewhere
/ntfs
just to give it a name/path, but any other path should be the same.If you wanted your ENTIRE NTFS partition to be on
~/Downloads
it’s as easy as changing that fstab entry from/ntfs
to/home/gpstarman/Downloads
(or whatever your username is). But I imagine you want something more complex, you want to have/ntfs/downloads
and~/Downloads
to be the same directory.Like you found out there are two ways to do this, the first and most easy one is to create a link. To do so graphically just open whatever file explorer you use right click and drag from one path to the other and you should have an option
link here
or something similar. Note that you might need to delete or rename your existing~/Downloads
folder to have the link be named that. If you wanted to do it by command line it’sln -s <target> <link name>
, so in your hypothetical caseln -s /ntfs/downloads ~/Downloads
This should work for 99% of cases and honestly I don’t think you should care too much about mounting. I’ll reply to this comment with the steps for mounting and explaining why it’s different just to be on the safe side.
For mounting it’s a bit trickier, just like you added an entry to fstab to say that you wanted to mount (for example )
/dev/sdb2
on/ntfs
you would need to add another one saying you want to mount/ntfs/downloads
to/home/<username>/Downloads
. If you want to run this as a one off the command ismount --bind /ntfs/downloads /home/<username>/Downloads
(but note that running this with a command will become undone when you reboot, the only way to preserve it after reboots is to have an fstab entry)What this does is essentially at the kernel level say that one path is the other. How is this different from a link? Well, a link is just a file that points to the other place, whereas a mount is the other place. A couple of examples on how this is different:
-
If you had a Download folder you would need to rename or delete it before making a link there. Mounting on the other hand necessitates that the Downloads folder exists, and will obfuscate anything inside it while the other folder is mounted. This means that if you had files inside Downloads and you mounted the other folder on top those files are still in the disk, but you have no way of accessing them until you unmount the folder.
-
Links can’t go outside of your system. This is likely not important to you, but if you for example are doing things with chroot or docker this can become a problem.
In short, a link is like a door that when you open it tells you “go to the other door”, whereas the mount is replacing the room behind that door with another one. Most programs are smart enough to go to the other door, and on most cases the other door exists so all is good. On some edge cases (like I said, docker, chroot, etc) the “go to door X” could be a problem if inside the client system X doesn’t exist.
Ps: I don’t know of any way of doing this graphically, this is advanced stuff so likely it’s expected that people who want to mount folders know enough to do it in a terminal
Thanks Again.
This is Everything I needed to know.
Guess I’ll stick to Symlinks for the sake of simplicity.
-
I don’t think this is a bad question at all, personally I would prefer to mount the drive once and symlink folders for a couple reasons:
- It’s easier to automate
- it’s theoretically faster (to initialize) as symlinks are effectively free
- I personally like symlink syntax more than mount syntax :P
One possible con to symlinks is that certain (linux native) software can misbehave when it has to interact with them, but this is a fairly uncommon issue. Stuff ran through wine or proton should support them just fine, as they are abstracted away.
bind mounts don’t usually have the problems that symlinks do. The only time I’ve had issues involve container systems like docker or flatpak.
Lots of internet people says that one can’t create mount points across different filesystems.
problems that symlinks do
Can you explain more please?
Lots of internet people says that one can’t create mount points across different filesystems.
Citation needed. Bind mounts work just fine wherever you put them, again: you need to mount your source filesystem somewhere then you can bind mount paths from that mounted filesystem anywhere in the running VFS tree. You should Google linux bind mounts, they’re quite simple.
problems that symlinks do
Can you explain more please?
Some software has problems following symlinks properly and fails to work unless given the symlink source path instead
Citation needed
My bad. I got it confused with hardlinks.
Thank you.
Thanks man.
It’s easier to automate
I’m failing to see how and why one would do this? ( just curious )
I personally like symlink syntax more than mount syntax :P
same man. It’s just more simple.
Not related to your question exactly, but if you want certain “special” folders (Downloads, Music etc.) to be in specific places, it might be worth setting up xdg data dirs to the appropriate location.
Thank You.
This helped me. But would you suggest XDG or creating Symlinks?
I’d go with symlinks, so both you and software not strictly following standards know where to put and find stuff.
Thank you.
Honestly, whichever one you want. You could probably continue down the rabbit hole of which option is “better” or more closely fits some idealised standard. But ultimately, both methods solve your problem well enough.
Thanks.
For data like this from another filesystem I usually like to mount the entire volume somewhere private (like under
/run
) and then bind mount the parts I want to use into their desired locations (like/home/foo/Download
, etc.)I do this with a second ext4 drive that I use for performance sensitive storage with my primary btrfs system root. It works well, just be aware of edge cases involving containers (you may have to grant the container access to the original mount location under
/run
in addition to the bound path. This is definitely a gotcha when working with those paths with flatpak.)then bind mount the parts I want to use into their desired locations
how though?
This is definitely a gotcha when working with those paths with flatpak
Can you explain a bit more please?
how though?
mount -o bind /source /target
or use fstab or systemd mount unitsCan you explain a bit more please?
Container software often needs permission for both the virtual path (wherever the bind mount is mounted to) and the source path (wherever the original is mounted from. It’s not terribly complicated but it does mean fiddling with access permissions in flatpaks.
You should read about bind mounts, they’re fairly straightforward and there are many, many, many explanations available online
Thank you.
Flatpak can sometimes complain when there’s a symlink (Steam, in particular, does this) so you can use the symlink, but have to update XDG-USER-DIRS to point to the actual location. I wrote it up here: https://ideatrash.net/2024/07/howto-update-xdg-user-dirs-to-avoid-symlink-issues-with-flatpak.html
Thank You for sharing.
Folders? you mean directories 👀
Mount the disk (if you ask me at
/media/nameofdir
) and configure${XDG_CONFIG_HOME:-~/.config}/user-dirs.dirs
(99% of that time that would be the .config dir in your home lol) and define eachXDG_***_DIR=
to the respective directory in the path of the mounted disk, no need to make symlinks, though you might need to because there is likely many apps that don’t follow xdg specs.I would really appreciate a GUI way
I know gnome-disks has a GUI way to change the mount options, I don’t know how good it is though.
Thank You.
would you suggest XDG or creating Symlinks?
Found this just for you. https://lemmy.world/post/1352601
would you suggest XDG or creating Symlinks?
You can do both, and both are easy.
The
user-dirs.dirs
file contains something like this:XDG_DESKTOP_DIR="$HOME/Desktop" XDG_DOCUMENTS_DIR="$HOME/Documents" XDG_DOWNLOAD_DIR="$HOME/Downloads" XDG_MUSIC_DIR="$HOME/Music" XDG_PICTURES_DIR="$HOME/Pictures" XDG_PUBLICSHARE_DIR="$HOME/Public" XDG_TEMPLATES_DIR="$HOME/Templates" XDG_VIDEOS_DIR="$HOME/Videos"
For example if you mount the disk in
/media/dirname
, it would be something like this, I’m giving it aexternal-drive
name in this example:XDG_DESKTOP_DIR="/media/external-drive/Desktop" XDG_DOCUMENTS_DIR="/media/external-drive/Documents" XDG_DOWNLOAD_DIR="/media/external-drive/Downloads" XDG_MUSIC_DIR="/media/external-drive/Music" XDG_PICTURES_DIR="/media/external-drive/Pictures" XDG_PUBLICSHARE_DIR="/media/external-drive/Public" XDG_TEMPLATES_DIR="/media/external-drive/Templates" XDG_VIDEOS_DIR="/media/external-drive/Videos"
And for the symlinks, if the drive already has the
Desktop
,Documents
, etc directories. It is as simple as this:ln -s /media/external-drive/* $HOME
That will symlink all the files in the drive to your $HOME
I suggest you do both because you might run into a program that doesn’t follow XDG user directories.
Thank you.
a lot of good answers here:
https://askubuntu.com/questions/557733/what-is-the-difference-between-ln-s-and-mount-bind#557735Thank you for the link. This helped a lot.
afaik you can’t mount folders, only drives. So what you’re looking for are symlinks (symbolic links, as opposed to hard links; use e.g.
ln -s <source> ~/Downloads
). I have a few in my$HOME
pointing to other drives as well.if your NTFS drive is unmounted or unavailable, the link will be broken; but you won’t have to recreate it in the future: so it’s a “set and forget” operation for as long as the path the link points to remains the same.
Thank You.
FYI, you can mount folders. I just don’t exactly know how.
Seconding this. As it’s a mount that is explicitly for your user, you might as well mount it where it’s most convenient for you.
If, on the other hand, it was a mountpoint for the entire system, I’d keep it in /mnt and go the symlink route - I’m old fashioned, and I like to use /mnt for as much as possible. I find it more tidy that way. On that note, I’m not 100% sold on /media yet
Seconding this.
I’m sorry, but which one exactly?
As it’s a mount that is explicitly for your user
So, mounting folders just do that for a single user whom created the mount point?