Show HN: I wrote a modern Command Line Handbook

297 petr25102018 80 5/29/2025, 2:44:33 PM commandline.stribny.name ↗
TLDR: I wrote a handbook for the Linux command line. 120 pages in PDF. Updated for 2025. Pay what you want.

A few years back I wrote an ebook about the Linux command line. Instead of focusing on a specific shell, paraphrasing manual pages, or providing long repetitive explanations, the idea was to create a modern guide that would help readers to understand the command line in the practical sense, cover the most common things people use the command line for, and do so without wasting the readers' time.

The book contains material on terminals, shells (compatible with both Bash and Zsh), configuration, command line programs for typical use cases, shell scripting, and many tips and tricks to make working on the command line more convenient. I still consider it "an introduction" and it is not necessarily a book for the HN crowd that lives in the terminal, but I believe that the book will easily cover 80 % of the things most people want or need to do in the terminal.

I made a couple of updates to the book over the years and just finished a significant one for 2025. The book is not perfect. I still see a lot of room for improvement, but I think it is good enough and I truly want to share it with everyone. Hence, pay what you want.

EXAMPLE PAGES: https://drive.google.com/file/d/1PkUcLv83Ib6nKYF88n3OBqeeVff...

https://commandline.stribny.name/

Comments (80)

mtlynch · 14h ago
Cool book!

Humble suggestion: Give more specific examples of what the reader will learn on the landing page. From the landing page, I don't know if this is for total command line beginners or has helpful tips for people familiar with bash already. I had to hunt around to find sample pages, and they provided much better sense of what's in the book.

Also, spotted some small issues in the copy:

"Fresh out of press" - The more common expression is "hot off the press." "Out of press" sounds similar to "out of print" (i.e., no longer sold)

"Grok the Linux command line on only 120 pages" - should be "in only 120 pages"

petr25102018 · 14h ago
True, the landing page could be more detailed. I didn't want to repeat much the info on Gumroad page, but maybe I should rethink it.

And thanks for the copy suggestions. I am not a native speaker :)

rubit_xxx17 · 4h ago
I’m excited about this book and appreciate your work!

One thing that was distracting was the large title font when I tried to view this site in portrait mode on mobile, as some of the letters are cut off. If that could be fixed, it would help ensure people stay engaged and read it.

You could also potentially use an LLM or something like Grammarly to help proofread it (not edit it).

This is very cool!

petr25102018 · 2h ago
Thank you!

Yes, as other people pointed out too, the landing page could do with some mobile and copy improvements.

frosting1337 · 5h ago
I definitely think you should add more info to the landing page - I had no idea there was further information on the Gumroad page.
charlie-83 · 14h ago
Cool, couple of comments. The website it a bit broken on mobile (at least for me) since text goes off the screen. Second, it would be good to have some sample pages or at least a page of contents so people can see the level of detail the book is aimed at. I know I could just get the book for free and then pay later but that kind of a faff and I feel bad choosing $0 for these kinds of things.
petr25102018 · 14h ago
Thanks for the feedback. I was trying to make it work on mobile but maybe I didn't test it well in the end.

As for a sample, I will go and try to make something now. Thanks.

Edit: Example pages here: https://drive.google.com/file/d/1PkUcLv83Ib6nKYF88n3OBqeeVff...

PeterWhittaker · 11h ago
One nit: ^D only exits if the cursor is at the beginning of a line. Enter <space>^D and the session remains.

Otherwise, looks good! Use of "env" and proper quoting are strong signals!

petr25102018 · 5h ago
Thanks for the clarification. I will see if I can sneak in a note about this in the next update :)
pipes · 9h ago
I agree with all this. I'm on Firefox android, pixel, lose part of the screen too.

I'd love to read a table of contents. I don't want to rip you off with zero dollars!

Anyway, sounds like a great book. Congratulations on completing and "shipping"!

petr25102018 · 6h ago
> I agree with all this. I'm on Firefox android, pixel, lose part of the screen too.

Ah okay, I really wasn't aware. Thanks for reporting.

