Is there a good, modern, widely accepted, learning Linux resource? - eviltoast

I’ve always approached learning Linux by just diving into it and bashing my head against problems as they come until I either solve them or give up, the latter being the more common outcome.

I wouldn’t take this approach with other pieces of software though - I’d read guides, best practices, have someone recommend me good utility tools or extensions to install, which shortcuts to use or what kind of file hierarchy to use, etc.
For example, for python I’d always recommend the “Automate the boring stuff with Python”, I remember learning most Java with that “Head first Java” book back in the days, c# has really good official guides for all concepts, libraries, patterns, etc.

So… lemme try that with Linux then! Are there any good resources, youtube videos, bloggers or any content creators, books that go explain everything important about linux to get it running in an optimal and efficient way that are fun and interesting to read? From things like how the file hierarchy works, what is /etc, how to install new programs with proper permissions, when to use sudo, what is a flatpak and why use it over something else, how to backup your system so you can easily reconstruct your setup in case you need to do an OS refresh, etc? All those things that people take for granted but are actually a huge obstacle course + minefield for beginners?

And more importantly, that it’s up to date with actually good advice?

  • Cyno@programming.devOP
    link
    fedilink
    arrow-up
    1
    ·
    edit-2
    2 months ago

    I want to use the terminal and I’d prefer the simplicity and reliability of a single command over various GUIs, but it doesn’t feel like it’s consistent or simple with the terminal either. For example with VSCode, it doesn’t have apt-get install vscode command (at least not listed on its installation pages) - it recommends manually downloading the deb file and then apt installing it.

    https://code.visualstudio.com/docs/setup/linux

    I just don’t know whats the proper / good way of doing it anymore. The popOS shop is horrible, you cant stop running installations cuz it freezes and stops giving any feedback, sometimes it breaks and doesn’t open fully, the UX is bad, but i dont know what else to do. At least with the shop I have a clear list of installed apps and a place to uninstall them, if i do it with the terminal I have no idea where they end up living.

      • Cyno@programming.devOP
        link
        fedilink
        arrow-up
        1
        ·
        edit-2
        2 months ago

        That gives me a list of over 2000 rows inside of the terminal that i cant apparently search or sort -.-

        Then I tried to be smart and do man dpkg -l to see if that has any options on how to use it better, and instead i got another huge text file that i cant search or navigate through properly

        So then i googled how to open it in an editor and tried man dpkg -l | nano, which does open it for a second and then crashes, i just get “too many errors from stdin, buffer written to nano.12608.save” in the terminal

        ofc something as simple as map dpkg -l | vscode doesnt work either

        I’m just tired

        • ericjmorey@programming.dev
          link
          fedilink
          arrow-up
          2
          ·
          2 months ago

          It can be exhausting to know just enough to see results that aren’t quite what you’re after, but not quite know enough to refine it to get what you want. And you’re supper close to it. Here’s some things to fill the gap (and correct a misunderstanding or two):

          gives me a list of over 2000 rows inside of the terminal that i cant apparently search or sort

          The dpkg -l command can be postfixed with a search pattern:
          dpkg -l lib* will return all packages with names that start with lib

          ||/ Name                                 Version                           Architecture Description
          +++-====================================-=================================-============-===============================>
          ii  libaa1:amd64                         1.4p5-46                          amd64        ASCII art library
          un  libabiword-3.0                       <none>                            <none>       (no description available)
          ii  libaccountsservice0:amd64            0.6.55-0ubuntu12~20.04.7          amd64        query and manipulate user accou>
          ii  libacl1:amd64                        2.2.53-6                          amd64        access control list - shared li>
          ii  libaio1:amd64                        0.3.112-5                         amd64        Linux kernel AIO access library>
          ii  libalgorithm-diff-perl               1.19.03-2                         all          module to find differences betw>
          ii  libalgorithm-diff-xs-perl            0.04-6                            amd64        module to find differences betw>
          ii  libalgorithm-merge-perl              0.08-3                            all          Perl module for three-way merge>
          ii  libamd2:amd64                        1:5.7.1+dfsg-2                    amd64        approximate minimum degree orde>
          ii  libamtk-5-0:amd64                    5.0.2-1build1                     amd64        Actions, Menus and Toolbars Kit>
          ii  libamtk-5-common                     5.0.2-1build1                     all          Actions, Menus and Toolbars Kit>
          un  libansicolor-perl                    <none>                            <none>       (no description available)
          ii  libapparmor1:amd64                   2.13.3-7ubuntu5.3                 amd64        changehat AppArmor library
          ii  libappindicator3-1                   12.10.1+20.04.20200408.1-0ubuntu1 amd64        Application Indicators
          ii  libappstream4:amd64                  0.12.10-2                         amd64        Library to access AppStream ser>
          un  libapt-inst1.5                       <none>                            <none>       (no description available)
          un  libapt-pkg                           <none>                            <none>       (no description available)
          un  libapt-pkg5.0                        <none>                            <none>       (no description available)
          ii  libapt-pkg6.0:amd64                  2.0.10                            amd64        package management runtime libr>
          un  libarchive-tar-perl                  <none>                            <none>       (no description available)
          un  libarchive1                          <none>                            <none>       (no description available)
          ii  libarchive13:amd64                   3.4.0-2ubuntu1.2                  amd64        Multi-format archive and compre>
          un  libarcus3                            <none>                            <none>       (no description available)
          ii  libargon2-1:amd64                    0~20171227-0.2                    amd64        memory-hard hashing function - >
          

          dpkg -l ?lib* will return all packages with names that have lib in the second third and fourth character positions.

          ||/ Name                     Version                  Architecture Description
          +++-========================-========================-============-====================================================
          ii  glib-networking:amd64    2.64.2-1ubuntu0.1        amd64        network-related giomodules for GLib
          ii  glib-networking-common   2.64.2-1ubuntu0.1        all          network-related giomodules for GLib - data files
          ii  glib-networking-services 2.64.2-1ubuntu0.1        amd64        network-related giomodules for GLib - D-Bus services
          un  glib-networking-tests    <none>                   <none>       (no description available)
          un  glibc-doc                <none>                   <none>       (no description available)
          ii  klibc-utils              2.0.7-1ubuntu5.1         amd64        small utilities built with klibc for early boot
          un  zlib1                    <none>                   <none>       (no description available)
          ii  zlib1g:amd64             1:1.2.11.dfsg-2ubuntu1.5 amd64        compression library - runtime
          

          Then I tried to be smart and do man dpkg -l to see if that has any options on how to use it better, and instead i got another huge text file that i cant search or navigate through properly

          Yeah, man pages are overwhelming at times. There are ways to navigate them in the terminal, but I would have to look that up because I pretty much never do that. It’s easier for me to just look it up online or open the text in an editor. Looks like you had the same idea with trying man dpkg -l | nano and man dpkg -l | vscode and you were so close to the end goal of reading the man page in a text editor!

          Here are two ways you can make it work:

          For both methods you will need to drop the -l so just use man dpkg.

          Method 1:

          Use the > operator to redirect the output of man dpkg to a file: man dpkg > dpkg.man
          (note that the file name after the > operator above can be anything you want the name of the file to be. I chose dpkg.man because it seemed like it would be easy to remember for me.)

          Then open the file using nano or vscode:
          nano dpkg.man
          code dpkg.man
          (note the name of the package for vscode is code)

          Method 2:

          Use the | operator to send the output of man dpkg to a nano filebuffer:
          man dpkg | nano

          Then open file that was saved when nano returned an error message. In your case:
          nano nano.12608.save
          code nano.12608.save
          (This second method feels a bit janky but it works.)

          Since you were talking about using apt-get and apt to manage packages, I’ll suggest nala as a more beginner friendly alternative that is more verbose and explicit about what it is doing. Give nala a try.

          I hope this helps and that you can return to learning how to get things done using Linux with renewed resolve now that you’ve had some time away from it.

          Keep asking questions! You’re probably learning more than you realize already.

          • Cyno@programming.devOP
            link
            fedilink
            arrow-up
            2
            ·
            2 months ago

            Thank you very much for such a detailed answer! This is exactly the type of stuff I wanted to learn in advance from some generalist tutorial because honestly, I feel bad constantly asking such basic questions and there’s no guarantee there will always be someone like you to answer them. In retrospect it’s probably the smarter and simpler option to just google the command docs online, I just wanted to do it “right” since I heard all the praise about man command and you never know if you’re working offline.

            I’ll check out nala, could be a good learning tool, thanks!

            • ericjmorey@programming.dev
              link
              fedilink
              arrow-up
              2
              ·
              edit-2
              2 months ago

              I find that books and resources on basics are hard to find motivation to get through. I don’t have a problem researching for an hour or two when I’m stuck on something that I want to accomplish, but that same information would be impossible for me to focus on if there’s no immediate motive to read it. Knowing that some information might generally come in handy later is often not enough for me to stick with it. So I don’t think people really mind helping people with “basic” questions, but their availability can unreliable.

              That said, there are a lot of good suggestions in both threads you started and if you can stick with any of them it will probably be a big boost for your comfort level in using Linux.

              I heard all the praise about man command and you never know if you’re working offline.

              Now you can open man pages in your favorite text editor with all the associated navigational conveniences!

              I’ll check out nala, could be a good learning tool, thanks!

              A lot of people who try nala never switch back to apt, I hope you find it more pleasant to use.