What do you advice for shell usage?
- Do you use bash? If not, which one do you use? zsh, fish? Why do you do it?
- Do you write
or
? Do you write fish exclusive scripts?
- Do you have two folders, one for proven commands and one for experimental?
- Do you publish/ share those commands?
- Do you sync the folder between your server and your workstation?
- What should’ve people told you what to do/ use?
- good practice?
- general advice?
- is it bad practice to create a handful of commands like
podup
andpoddown
that replacepodman compose up -d
andpodman compose down
orpodlog
aspodman logs -f --tail 20 $1
orpodenter
forpodman exec -it "$1" /bin/sh
?
Background
I started bookmarking every somewhat useful website. Whenever I search for something for a second time, it’ll popup as the first search result. I often search for the same linux commands as well. When I moved to atomic Fedora, I had to search for rpm-ostree
(POV: it was a horrible command for me, as a new user, to remember) or sudo ostree admin pin 0
. Usually, I bookmark the website and can get back to it. One day, I started putting everything into a .bashrc
file. Sooner rather than later I discovered that I could simply add ~/bin
to my $PATH
variable and put many useful scripts or commands into it.
For the most part I simply used bash. I knew that you could somehow extend it but I never did. Recently, I switched to fish because it has tab completion. It is awesome and I should’ve had completion years ago. This is a game changer for me.
I hated that bash would write the whole path and I was annoyed by it. I added PS1="$ "
to my ~/.bashrc
file. When I need to know the path, I simply type pwd
. Recently, I found starship which has themes and adds another line just for the path. It colorizes the output and highlights whenever I’m in a toolbox/distrobox. It is awesome.
#!/usr/bin/env bash
A folder
dotfiles
as git repository and adotfiles/install
that soft links all configurations into their places.Two files,
~/.zshrc
(without secrets, could be shared) and another for secrets (sourced by.zshrc
if exist secrets).This is the way!
why?
!/usr/bin/env
will look inPATH
forbash
, andbash
is not always in/bin
, particularly on non-Linux systems. For example, on OpenBSD it’s in /usr/local/bin, as it’s an optional package.If you are sure
bash
is in/bin
and this won’t change, there’s no harm in putting it directly in your shebang.
dotfiles
Thanks! I’ll check them out. I knew the cooncept existed but so far I didn’t dig deep into managing them. This is my start I guess https://wiki.archlinux.org/title/Dotfiles
I use bash for scripts almost exclusively even though i use zsh interactively (startup scripts for zsh are an obvious exception).
The vast majority of my scripts start with
set -e -u
which makes the script exit if a command (that is not in a few special places like an if) exits with an error status code and also complains about unbound variables when you use them.
Use
bash -n
and
shellcheck
to test your script for errors and problems if you try it.
Always use curly braces for variables to avoid issues with strings after the variable name being interpreted as part of the variable name.
Always use 10# before numbers in $(()) expressions to avoid leading zeroes turning your decimal number variables into octal ones.
Always use
while read -r foo do ... done < <(command ...)
instead of
command ... | while read -r foo do ... done
to avoid creating a subshell where some changes you make will not affect your script outside the loop.
In
while read -r foo do ... done < ...
loops always make sure you redirect all stdin from /dev/null or otherwise close it with suitable parameters or the content of your loop will eat some of the lines you meant for the read. Alternatively fill a bash array in the loop and then use a for loop to call your commands and do more complex logic.
When using temporary directories or similar resources use
cleanup() { ... } trap cleanup EXIT
handlers to clean up after the script in case it dies or is killed (by SIGTERM or SIGINT,…; obviously not SIGKILL).
When writing scripts for cronjobs take into account that the environment (PATH In particular) might be more limited. Also take into account that stderr output and non-zero exit status can lead to an email about the cronjob.
Use pushd and popd instead of cd (especially cd …), redirect their output to /dev/null. This will prevent your scripts from accidentally running later parts of the script in a wrong directory.
There are probably many other things to consider but that is just standard stuff off the top of my head.
If you do need any sort of data structure and in particular arrays of data structures use a proper programming language. I would recommend Rust since a compiled language is much easier to run on a variety of systems than the Python so many others here recommend, especially if you need to support the oldest supported version of an OS and the newest one at the same time.
Great list! I would add “always surround variables with quotes in case the value contains spaces”.
Good point, forgot one of the basics.
Also, to make your scripts more readable and less error prone use something like
if [[ $# -gt 0 ]] && [[ "$1" == "--dry-run" ]]; then dry_run=1 shift else dry_run=0 fi if [[ $# != 3 ]]; then echo "Usage: $0 [ --dry-run ] <description of foo> <description of bar> <description of baz>" >&2 exit 1 fi foo="$1" shift bar="$1" shift baz="$1" shift
at the start of your script to name your parameters and provide usage information if the parameters did not match what you expected. The shift and use of
$1
at the bottom allows for easy addition and removal of parameters anywhere without renumbering the variables.Obviously this is only for the 90% of scripts that do not have overly complex parameter needs. For those you probably want to use something like getopt or another language with libraries like the excellent clap crate in Rust.
Thank you very much!
- I use
bash
, because I never had the time to learn anything else. - Like @[email protected] said, I use the
shebang.
- Nope
- Also nope
- Nope. Shell scripts reside in Git repos on Gitlab/Gitea/Forgejo and are checked out using Ansible playbooks onto the servers as necessary.
- For scripts? Python. Read this blog post by the great @[email protected]. For interactive use?
bash
is just fine for me, though I’ve customized it using Starship and created some aliases to have colored/pretty output where possible. - Use
shellcheck
before running your scripts in production, err on the side of caution,set -o pipefail
. There are best practices guides for Bash, use those and you’ll probably be fine. - Be prepared to shave yaks. Take breaks, touch grass, pet a dog. Use
set -x
inside your Bash script orbash -x scriptname
on the CLI for debugging. Remember that you can always fallback to interactive CLI to test/prepare commands before you put them into your script. Think before you type. Test. Optimize only what needs optimization. Use long options for readability. And remember: Always code as if the guy who ends up maintaining your code will be a violent psychopath who knows your address. - Nope, it’s absolutely not bad practice to create aliases to save you some typing in interactive shell. You shouldn’t use them inside your scripts though, because they might/will not be available in other environments.
I switched to fish because it has tab completion Yeah, so does Bash, just install it.
Oh, I also “curate” a list of Linux tools that I like, that are more modern alternatives to “traditional” Linux tools or that provide information I would otherwise not easily get. I’ll post i
Tools
Debian-Packages available
- mtr
- iputils-tracepath
- iproute2
- zsh
- httpie
- aria2
- icdiff
- progress
- diffoscope
- atop
- powertop
- ntopng
- ethtool
- nethogs
- vnstat
- ss
- glances
- discus
- dstat
- logwatch
- swatch
- multitail
- lynis
- ncdu (du-clone), alias du=“ncdu --color dark -rr -x --exclude .git --exclude node_modules”
- nnn (fully-featured terminal file manager. It’s tiny, nearly 0-config and incredibly fast. https://github.com/jarun/nnn)
- slurm
- calcurse
- newsbeuter
- tig (“ncurses TUI for git. It’s great for reviewing and staging changes, viewing history and diffs.”)
- qalc -ttyrec
- taskwarrior
- ttytter
- ranger
- ipcalc
- pandoc
- moreutils
- googler
- weechat
- pdftk
- abcde
- dtrx
- tload
- ttyload
- cockpit
- sar
- ht (hte Hex Editor)
- dhex
- ack (grep-clone)
- silversearcher-ag (grep-clone)
- ripgrep (“recursively searches file trees for content in files matching a regular expression. It’s extremely fast, and respects ignore files and binary files by default.”, https://github.com/BurntSushi/ripgrep)
- exa (statt ls) https://the.exa.website/ (“replacement for ls with sensible defaults and added features like a tree view, git integration, and optional icons.”)
- fzf (CLI fuzzy finder), alias preview=“fzf --preview ‘bat --color "always" {}’”
- fd (simple, fast and user-friendly alternative to ‘find’, https://github.com/sharkdp/fd) -entr (watch-clone)
- csvkit (awk-clone)
- ccze (log coloring)
- surfraw -hexyl (“hex viewer that uses Unicode characters and colour”, https://github.com/sharkdp/hexyl) -jq (“awk for JSON. It lets you transform and extract information from JSON documents”, https://stedolan.github.io/jq/) -pass (“password manager that uses GPG to store the passwords”, https://github.com/lunaryorn/mdcat)
- restic (“backup tool that performs client side encryption, de-duplication and supports a variety of local and remote storage backends.”, https://restic.net/)
- mdp (Markdown Presentation on CLI) -grepcidr
- qrencode
- caca-utils (show images on the CLI)
- fbi ( & fbgs) (show images in Framebuffer device)
- fbcat (take screnshot on framebuffer device)
- nmap
- micro (CLI Text Editor, ab Debian 11, https://micro-editor.github.io)
- masscan (https://github.com/robertdavidgraham/masscan)
- socat (Nachfolger von netcat, https://www.heise.de/select/ix/2017/11/1509815804306324)
- dc3dd (patched version of GNU dd with added features for computer forensics)
- smem (memory reporting tool)
- free (Show Linux server memory usage)
- mpstat (Monitor multiprocessor usage on Linux, part of sysstat package)
- pmap (Montor process memory usage on Linux, part of the procps)
- monit (Process supervision)
- oping & noping
- saidar (Curses-basiertes Programm für die Anzeige von Live-Systemstatistiken)
- reptyr (Tool for moving running programs between ptys)
- gron (https://github.com/tomnomnom/gron, makes JSON greppable, kann HTTP-Requests absetzen)
- jc (https://github.com/kellyjonbrazil/jc, CLI tool and python library that converts the output of popular command-line tools and file-types to JSON or Dictionaries. This allows piping of output to tools like jq and simplifying automation scripts.)
- bat (cat-clone), alias cat=‘bat’ (“alternative to the common (mis)use of cat to print a file to the terminal. It supports syntax highlighting and - git integration.”, https://github.com/sharkdp/bat)
- ioping (https://github.com/koct9i/ioping, simple disk I/0 latency measuring tool, auch für disk seek rate/iops/avg)
- vd (Visidata, multipurpose terminal utility for exploring, cleaning, restructuring and analysing tabular data. Current supported sources are TSV, CSV, fixed-width text, JSON, SQLite, HTTP, HTML, .xls, and .xlsx)
- pdfgrep
- duf https://github.com/muesli/duf (combined df and du, ncurses-based)
- nala (apt-alternate, https://gitlab.com/volian/nala, https://christitus.com/stop-using-apt/)
- iprange
- tldr
- rmlint
- nvtop (https://github.com/Syllo/nvtop, GPUs process monitoring for AMD, Intel and NVIDIA)
- lf (lf (as in “list files”) is a terminal file manager written in Go with a heavy inspiration from ranger file manager)
no Deb pkg avail
- oh-my-zsh (http://ohmyz.sh)
- webmin
- observium
- cheat (https://github.com/cheat/cheat, create and view interactive cheatsheets on the command-line.)
- bropages
- ipbt / its-playback-time
- todo
- earthquake
- suplemon
- Newsroom
- unity
- ired
- wpe
- prettyping (ping), alias ping=‘prettyping --nolegend’
- diff-so-fancy (diff-clone)
- q (query CSV Files with SQL) https://harelba.github.io/q/
- gping (ping with a graph in CLI)
- http-prompt (install via pip)
- alt (“finding the alternate to a file. E.g. the header for an implementation or the test for an implementation. I use it paired with Neovim”, https://github.com/uptech/alt)
- chars (“shows information about Unicode characters matching a search term.”, https://github.com/antifuchs/chars)
- dot (“dotfiles manager. It maintains a set of symlinks according to a mappings file”, https://github.com/ubnt-intrepid/dot)
- dust (“alternative du -sh. It calculates the size of a directory tree, printing a summary of the largest items.”, https://github.com/bootandy/dust)
- eva (“command line calculator similar to bc, with syntax highlighting and persistent history.”, https://github.com/NerdyPepper/eva)
- hyperfine (“command line benchmarking tool. It allows you to benchmark commands with warmup and statistical analysis.”, https://github.com/sharkdp/hyperfine)
- mdcat (“renders Markdown files in the terminal”, https://github.com/lunaryorn/mdcat)
- podman (“alternative to Docker that does not require a daemon. Containers are run as the user running Podman so files written into the - host don’t end up owned by root. The CLI is largely compatible with the docker CLI.”, https://podman.io/)
- skim (“fuzzy finder. It can be used to fuzzy match input fed to it. I use it with Neovim and zsh for fuzzy matching file names.”)
- z (“tracks your most used directories and allows you to jump to them with a partial name.”, https://github.com/rupa/z)
- alias wetter_graph=‘finger [email protected]’
- alias wetter_color=‘curl wttr.in’
- alias maps_cli=‘telnet mapscii.me’
- https://github.com/say4n/crappybird
- https://asciicker.com
- cbonsai https://gitlab.com/jallbrit/cbonsai
- GNU poke binary editor http://www.jemarch.net/poke / https://git.savannah.gnu.org/cgit/poke.git
- gdu GoDiskUsage https://github.com/dundee/gdu
- Cirrus CLI https://github.com/cirruslabs/cirrus-
- tuxi https://github.com/Bugswriter/tuxi personal CLI assistant
- ngrep https://github.com/jpr5/ngrep
- topgrade https://github.com/r-darwish/topgrade
- ndiff https://nmap.org/ndiff/ compare nmap scans
- natlas https://github.com/natlas/natlas
- sift https://sift-tool.org grep-alternative
- xplr https://github.com/sayanarijit/xplr (hackable, minimal, fast TUI file explorer, stealing ideas from nnn and fzf)
- croc https://github.com/schollz/croc (allows any two computers to simply and securely transfer files and folders, great for forensics)
- slidev https://sli.dev (HTML5 presentations)
- lfs https://github.com/Canop/lfs (df alternative)
- vtop (https://github.com/MrRio/vtop)
- gtop (https://github.com/aksakalli/gtop)
- up (Ultimate Plumber https://github.com/akavel/up)
- ttyd (https://github.com/tsl0922/ttyd, Share your terminal over the web)
- nms (no more secrets, https://github.com/bartobri/no-more-secrets, A command line tool that recreates the famous data decryption effect - seen in the 1992 movie Sneakers.)
- xsv (https://github.com/BurntSushi/xsv, A fast CSV command line toolkit written in Rust.)
- fx (https://github.com/antonmedv/fx, Terminal JSON viewer)
- ccat (https://github.com/owenthereal/ccat, colorized cat mit Syntax Highlighting)
- delta (https://github.com/dandavison/delta, A syntax-highlighting pager for git, diff, and grep output. VORSICHT: Paket einer anderen Software mit gleichem Namen unter Debian Bullseye als Paket verfügbar!)
- dyff (https://github.com/homeport/dyff, /ˈdʏf/ - diff tool for YAML files, and sometimes JSON)
___
Rest of the list:
Tools pt. 2
- skim (https://github.com/lotabout/skim, Fuzzy finder in Rust)
- choose (https://github.com/theryangeary/choose, A human-friendly and fast alternative to cut and (sometimes) awk)
- sd (https://github.com/chmln/sd, wie sed, Intuitive find & replace CLI, mit regex)
- map (https://github.com/soveran/map, Map lines from stdin to commands, gemütliche Variante von xargs mit einfacherer Syntax und weniger Funktionsumfang)
- crush (https://github.com/liljencrantz/crush, Crush is a command line shell that is also a powerful modern programming language. Kann u.a. SQL-Statements)
- xxh (https://github.com/xxh/xxh, Bring your favorite shell wherever you go through the ssh.)
- starship (https://starship.rs, Shell-Prompt anpassen mit Nerdfont)
- q (https://github.com/natesales/q, A tiny & colorful command line DNS client with support for UDP, TCP, DoT, DoH, DoQ and ODoH.)
- gping (https://github.com/orf/gping, Ping, but with a graph)
- broot (https://github.com/Canop/broot, A new way to see and navigate directory trees : https://dystroy.org/broot)
- dust (https://github.com/bootandy/dust, intuitive du colored)
- dutree (https://github.com/nachoparker/dutree, a tool to analyze file system usage written in Rust)
- lsd (https://github.com/Peltoche/lsd, next-gen ls)
- mcfly (https://github.com/cantino/mcfly, Fly through your shell history using neural nets)
- procs (https://github.com/dalance/procs, A modern replacement for ps written in Rust, color, human readable, multi-column keword search)
- bottom (https://github.com/ClementTsang/bottom, top replacement, cross-platform graphical process/system monitor, zoom support)
- btop++ (https://github.com/aristocratos/btop, resource monitor CPU, RAM, IO, processes, IN SCHICK!!!, C+±continuation of bpytop https://github.com/aristocratos/bpytop)
- musikcube (https://github.com/clangen/musikcube, cross-platform, terminal-based music player, audio engine, metadata indexer, and server in c++ with an ncurses TI, incl.Android App)
- viu (https://github.com/atanunq/viu, Terminal image viewer with native support for iTerm and Kitty, auch animated gif)
- glow (https://github.com/charmbracelet/glow, Render markdown on the CLI)
- falsisign (https://gitlab.com/edouardklein/falsisign, For bureaucratic reasons, a colleague of mine had to print, sign, scan and send by email a high number of pages. To save trees, ink, time, and to stick it to the bureaucrats, I wrote this script.)
- ponysay (https://github.com/erkin/ponysay, wie cowsay mit bunten Ponies)
- sniffnet (https://github.com/GyulyVGC/sniffnet, cross-platform application to monitor your network traffic with ease, Debian-Pakete von GitHub verfügbar)
- netop (https://github.com/ZingerLittleBee/netop, monitor network traffic with bpf)
- corefreq (https://github.com/cyring/CoreFreq, CPU monitoring software for 64-bits Processors.)
- ctop (https://github.com/bcicen/ctop, Top-like interface for container metrics)
- dua (https://github.com/Byron/dua-cli, View disk space usage and delete unwanted data, fast.)
- dust (https://github.com/bootandy/dust, A more intuitive version of du in rust)
- helix editor
- lnav (https://github.com/tstack/lnav Log navigator)
- bottom (github.com/ClementTsang/bottom, another cross-platform graphical process/system monitor)
- broot (https://github.com/Canop/broot, a different than ranger/lf approach to navigating folders)
- mdr (https://github.com/michaelmure/mdr, a markdown viewer)
- eza (https://github.com/eza-community/eza, modern ls, with cool features like file icons)
- ouch (https://github.com/ouch-org/ouch, It’s a CLI tool for compressing and decompressing for various formats. such as .tar .zip 7z .gz .xz .lzma .bz .bz2 .lz4 .sz .zst .rar)
- spotify-tui (https://github.com/Rigellute/spotify-tui, Spotify CLI frontend (Spotify via terminal))
- toilet (http://caca.zoy.org/wiki/toilet, turn text into ASCII art)
DNS tools:
- viewdns.info
- dnslytics.com
- dnsspy.io
- leafdns.com
- dnsdumpster.com
- intodns.com
- www.zonecut.net/dns
- xip.io
- nip.io
- ptrarchive.com
- www.whatsmydns.net
- ceipam.eu/en/dnslookup.php
- spyse.com/tools/dns-lookup
- www.buddyns.com/delegation-lab
Good stuff for pentesters and security researchers:
- contained.af
- cryptohack.org
- 0x00sec.org
- hack.me
- chall.stypr.com
- crackmes.one
- hackxor.net
- tryhackme.com
- ctftime.org
- ctflearn.com
- picoctf.org
### .bashrc ### CUSTOM FUNCTIONS # https://www.linuxjournal.com/content/boost-productivity-bash-tips-and-tricks ftext () { grep -iIHrn --color=always "$1" . | less -R -r } duplicatefind (){ find -not -empty -type f -printf "%s\n" | sort -rn | uniq -d | \ xargs -I{} -n1 find -type f -size {}c -print0 | \ xargs -0 md5sum | sort | uniq -w32 --all-repeated=separate } generateqr (){ # printf "$@" | curl -F-=\<- qrenco.de printf "$@" | qrencode -t UTF8 -o - }
My brian has too little ram to process the list of packages 😂 good to know the rest!
Neither does mine, but, I keep it to test a new tool from time to time.
deleted by creator
- I use
Use
set -x
For debugging
Good to know!
Several things
- write bash and nothing else (except posix sh)
- find a good way to take notes. It shouldn’t be in your bashrc
- only write fish for fish config
- use $!/usr/bin/env bash
Good idea I added a “iwish” command a while ago. Whenever I am pissed about gnome not being able to do something, or anything else that didn’t work as it should, I wrote “iwish gnome had only one extension app” and it would add a new line to my wishlist.md Maybe it would be good for notes too.
inote bla
- Fish. Much, much saner defaults.
- I am writing
for dead simple scripts, so they will be a tiny bit more portable and run a tiny bit faster. The lack of arrays causes too much pain in longer scripts. I would love to use Fish, but it lacks a strict mode.
- No, why would I?
- I used to share all my dotfiles, scripts included, but I was too afraid that I would publish some secrets someday, so I stopped doing that. For synchronizing commands, aliases and other stuff between computers I use Chezmoi.
- To use Fish instead of fighting with start up time of Zsh with hundreds of plugins
- Always use the so-called “strict mode” in Bash, that is, the
set -euo pipefail
line. It will make Bash error on non-zero exit code, undefined variables and non-zero exit codes in commands in pipe. Also, always use shellcheck. It’s extremely easy to make a mistake in Bash. If you want to check the single command exit code manually, just wrap it inset +e
andset -e
. - Consider writing your scripts in Python. Like Bash, it also has some warts, but is multiplatform and easy to read. I have a snippet which contains some boilerplate like a
main
function definition withArgumentParser
instantiated. Then at the end of the script themain
function is called wrapped intry … except KeyboardInterrupt: exit(130)
which should be a default behavior. - Absolutely not a bad practice. If you need to use them on a remote server and can’t remember what they stand for, you can always execute
type some_command
. Oh, and read about abbreviations in Fish. It always expands the abbreviation, so you see what you execute.
I use
sh
to attempt to keep it compatible with POSIX systems.I use pain bash. Never really tried zsh and fish, since most of my Linux work is on servers and I don’t really care for extra features.
I try and write idempotent scripts when possible.
I wouldn’t create those aliases on a fleet because writing them to the configuration file of your shell in an idempotent fashion is hacky and my VMs are like cattle.
Yes, using bash on all boxen.
Scripts start with #!/bin/sh ,because, that gives quicker execution times.
Any simple aliases, I put in .bash_aliases
Tried tcsh and zsh around 30yrs ago, all bash since then.
Shell scripts are one of the things that makes Linux what it is. They’re relatively easy to create, powerful, etc. It was the thing that drove me to it from Windows in the first place.
One thing I would recommend against is creating dozens of utility scripts and/or aliases for things you run frequently. I have found it’s much better in the long-run to simply learn the “proper” commands and switches. If you use them often enough you start to type them very quickly. When you create helpers you start to learn your own ecosystem and will be lost on any system that doesn’t have your suite of helper apps installed.
There are exceptions to this to be sure (e.g. I always alias ‘l=ls -FhlA’) but I would specifically avoid the
podup
andpoddown
ones myself. I’ve gotten very quick at typing “docker run -it --rm foo” just by rote repetition.You’re free to do as you like though. Maybe you’ll only run Linux on your own desktop so that’s all that matters. But something to keep in mind. I would at least learn the commands very well first and then later alias or script them for convenience.
I agree. However… I do have a public repo with my helper scripts in case I need to set them up on a new machine. best of both worlds!
Welcome to the world of funny when you come across an airgapped server which doesn’t have the tools you use.
Eg: RHEL doesn’t have vim installed, now I can deal with nano but I’m way slower to do that. Luckily IaC has made my life somewhat easier
Agreed, IaC has helped that process a lot. I just used to curse.
I use fish shell only now. Used to only write bash, but I’ve started writing some fish scripts. I wouldn’t try to plan too much WRT shell scripting up front. Just fix your pain points as you go.
Am I missing something - doesn’t bash have tab completion or of the box?
hardly
Bash script for simple things (although Fish is my regular shell) and Node or Python scripts for complex things. Using
works just like it would for Bash so you know.
- Do you use bash? If not, which one do you use? zsh, fish? Why do you do it?
- Do you write #!/bin/bash or #!/bin/sh? Do you write fish exclusive scripts?
I use bash, and I use
for my scripts. Some are POSIX compliant, some have bashisms. But I really don’t care about bashisms, since I explicitly set the bash as interpreter. So no, no fish exclusive scripts, but some “bash exclusive” scripts. Since fish is aimed towards being used as interactive shell I don’t see a real reason to use it as interpreter for scripts anyways.
- Do you have two folders, one for proven commands and one for experimental?
- Do you publish/ share those commands?
- Do you sync the folder between your server and your workstation?
I have my scripts in
$HOME/.scripts
and softlink them from a directory in$PATH
. Some of the scripts are versioned using Git, but the repository is private and I do not plan sharing them because the repoand the scripts scripts contain some not-tho-share information and mostly are simply not useful outside my carefully crafted and specific environment. If I want to share a script, I do it individually or make a proper public Git repository for it.Since my server(s) and my workstations have different use cases I do not share any configuration between them. I share some configuration between different workstations, though. My dotfiles repository is mainly there for me to keep track of changes in my dotfiles.
is it bad practice to create a handful of commands
It becomes bad practice if it is against your personal or corporate guidelines regarding best practices. While it is not particularly bad or insecure, etc. to create bash scripts containing a single command, maybe use an alias instead. The
$1
is automatically the first parameter after typing the alias in the shell.alias podup="podman compose up -d" alias poddown="podman compose down" alias podlog="podman logs -f --tail 20"
Not quite sure about the podman syntax, if
podman exec /bin/sh -it "$1"
also works, you can usealias podenter="podman exec /bin/sh -it
, Otherwise a simple function would do the trick.Do you use bash? Yes because it is everywhere and available by default.
I use bash as my interactive shell. When ~20 years ago or so I encountered “smart” tab completion for the first time, I immediately disabled that and went back to dumb completion, because it caused multi-second freezes when it needed to load stuff from disk. I also saw it refuse to complete filenames because they had the wrong suffix. Maybe I should try to enable that again, see if it works any better now. It probably does go faster now with the SSDs.
I tried OpenBSD at some point, and it came with some version of ksh. Seems about equivalent to bash, but I had to modify some of my .bashrc so it would work on ksh. I would just stick to the default shell, whatever it is, it’s fine.
I try to stick to POSIX shell for scripts. I find that I don’t need bashisms very often, and I’ve used systems without bash on them. Most bash-only syntax has an equivalent that will work on POSIX sh. I do use bash if I really need some bash feature (I recently wanted to
set -o pipefail
, which dash cannot do apparently, and the workaround is really annoying).Do not use
if you’re writing bash-only scripts. This will break on Debian, Ubuntu, BSD, busybox etc. because /bin/sh is not bash on those systems.