jaredhallen · 8h ago
I am also seeing text off the screen using Brave on Android.
petr25102018 · 6h ago
You are right. It is wrong, will need to look into this.
curtgrimes · 1h ago
These two tweaks should improve it (by preventing the largest text and book graphic from overflowing the viewport horizontally on some smaller screen sizes):

  diff --git a/index.html b/index.html
  index a0f978c..040e50e 100644
  --- a/index.html
  +++ b/index.html
  @@ -21,3 +21,3 @@
         h1 {
  -        font-size: 3.8em;
  +        font-size: clamp(2.2em, 7vw, 3.8em);
           margin-bottom: 0;
  @@ -60,2 +60,3 @@
         .hero-img {
  +        max-width: 100%;
           transform: rotate(2deg);
  
Also, I really like what I see in your book so far and I am already learning things on the first few pages. Thanks!
petr25102018 · 14h ago
justusthane · 11h ago
I consider myself reasonably proficient in the shell, but I learned something just from your sample pages (process substitution). Purchased!
petr25102018 · 11h ago
Thanks!
teddyh · 10h ago
If you have not skimmed through the manual of bash¹ enough to learn about process substitutions, what makes you think you would read a book?

1. <https://www.gnu.org/software/bash/manual/bash.html>

justusthane · 9h ago
Because generally a manual is “here is every single detail of this thing”, while a book like this is “here’s an overview of the particularly useful stuff.”

I’ll go to the manual if I’m trying to understand how a particular thing works, or how to do a particular thing, but it’s not as useful to me for feature discovery.

mtlynch · 9h ago
Different people prefer different formats for information. Some people prefer to read the manual from start to finish while others learn better seeing the same concepts in a hands-on tutorial.

From reading the sample of OP's book, it seems far more practical and accessible than the bash manual, so I'm not surprised that a lot of people would read OP's book that have no interest in reading the bash manual cover to cover.

cortesoft · 9h ago
Maybe because they didn't think to?
jcynix · 11h ago
Hmm, the example page doesn't convince me, for example

> The diff utility can compare files and print their differences. If we pass it the result of ls commands, we can compare the contents of directories.

No, if you pass the output of ls commands, you might get an error because you'll pass a bunch of files to diff.

And last but not least there's

    diff -r directory-a directory-b
to compare two directories file by file.
sureglymop · 6h ago
I think it was about demonstrating process substitution. You don't pass a bunch of files to diff, you pass the output of ls, as a file, to diff.

I actually thought it was awesome to see that. I use this a lot to diff the output of commands and many people don't know about it.

petr25102018 · 11h ago
I wanted to demonstrate the use of the substitution, not the best way to diff directories. Often I tried to create examples that demonstrate multiple concepts or tools at once to save space. But I see your point.
asicsp · 1h ago
I wrote interactive TUI apps with exercises for Linux CLI tools, coreutils, grep, sed and awk: https://github.com/learnbyexample/TUI-apps
briandoll · 8h ago
Folks interested in this will also appreciate The Shell Haters Handbook: https://shellhaters.org/deck/
MaggieL · 2h ago
Also don't miss https://wizardzines.com/
dkarl · 11h ago
Is your focus on older tools that tend to be on most machines and used in older shell scripts (e.g., find and grep), or on newer and upgraded tools (fd, fzf, rg) that developers install on their own machines, or both?
petr25102018 · 11h ago
The older standard tools, because they can be easily put in CI pipelines and shared as scripts with coworkers.

For example, in my personal and professional life I use Make everywhere. The book mentions alternatives, but the examples are built on the time-tested tools.

I focused on things that don't require install (if given the option) or the ones that you are more likely to encounter at work. It is a tradeoff and I can see how the reverse would be appealing too.

cerved · 10h ago
<3 GNU Make
ontouchstart · 8h ago
Make is a powerful self-documentable tool. It can hide tons of complicated dependencies implementation details behind a simple and universal CLI.
subjectsigma · 7h ago
If you want to use make, power to you, it’s definitely a useful tool. (What I’m trying to say is I’m bashing make, not you.)

That being said, I absolutely hate make, there are so many footguns and weird quirks and implicit behavior that always end up biting me.

I find that 90% of the time what I actually want is a command runner like Just (https://github.com/casey/just) and have the make file contain the absolute sheer minimum required to build code.

While we’re at it, CMake is another build tool with the same problems as make - powerful, with an ugly syntax, unintuitive semantics, hidden dragons, and a manual that’s torturous to read.

petr25102018 · 5h ago
I agree too, Just (and others) are better as a pure entry point. But when you come to projects that already have Makefiles, or you know you have just one less thing to install in a container... you use Make.
0x62 · 3h ago
The content seems really great, however the typesetting makes it quite hard to read:

* Code blocks on a subsequent page to the explanation, especially when there is enough space to show it (p18/19)

* Call-outs as above (p26/27)

* Single words broken by a page (p51/52)

* Footers spanning multiple pages (p61/62)

It sounds quite nitpickey but I find it really breaks the flow when I’m reading, and trying to comprehend a section requires scrolling back and forth between two pages.

petr25102018 · 2h ago
Thanks for the feedback.

I agree and I try to keep it as nice as I can, but it can be hard to do when the book is being updated and the content changes.

Nevertheless I will be mindful of it for the next update.

sagarpatil · 2h ago
Just bought it. Any advice on how to use the book to master the terminal? One page a day or try to finish everything in a week or two?
petr25102018 · 1h ago
I definitely recommend to try things as you go along, copy paste things and run them yourself. As for the timeline, everyone is different. My own take is that learning always takes time and repetition, so I would not rush it and focus on practice.
_joel · 9h ago
Nice work, I've been using linux 20+ years and learnt something from the example pages. (edit, just realised it's closer to 30 now, jesus)
petr25102018 · 5h ago
Thanks!
rochak · 10h ago
Good resource to couple this resource with: https://linuxjourney.com.
asicsp · 1h ago
See also this open source version inspired by that site: https://github.com/daquino94/linux-path
nickjj · 13h ago
How has the "pay what you want" model worked out if you don't mind me asking? It's something I've thought about in the past for selling courses.
petr25102018 · 13h ago
I just changed the payment model before posting it here, so there is no past data on this. I don't expect it to generate revenue compared to normal sales (it will most likely be a small fraction). But for normal sales you need to be able to promote it.

My primary motivation is to share the work that I spent a lot of time on because I want to move on and work on other things (I don't want it to just sit on my disk when it can be useful to others before getting outdated etc.). It never was meant to be some primary source of income. In that case I would be writing a book about AI :)

Maybe I will write a blog post with some reflections about making the book at some point :)

ctippett · 12h ago
I admire your mindset (and humility). Thanks for making this available.
MikeTheGreat · 11h ago
This is excellent! Thank you for posting and best wishes for your success with this!

I'm teaching a class next year that'll have college-level students learning to use the command line and this looks perfect. Nowadays most 'learn the shell' resources online seem to focus on how to write scripts, without explaining how to use it interactively. Given this will be (for many) their first experience with a command line stuff like "type your command, then press enter", or "Up arrow to go back through your history" are a necessary foundation for them. Not to mention stuff like Job Control and using AI to help you create the more complicated commands that folks need to do - nicely done!

Plus, the book is inexpensive enough that they can still afford other resources too :)

Definitely gonna recommend this next year :)

