this post was submitted on 18 Jan 2024
744 points (99.1% liked)

Linux

48927 readers
920 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
 

Timothée Besset, a software engineer who works on the Steam client for Valve, took to Mastodon this week to reveal: “Valve is seeing an increasing number of bug reports for issues caused by Canonical’s repackaging of the Steam client through snap”.

“We are not involved with the snap repackaging. It has a lot of issues”, Besset adds, noting that “the best way to install Steam on Debian and derivative operating systems is to […] use the official .deb”.

Those who don’t want to use the official Deb package are instead asked to ‘consider the Flatpak version’ — though like Canonical’s Steam snap the Steam Flatpak is also unofficial, and no directly supported by Valve.

you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 1 points 11 months ago (1 children)

I still don’t understand why everyone was so against static linking before the advent of Snaps/Flatpaks, but are now sooo into them. Windows software devs have been doing this for decades. Link statically and compress with UPX or whatever.

Security is one aspect. You are distributing all the dependencies with your binary now, if a vulnerability is found in any of those dependencies you're going to have to push out a new build instead of your OS providing you with an updated library.

Memory and storage are the other reasons. Libraries can be shared between running applications, loaded into memory once and stored on disk once. Modern hardware is so powerful now that memory and storage are nothing like the limitations that they once were.

[–] 0x4E4F 1 points 11 months ago

Security is one aspect. You are distributing all the dependencies with your binary now, if a vulnerability is found in any of those dependencies you're going to have to push out a new build instead of your OS providing you with an updated library.

The same thing is going on now with Snap/Flatpak. They don't use system libs, they use their own integrated ones. If a lib has a security issue embedded in the app, the app developer has to make a new build. But, even if the developer doesn't make a new build, that is the only app that is vulnerable, your distro will push a new build in the repos probably a lot sooner than the dev of that app.

As I said, Windows devs have been doing this for ages. Why? DLL hell is one reason, the other is "everything just works out of the box" (no end user late night calls after deployment). This was a security nightmare, I agree, but the alternative was a lot more work (make sure every user out there have those exact dependencies installed which work with your app)... not to mention this scenario: MS pushes a new version of that dll in an update or a redistributable, and guess what, your app doesn't work with that version 😒. Great, now I gotta debug to see what the reason is. What if the buyer doesn't want to pay you for this update? It has happened. It's not my fault that MS pushed this.

We've had a situation where specific versions of C++ runtimes had to be installed because the software just doesn't work with the latest ones. Not to mention hunting down those specific versions is a PITA. And even then there were problems. In the end, a redist repack of every version there is under the sun was the only solution that worked 100%. Mind you, this software works with AD, so it's not something run locally, this thing uses TCP/IP.