this post was submitted on 09 Apr 2024
314 points (98.8% liked)

Linux

48207 readers
710 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 5 years ago
MODERATORS
 

I thought I'll make this thread for all of you out there who have questions but are afraid to ask them. This is your chance!

I'll try my best to answer any questions here, but I hope others in the community will contribute too!

you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 21 points 7 months ago* (last edited 7 months ago) (15 children)

Why do programs install somewhere instead of asking me where to?

EDIT: Thank you all, well explained.

[–] [email protected] 5 points 7 months ago (7 children)

I wish every single app installed in the same directory. Would make life so much easier.

[–] [email protected] 8 points 7 months ago (3 children)

They do! /bin has the executables, and /usr/share has everything else.

[–] [email protected] 4 points 7 months ago* (last edited 7 months ago)

They do! /bin has the executables, and /usr/share has everything else.

Apps and executables are similar but separate things. An app is concept used in GUI desktop environments. They are a user-friendly front end to one or more executable in /usr/bin that is presented by the desktop environment (or app launcher) as a single thing. On Linux these apps are usually defined in a .desktop file. The apps installed by the Linux distribution's package manager are typically in /usr/share/applications, and each one points to one of the executables in /usr/bin or /usr/libexec. You could even have two different "apps" launch a single executable, but each one using different CLI arguments to give the appearance of different apps.

The desktop environment you use might be reconfigured to display apps from multiple sources. You might also install apps from FlatHub, Lutris, Nix, Guix, or any of several other package managers. This is analogous to how in the CLI you need to set the "PATH" environment variable. If everything is configured properly (and that is not always the case), your desktop environment will show apps from all of these sources collected in the app launcher. Sometimes you have the same app installed by multiple sources, and you might wonder "why does Gnome shell show me OpenTTD twice?"

For end users who install apps from multiple other sources besides the default app store, there is no easy solution, no one agreed-upon algorithm to keep things easy. Windows, Mac OS, and Android all have the same problem. But I have always felt that Linux (especially Guix OS) has the best solution, which is automated package management.

[–] [email protected] 2 points 7 months ago (1 children)

Not all. I've had apps install in opt, flatpaks install in var out of all places. Some apps install in /etc/share/applications

[–] [email protected] 1 points 7 months ago (1 children)

In /etc? Are you sure? /usr/share/applications has your system-wide .desktop files, (while .local/share/applications has user-level ones, kinda analogous to installing a program to AppData on Windows). And .desktop files could be interpreted at a high level as an "app", even though they're really just a simple description of how to advertise and launch an application from a GUI of some kind.

[–] [email protected] 1 points 7 months ago (1 children)

OK, that was wrong. I meant usr/share/applications. Still, more than one place.

[–] [email protected] 3 points 7 months ago

The actual executables shouldn't ever go in that folder though.

Typically packages installed through a package manager stick everything in their own folder in /usr/lib (for libs) and /usr/share (for any other data). Then they either put their executables directly in /usr/bin or symlink over to them.

That last part is usually what results in things not living in a consistent place. A package might have something that qualifies as both an executable and a lib, so they store it in their lib folder, but symlink to it from bin. Or they might not have a lib folder, and just put everything in their share folder and symlink to it from bin.

[–] [email protected] 1 points 7 months ago

There is also /sbin or /usr/sbin, for executables only available to the superuser.

load more comments (3 replies)
load more comments (10 replies)