petr25102018 · 11h ago
Thank you for the nice words :)
jdshaffer · 1h ago
Looks nice! Purchased a copy. :-)
JulianWasTaken · 11h ago
Looks very nice!

I have an interactive tutorial I wrote and teach with which is here: https://github.com/JulianEducation/CommandLineBasics in case it's useful as well. I only have 90 minutes in my case so it's a constant battle to tweak what I can get to with my audience, so there's still lots of things I want to change.

But I think it's very important to have lots of resources here so I'm excited to look at yours.

petr25102018 · 5h ago
Thanks.

You teach this in a classroom?

JulianWasTaken · 2h ago
I do, it's given as a seminar twice a year.
petr25102018 · 2h ago
Nice! At least you get your feedback in real time, see what people struggle with and so on. That can be very useful.
catoc · 13h ago
Interested, but going to the website told me nothing other than a book about the command line. Would be nice be able to get a preview of a some pages/chapters.
petr25102018 · 13h ago
Noted. For now I put links here, in the comments, and in the Gumroad page to sample pages. I will need to change the homepage later. Thanks for the input!
dedicate · 14h ago
It makes me wonder – what's that one command or concept you CLI vets wish you'd learned way earlier that totally changed your game, something that might be in that 'next 20%'? Curious about those 'aha!' moments!
bionsystem · 3h ago
grep, sed, awk and regular expressions would probably be part of my 1st hour course if I were to produce one. And by awk I mean the super basic stuff like -F',' '{print $3" "$NF}' is already a long way

also any command | while read line; do something $line; done

and find and vi of course

smw · 7h ago

  bat     # cat with syntax highlighting
  zoxide  # keeps track of directories 
  tig     # ncurses git viewer
  atuin   # shell history across machines
  choose  # easier cut or "awk '{print $1}'"
  direnv  # set environment vars when you enter a directory
  fd      # better find
  fzf     # fuzzy find anything, total game changer
  gh      # GitHub client
  rg      # really fast recursive grep
