Filesystem For Linux And Mac
What Filesystem should I use for an external USB harddrive (500GB), with possibility to share with a Mac and Windows systems, for example at the office. Now it is NTFS but back in the day the NTFS support was not stable under Linux and I think it is not supported on a Mac. I have an external drive hooked up to my Mac, and I'm trying to determine things like, e.g., is this HFS or FAT, is it 32-bit or 64-bit, etc. It seems like there should be some trivial command that gives me this info, but I can't seem to find one.
- Linux supports numerous file systems, but common choices for the system disk on a block device include the ext. family (ext2, ext3 and ext4), XFS, JFS, and btrfs. For raw flash without a flash translation layer (FTL) or Memory Technology Device (MTD), there are UBIFS, JFFS2 and YAFFS, among others. SquashFS is a common compressed read-only file.
- Linux is UNIX like a source software and can use an operating system which provides full memory protection and multi-tasking operations. It is an open d by anyone. Head To Head Comparison Between Linux and MAC and Windows (Infographics) Below is the Top 5 Comparisons Between Linux vs MAC.
- The exfat driver for macos is not as full-featured as on windows, and on mac the drive often gets the dirty flag set, as result you might need to to wait for hours (on multi-TB drives) the next time you plug it it because fsckexfat has to finish checking it. The linux driver for exfat is.
More Linux resources
You probably learned how to interact with a computer using a GUI, and you're probably very good at it. You may be surprised to learn, then, that there's a more direct way to use a computer: a terminal, or shell, which provides a direct interface between you and the operating system. Because of this direct communication without the intervention of additional applications, using a terminal also makes it easy to script repetitive tasks, and design workflows unique to your own needs.
There's a catch, however. As with any new tool, you have to learn the shell before you can do anything useful with it.
This article compares navigating a computer desktop without the desktop. That is, this article demonstrates how to use a terminal to move around and browse your computer as you would on a desktop, but from a terminal instead.
While the terminal may seem mysterious and intimidating at first, it's easy to learn once you realize that a terminal uses the same information as all of your usual applications. There are direct analogs for everything you do in a GUI to most of the everyday activities you do in a terminal. So instead of starting your journey with the shell by learning terminal commands, begin with everyday tasks that you're already familiar with.
View file lists
To list the files on your computer or device, you generally open a file manager application, whether it's called Explorer (Windows), Finder (Mac), Nautilus (GNOME), Amaze (Android), or anything else.
The ls
(list) command lists all files in the current directory.
The pwd
(print working directory) command tells you what directory you're currently in. From there, the ls
(list) command shows you what's in that (or any other) directory:
The first items listed are dots. The single dot is a meta-location, meaning the folder you are currently in.
The double dot is an indicator that you can move back from this location. That is, you're in a folder inside of another folder. Once you start moving around within your computer, you can use that information for reference.
You may also notice that it's hard to tell a file from a folder. Some Linux distributions have colors pre-programmed so that folders are blue, files are white, binary files are green, and so on. If you don't see those colors, you can use ls --color
to try and activate that feature. Colors don't always transmit over remote connections to distant servers, though, so a common and generic method to make it clear what are files and what are folders is the --classify
(-F
) switch:
Folders are given a trailing slash (/
) to denote that they are directories. Binary entities, like ZIP files and executable programs, are indicated with an asterisk (*
). Plain text files are listed without additional notation.
If you're used to the dir
command from Windows, you can use that on Linux as well. It works exactly the same as ls
.
[ Free download: Advanced Linux commands cheat sheet. ]
Open a folder
Double-click on a folder. When it opens, you are 'in' that folder.
The cd
(change directory) command opens a folder and makes it your new current working directory.
To open—or enter—a folder on the command line, use the cd
(change directory) command as follows:
Close a folder
Close the desktop window you're in, or press the Back button in your file manager to leave the folder.
You don't so much close a folder on the command line, as you leave it.
On a desktop, you judge your current location by what window you have open. For instance, when you open a window and click on the Documents folder icon, you think of yourself as being in your Documents folder.
In a terminal, the closest thing to this concept is the shell prompt. In most shells, your prompt is a dollar sign ($
), and its location within the computer can change depending on where you tell your terminal to go. You can always learn your current location with the pwd
(print working directory) command:
If you're in one location because you used the cd
command, you can 'close' that location by going back to your home directory. This directory is, more or less, your terminal's desktop—it's the place you find yourself staring at when you first open the terminal.
The command for returning home is the cd
command with no location specified (shorthand for cd ~
):
Navigate directories
Open a window, double-click on a folder, and then double-click on a sub-folder. Use the Back button to backtrack.
The cd
(change directory) command moves you into a different directory. To move out of that directory, use cd
along with the path to some other location, or use double dots to backtrack, or return home to navigate from there.
Navigating a Linux computer is like navigating the internet. The very concept of a URL is pulled directly from UNIX. When you navigate to a specific page on a website, like https://www.redhat.com/en/topics/linux, you're actually changing directory to /var/www/redhat.com/en/topics/linux
(this isn't exactly true for pages built by PHP and other dynamic languages, but even they are essentially building a virtual file system).
To go back a page in this example, delete the linux
part of the URL. You're taken to a new location, the parent directory, containing a different file for you to view. Because this happens inside your web browser, you probably don't think of it as navigating a computer, but you use the same principle in a Linux terminal.
Think of your computer as the internet (or the internet as a computer, more appropriately). If you start in your home folder, then all of your personal files can be expressed using your home as the starting point. Think of your home folder as a web URL's domain. Instead of a URL, the term directory path or file path is used. Here are some example paths:
/home/seth/bin
/home/seth/despacer.sh
/home/seth/documentation.zip*
/home/seth/people
Because you return home often, your home directory can be abbreviated as ~
. For instance:
~/bin
~/despacer.sh
~/documentation.zip*
~/people
To navigate directly to the people
folder, use the cd
command along with the entire directory path:
Suppose that inside the people
folder, there are the directories developers
and marketing
.
Now that you're inside the people
directory, you can move out of it in one of three different ways.
One option is to navigate into a different directory from where you are now. This method uses a dot as your starting point.
Remember that a dot is a meta-location, meaning 'where I am right now.' This method is akin to, for instance, manually adding a level in a URL, such as changing https://www.redhat.com/en/topics to https://www.redhat.com/en/topics/linux. So, to change to the developers
directory from your current location, do the following:
You could move through all of your directories this way: change directory to one folder, list its contents, and then move into the next one, and so on. However, if you know the path of where you want to go, you can transport yourself there instantly all in one command. To reach the to /home/seth/people/developers
directory instantly from anywhere, instantly:
Once in a directory, you always have the option to backtrack out of your current location using the meta-location ..
to tell cd
to take you up one folder:
You can keep using this trick until you have nowhere left to go:
You can also always return to your home directory instantly using this shortcut:
Because users go home often, most shells are set to go back home should you type cd
with no destination:
Absolute paths
File paths technically start at the very root of your computer's file tree. Even your home directory starts at the very bottom of the tree. This fact is significant because system administrators deal with lots of data that exists outside of their own home directory.
When you go as far back in a file path you can go, you reach the root directory, represented by a single slash (/
). You see the root directory at the beginning of all absolute paths:
Filesystem Compatible With Linux And Mac
/home/seth
/etc/apache2/apache.conf
/var/www/htdocs
When in doubt, you can always use the absolute path to any location:
To find where you want to go, use the ls
command to 'open' a directory and look inside:
Conclusion
Try navigating through your system using the terminal. As long as you restrict yourself to the cd
, ls
, and pwd
commands, you can't do any harm, and the practice will help you get comfortable with the process. On most systems, the Tab key auto-completes file paths as you type, so if you're changing to ~/people/marketing
, then all you need to type is cd ~/people/m
and then press Tab. If Tab is unable to complete the path, you know that you either have the wrong path or there are several directories with similar names, so your shell is unable to choose which to use for auto-completion.
Navigating in the terminal takes practice, but it is far faster than opening and closing windows, and clicking on Back buttons and folder icons, especially when you already know where you want to go. Give it a try!
Related Content
Important:This document may not represent best practices for current development. Links to downloads and other resources may no longer be valid.
The following sections discuss the file systems supported by OS X and the impact they can have on application performance.
Supported File Systems
OS X supports a variety of file systems and volume formats, including those listed in Table 1. Although the primary volume format is HFS Plus, OS X can also boot from a disk formatted with the UFS file system. Future versions of OS X may be bootable with other volume formats as well.
File System | Description |
---|---|
HFS | Mac OS Standard file system. Standard Macintosh file system for older versions of Mac OS. |
HFS Plus | Mac OS Extended file system. Standard Macintosh file system for OS X. |
UFS | Unix File System. A variant of the BSD “Fast File System.” |
WebDAV | Used for directly accessing files on the web. For example, iDisk uses WebDAV for accessing files. |
UDF | Universal Disk Format. The standard file system for all forms of DVD media (video, ROM, RAM and RW) and some writable CD formats. |
FAT | The MS-DOS file system, with 16- and 32-bit variants. |
SMB/CIFS | Used for sharing files with Microsoft Windows SMB file servers. |
AFP | AppleTalk Filing Protocol. The primary network file system for all versions of Mac OS. |
NFS | Network File System. A commonly-used BSD file sharing standard. OS X supports NFSv2 and NFSv3 over TCP and UDP. |
FTP | A file system wrapper for the standard Internet File Transfer Protocol. |
Linux File System
Accessing File-System Data
Filesystem For Linux And Mac Operating System
Every file system stores metadata about the files in the file system. This metadata describes the file but is not part of the file itself. The metadata for a file can include attributes such as Mac OS file type information, BSD-style file access permissions, and creation and modification dates. Because of the differences in how file systems store this data, accessing metadata can be a potentially expensive operation on some file systems.
It’s important to realize that if a piece of data is not immediately present in the file system, that information might have to be calculated. Retrieving file-system information is a time-consuming operation as it is, but if the information must be calculated or read separately from disk, it becomes even more time-consuming. The valence of a directory—the number of items in that directory—is a typical example of information that must be calculated on most file systems.
When calling file-system routines, you should always carefully consider what information you actually need and request only that information. For example, a single call to PBGetCatInfoSync
returns Finder file type information from a file or folder. On HFS and HFS Plus file systems, the penalty for retrieving this metadata is minimal because it is stored in the file’s catalog node and read into memory along with the file name. However, on other file systems, this data may have to be read separately, incurring another read operation. Instead of PBGetCatInfoSync
, you should have used FSGetCatalogInfo
or PBGetCatalogInfoSync
and specified exactly which pieces of information you wanted.
View Linux Filesystem In Windows
Linux Filesystem Commands
Copyright © 2003, 2014 Apple Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2014-03-10