I’ve been setting up a new Proxmox server and messing around with VMs, and wanted to know what kind of useful commands I’m missing out on. Bonus points for a little explainer.
Journalctl | grep -C 10 'foo' was useful for me when I needed to troubleshoot some fstab mount fuckery on boot. It pipes Journalctl (boot logs) into grep to find ‘foo’, and prints 10 lines before and after each instance of ‘foo’.
redshift -O 5000: ‘redshift’ is a utility that adjusts the color temperature of your display, ‘-O’ allows you to set a specific temperature, and ‘5000’ is what I like.Edit: I also like
xkill. xkill lets you click on a window or program and kills it. I need to do this frequently every time exit Kodi; the program stops, but the window is still there.I use $_ a lot, it allows you to use the last parameter of the previous command in your current command
mkdir something && cd $_
nano file
chmod +x $_As a simple example.
If you want to create nested folders, you can do it in one go by adding -p to mkdir
mkdir -p bunch/of/nested/folders
Good explanation here:
https://koenwoortman.com/bash-mkdir-multiple-subdirectories/qSometimes starting a service takes a while and you’re sitting there waiting for the terminal to be available again. Just add --no-block to systemctl and it will do it on the background without keeping the terminal occupied.
systemctl start --no-block myservice
For interactive editing, the keybind
alt+.inserts the last argument from the previous command. Using this instead of $_ has the potential to make your shell history a little more explicit. (vim $_isn’t as likely to work a few commands later, butvim actual_file.shmight)You can also press
alt+.multiple times to cycle through all recent argumentsYes, definitely and I do run into that when I search my history
I just press M-.
I’m not sure what you mean. I gave 3 different commands…
You can use M-. instead of $_ to insert last param of last command. You can also access older commands’ param by repeated M-. just like you would do for inserting past commands with up arrow or C-p
I really hope I remember this one long enough to make it a habit
I have my .bashrc print useful commands with a short explanation. This way I see them regularly when I start a new session. Once I use a command enough that I have it as part of my toolkit I remove it from the print.
That is really useful! Thanks for the tip!
Ctrl-z to suspend the running program.
bgto make it continue running in the background.jobsto get an overview of background programs.fgto bring a program to the foreground.and
disownto keep background jobs alive when you close the terminal.
parallel, easy multithreading right in the command line. This is what I wish was included in every programming language’s standard library, a dead simple parallelization function that takes a collection, an operation to be performed on the members of that collection, and optionally the max number of threads (should be the number of hardware threads available on the system by default), and just does it without needing to manually set up threads and handlers.inotifywait, for seeing what files are being accessed/modified.tail -F, for a live feed of a log file.script, for recording a terminal session complete with control and formatting characters and your inputs. You can then cat the generated file to get the exact output back in your terminal.screen, starts a terminal session that keeps running after you close the window/SSH and can be re-accessed withscreen -x.Finally, a more complex command I often find myself repeatedly hitting the up arrow to get:
find . -type f -name '*' -print0 | parallel --null 'echo {}'Recursively lists every file in the current directory and uses parallel to perform some operation on them. The
{}in the parallel string will be replaced with the path to a given file. The'*'part can be replaced with a more specific filter for the file name, like'*.txt'.I can recommend tmux also as an alternative to screen
should be the number of hardware threads available on the system by default
No, not at all. That is a terrible default. I do work a lot on number churning and sometimes I have to test stuff on my own machine. Generally I tend to use a safe number such as 10, or if I need to do something very heavy I’ll go to 1 less than the actual number of cores on the machine. I’ve been burned too many times by starting a calculation and then my machine stalls as that code is eating all CPU and all you can do is switch it off.
I get a lot of mileage out of the line editing commands. I think they are Emacs based and optional… but like Ctrl k, Ctrl u, Ctrl a.
I usually set vi mode to have vi(m)-like line editing but I’ve always liked Ctrl+u over Esc d d. Thankfully it still works even with vi mode enabled. Seems to also be implemented as a shortcut for a lot of login managers and in DEs for settings menus, dialog boxes and such.
It’s funny, I love vim and have never understood Emacs, but when setting up a shell it seems the Emacs commands felt more natural.
A couple I use (concept of not exact), that I haven’t seen in the thread yet:
Using grep as diff:
grep -Fxnvf orig.file copy.fileUsing
xargs-xargs reads items from the standard input, delimited by blanks (which can be protected with double or single quotes or a backslash) or newlines, and executes the command (default is /bin/echo) one or more times with any initial-arguments followed by items read from standard input.
EG:
$ find ~/Pictures -name "*.png" -type f -print0 | xargs -0 tar -cvzf images.tar.gzI’m not much of a one-liner collector but I like this one:
vim +copen -q <(grep -r -n <search> .)which searches for some string and opens all instances in vim’s quickfix list (and opens the quickfix window too). Navigate the list with
:cnand:cn. Complex-ish edits are the obvious use case, but I use this for browsing logs too.Neovim improves on this with
nvim -q -and[q/]q, and plenty of fuzzy finder plugins can do a better version using ripgrep, but this basic one works on any system that has gnu grep and vim.Edit:
This isn’t exactly a command, but I can’t imagine not knowing about this anymore:
$ man grep / -n # double space before the dash!brings you directly to the documentation of the
-noption. Not the useless synopsis or any other paragraphs that mention-nin passing, but the actual doc for this option (OK, very occasionally it fails due to word wrap, but assuming the option is documented then it works 99% of the time).@marighost I dont use Prox, but for various random linux commands… ive got a wealth. :D in the journalctl vein.
journalctl -xeu \<service name\>ex:
journalctl -xeu httpdGives you the specific journal output for the given service. In this example. httpd.
Also,
journalctlis more than boot logs, its all of your logs from anything controlled by systemd. Mounts, services, timers, even sockets.For example. On my system, i have /var/home as a mount.
systemctlandjournalctlcan give me info on it with:systemctl status var-home.mount
journalctl -xeu var-home.mountYou can see all of the mounts with.
systemctl list-units --type=mountOr, see all of your services with
systemctl list-units --type=serviceOr all of your timers with
systemctl list-timersWe do a weekly show on getting into linux terminals, commands, tricks, and share our experience… It’s called Into the Terminal. on the Red Hat Enterprise Linux youtube channel. I’ll send you a link if you’re interested.
Deleted comment.
I double posted as Mlem didn’t show my initial comment after posting for some reason.
(Edit)
woh
I double posted as Mlem didn’t show my initial comment had posted.
I should have done an edit delete.
lol I just wanted people to question what was said.
Various uses of “find” in particular. “xargs” sometimes too. The capabilities of “bash” in general including scripting and the whole redirection, piping, and multiprocessing capabilities in particular.
when I forget to include sudo in my command:
sudo !!Also if you make a typo you can quickly fix it with ^, e.g.
ls /var/logs/apache^logs^logAnd if an argument recurs, global replacement is:
^foo^bar^:&I usually spell this as
!!:gs/foo/bar/(in bash). Is there a functional difference?!command history can also take line and word selectors. I type something like!-2:2surprisingly often.I honestly have no idea! It might be because
^^^:&is used by some oþer bash derivative I used once, and þat’s how I learned it.Yeah, I use !-# a bunch too, just not wiþ global replacement. I’m most often just redo-ing some action wiþ a couple of file extensions.
Similar-ish for quickly editing last command:
fc
To add to this one, it also supports more than just the previous command (which is what !! means), you can do like
sudo !453to run command 453 from your history, also supports relative like!-5. You can also use without sudo if you want which is handy to do things like!lsfor the last ls command etc. Okay one more, you can add:pto the end to print the command before running it just in case like!systemctl:pwhich can be handy!Absolutely wild stuff, there. Thanks for knowledge sharing!
Hah I am glad it was helpful! Glad to share, I always felt like half the point of learning is to share what you learned. That is one of my favorite “hidden gems” for lack of a better term that can be a real time saver.
Bonus just for more fun: you can use
cd -to switch back to the directory you were last in after changing directories, it toggles the top two paths in the stack. It is similar to how pushd/popd work if you have you used those. I use that one a ton, there are fancier tools now but that one works everywhere.Oh also, anyone on a Mac needs to know about pbcopy, Linux has xclip and I don’t remember what the Wayland analog is.
I learned about this through Bread On Penguins, she did a vid on useful commands
with zsh, you can use it, and then press space to have the !! replaced by the previous command to be able to edit it :)
You can do this on bash too if you add
bind Space: magic-spaceto your bashrc/profile
I forget where I got it. But mine will do this if I double tap ESC after I sent the command without sudo. Very useful.
I should probably figure out what it was I added to do this.
Doesn’t issue the command. Have to hit enter. Useful to verify it’s the right command first.
With the way bash history can work Id be worried about running sudo rm -rf ./* by mistake.
Just use thefuck. My alias is set to “fu” for work. It’s amazing.
If you use
fish, you just need to pressAlt+S.
It isn’t a command but an application. I cannot do my work without it.
screenI prefer tmux, but yes. Both do a great job in helping me manage my terminal sessions.
tmux is based
Tmux is good because I can have a little window with a bonsai in it and another little window for the matrix. Sometimes I even leave a window for typing in commands.
Based is fetch.
Stop trying to make fetch happen
What can I say. I’m old.
Scrolling in screen is superior to tmux imo
Scrolling is tmux is what I hate about it. I would prefer to use tmux since I’m use to it. But if someone can explain to me why I can’t just use my scroll wheel on my mouse.
As I understand it, the issue is that tmux invents its own terminal emulator functionality that conflicts with the existing terminal it runs within, while screen simply defers scroll functionality to the terminal emulator.
are you using a maintained alternative? Distros started to remove it from their repos years ago because it was not maintained anymore afaik
I have no idea where you got that from. 5.0.1 is from August 2025.
maybe they resumed development then, it was removed from Ubuntu and RHEL repos about 5 years ago when I had to look for an alternative
ctrl+r on bash will let you quickly search and execute previous commands by typing the first few characters usually.
it’s much more of a game changer than it first meets the eye.
And I believe shift+r will let you go forward in history if you’re spamming ctrl+r too fast and miss whatever you’re looking for
Just tested this out, it’s ctrl+shift+r
I only recently started using
C-rto search in the command history. Game changer!Want an even bigger game changer? fzf combined with control-r.
Enjoy.
https://atuin.sh/ does one better: history with context: $PWD, $HOST, time. There’s a bunch of other bells and whistles, but they’re easy to ignore to get an noninvasive upgrade to ctrl+R
This guy searches!
Yessir! Fzf is pretty much indispensable to me now.
Never seen ads in a read me before
Those projects contribute the bulk of funds for the development of fzf.
It’s normal to credit them and I’ve seen that done on multiple open source projects.
Credit ≠ Ads
Those are ads. It’s cringe.
Ok. Let’s go with it being ads. It’s a free open source project that’s absolutely worth using. Are you going to crucify them for it? Wanna donate for its development?
If they show me ads to donate? Fuck no.
The watch command is very useful, for those who don’t know, it starts an automated loop with a default of two seconds and executes whatever commands you place after it.
It allows you to actively monitor systems without having to manually re-run your command.
So for instance, if you wanted to see all storage block devices and monitor what a new storage device shows up as when you plug it in, you could do:
watch lsblkAnd see in real time the drive mount. Technically not “real time” because the default refresh is 2 seconds, but you can specify shorter or longer intervals.
Obviously my example is kind of silly, but you can combine this with other commands or even whole bash scripts to do some cool stuff.
Ooooh cool, I think this explains how they have our raid monitor set up at work! I keep forgetting to poke through the script
Yeah, it’s a neat little tool. I used it recently at my work. We had a big list of endpoints that we needed to make sure were powered down each night for a week during a patching window.
A sysadmin on my team wrote a script that pinged all of the endpoints in the list and returned only the ones that still were getting a response, that way we could see how many were still powered on after a certain time. But he was just manually running the script every few minutes in his terminal.
I suggested using the watch command to execute the script, and then piping the output into the sort command so the endpoints were nicely alphabetical. Worked like a charm!




