petr25102018 · 11h ago
One of my favorites from the book is to alias "xdg-open" to "open" because I never remember the command. So now I can just type "open X" to open a file system location or file in a normal GUI program when needed. It is a small thing but I use it a lot.

Something that I didn't put in the book because I learned it only recently is the use of "notify-send", aka you can send yourself a system notification from the command line or script (at least it workd for me in Gnome). For instance once a task is finished:

> echo "when finished send notification" && notify-send "system notification"

Pretty cool if you ask me!

litoE · 7h ago
In my Linux install (Debian 12/Bookworm) /usr/bin/open is a symlink to /usr/bin/xdg-open so I was always using xdg-open without even knowing it.
petr25102018 · 5h ago
Great somebody thought of it!
magarnicle · 4h ago
These might seem basic but they made a huge difference when I learnt them:

  set -o vi
  set -o xtrace
  xargs, xargs -I
  parameter expansion (see the Parameter Expansion section in the bash manual)
  ctrl + r
  find -exec
  lsof
justusthane · 11h ago
Get really comfortable with find and grep. They’re incredibly powerful. perl -pe is way easier than awk.
jcynix · 11h ago
I'll second that. And would like to add that find plus xargs is important to know, as it often works much better than the clumsy "exec in find itself.

Oh, and thus of course

    find ... | xargs perl -lne "fancy stuff"
to do some fancy stuff with found files ;-)
calvinmorrison · 9h ago
the basics of awk and perl, these days jq as well.
bprater · 12h ago
Any alternatives to Gumroad in buying this?
petr25102018 · 11h ago
Not for now. But I am happy to send you the PDF by email and receive a donation via PayPal if the reason is not to fund Gumroad. Just contact me on petr@stribny.name or @stribny on X.
meonkeys · 11h ago
Why?
honkycat · 5h ago
#1 thing in command line shell scripting should be: "Do not use it for advanced scripts. If you have multiple if statements and for loops, rewrite it in a higher level language."

This is also the advice given in the google shell guide.

I say this after years of being a DevOps and Platform engineer. Bash is trash. It is great for 10-20 line scripts. Beyond that, it is worthless.

petr25102018 · 5h ago
I would not say it is trash, but I tend to agree with the general sentiment and personally don't write longer scripts.

> This is also the advice given in the google shell guide.

This advice is also given in this handbook :) But in reality you might come to a work repo that already has such scripts and it is good to understand it a little bit, I would think.

honkycat · 3h ago
"I might come to work on..."

Friend, you have no idea LOL

My hatred is well earned!

JLO64 · 14h ago
Honestly I would’ve liked to fork over cash for a book like this but the deal breaker for me is that it’s in PDF format. I like to read all of my books on a Kindle (with koreader installed) so epub files that can be resized to fit its weird dimensions are a must.
petr25102018 · 14h ago
Noted. I will try to provide alternative formats. Not sure how it will go with the code examples, but I shall try.

Edit: One reason why I picked PDF is that I expect the readers to actually follow the examples in their own terminal while going through the book. So in that sense I was thinking about reading it on the desktop.

InsideOutSanta · 14h ago
Yeah, same. On a phone or smaller e-reader, regular PDFs designed for normal book size are often unreadable.
rmahan · 13h ago
Have you tried pdf reflow with koreader? I find it works pretty well
username223 · 13h ago
That's a big ask. I've written a couple of books, and PDF/print vs. ePub/webpage is a decision I had to make up front. For anything with more than the most basic formatting (e.g. a novel), the design and layout are different enough that one of them will turn out looking like crap. Given the audience, I probably would have chosen ePub for this one, but the book's done now.

Also, a TOC and sample chapter would be great. A lot more people will be likely to pay if they know what they're getting.

petr25102018 · 13h ago
Honestly I haven't tried yet. Maybe Asciidoctor (Which I used) has it figured out. It would at least need to have good enough output for the code examples, otherwise it would probably be a non-starter.

I added links to example pages (which include TOC) to the Gumroad page and here, but yeah I should have put it on the homepage.

reaperducer · 8h ago
Honestly I would’ve liked to fork over cash for a book like this but the deal breaker for me is that it’s in PDF format. I like to read all of my books on a Kindle

When I made my purchase, the options were Download and Send to Kindle. It's not ePub, but it's something.

sillyboi · 12h ago
Sorry, but it would be great to adapt it for the mobile layout.
petr25102018 · 12h ago
Do you mean the website or are you talking about the book PDF?
KasianFranks · 11h ago
Ahh yes, the lost art of UNiX sys admin always comes back.
shivajikobardan · 3h ago
There was no need of this book.