Linux Cheat Sheet
Generic
Install homebrew
#!/usr/bin/env bash
echo -en "\n" | /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" && \
echo 'eval "$(/home/linuxbrew/.linuxbrew/bin/brew shellenv)"' >> ~/.bashrc && \
eval "$(/home/linuxbrew/.linuxbrew/bin/brew shellenv)" && \
source ~/.bashrc && \
brew install gcc
Ubuntu
Install Podman on Ubuntu 22.04
#!/usr/bin/env bash
sudo apt-get update -qq
sudo apt-get -qq -y install podman
Set ubuntu as default shell or run shell from Windows
"wsl.exe" -d Ubuntu "bash"
Install PowerShell Core on Ubuntu
#!/usr/bin/env bash
sudo apt-get update && sudo apt-get install -y wget apt-transport-https software-properties-common && \
wget -q "https://packages.microsoft.com/config/ubuntu/$(lsb_release -rs)/packages-microsoft-prod.deb" && \
sudo dpkg -i packages-microsoft-prod.deb && \
sudo apt-get update && sudo apt-get install -y powershell && \
pwsh -Command Set-PSRepository -Name "PSGallery" -InstallationPolicy Trusted
sudo pwsh -Command Install-Module -Name Az -Force -AllowClobber -Scope AllUsers -Repository PSGallery
Update CA Certificates on an Ubuntu host
#!/usr/bin/env bash
sudo cp *.crt /usr/local/share/ca-certificates/
sudo cp *.crt /etc/ssl/certs
mkdir -p ~/.local/share/ca-certificates/ && cp *.crt ~/.local/share/ca-certificates/
update-ca-certificates
Configure Python PIP conf
#!/usr/bin/env bash
pip config set global.cert ca.crt
echo 'export REQUESTS_CA_BUNDLE="ca.crt"'
Setup Terraform environment variables
echo 'export ARM_TENANT_ID=""' >> ~/.bashrc
echo 'export ARM_CLIENT_ID=""' >> ~/.bashrc
echo 'export ARM_CLIENT_SECRET=""' >> ~/.bashrc
echo 'export ARM_SUBSCRIPTION_ID=""' >> ~/.bashrc
echo 'export ARM_DEPLOY_LOCATION=""' >> ~/.bashrc
echo 'export ARM_ACCESS_KEY=""' >> ~/.bashrc
Install GitHub CLI
#!/usr/bin/env bash
type -p curl >/dev/null || sudo apt install curl -y
curl -fsSL https://cli.github.com/packages/githubcli-archive-keyring.gpg | sudo dd of=/usr/share/keyrings/githubcli-archive-keyring.gpg \
&& sudo chmod go+r /usr/share/keyrings/githubcli-archive-keyring.gpg \
&& echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/githubcli-archive-keyring.gpg] https://cli.github.com/packages stable main" | sudo tee /etc/apt/sources.list.d/github-cli.list > /dev/null \
&& sudo apt update \
&& sudo apt install gh -y
Install Keybase on Ubuntu
curl --remote-name https://prerelease.keybase.io/keybase_amd64.deb
sudo apt install ./keybase_amd64.deb
run_keybase
Install JetBrains toolbox
#!/bin/bash
[ $(id -u) != "0" ] && exec sudo "$0" "$@"
echo -e " \e[94mInstalling Jetbrains Toolbox\e[39m"
echo ""
sudo apt-get install libfuse2
function getLatestUrl() {
USER_AGENT=('User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/59.0.3071.115 Safari/537.36')
URL=$(curl 'https://data.services.jetbrains.com/products/releases?code=TBA&latest=true&type=release' -H 'Origin: https://www.jetbrains.com' -H 'Accept-Encoding: gzip, deflate, br' -H 'Accept-Language: en-US,en;q=0.8' -H "${USER_AGENT[@]}" -H 'Accept: application/json, text/javascript, */*; q=0.01' -H 'Referer: https://www.jetbrains.com/toolbox/download/' -H 'Connection: keep-alive' -H 'DNT: 1' --compressed | grep -Po '"linux":.*?[^\\]",' | awk -F ':' '{print $3,":"$4}'| sed 's/[", ]//g')
echo $URL
}
getLatestUrl
FILE=$(basename ${URL})
DEST=$PWD/$FILE
echo ""
echo -e "\e[94mDownloading Toolbox files \e[39m"
echo ""
wget -cO ${DEST} ${URL} --read-timeout=5 --tries=0
echo ""
echo -e "\e[32mDownload complete!\e[39m"
echo ""
DIR="/opt/jetbrains-toolbox"
echo ""
echo -e "\e[94mInstalling to $DIR\e[39m"
echo ""
if mkdir ${DIR}; then
tar -xzf ${DEST} -C ${DIR} --strip-components=1
fi
chmod -R +rwx ${DIR}
ln -s ${DIR}/jetbrains-toolbox /usr/local/bin/jetbrains-toolbox
chmod -R +rwx /usr/local/bin/jetbrains-toolbox
echo ""
rm ${DEST}
echo -e "\e[32mDone.\e[39m"
Install Bitwarden
sudo snap install bitwarden # yes, really.
Install Azure Core Functions Tools
curl https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > microsoft.gpg
sudo mv microsoft.gpg /etc/apt/trusted.gpg.d/microsoft.gpg && \
sudo sh -c 'echo "deb [arch=amd64] https://packages.microsoft.com/repos/microsoft-ubuntu-$(lsb_release -cs)-prod $(lsb_release -cs) main" > /etc/apt/sources.list.d/dotnetdev.list' && \
sudo apt-get update && \
sudo apt-get install azure-functions-core-tools-4 -y
Install VSCode Ubuntu
#!/usr/bin/env bash
sudo apt-get install wget gpg
wget -qO- https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > packages.microsoft.gpg
sudo install -D -o root -g root -m 644 packages.microsoft.gpg /etc/apt/keyrings/packages.microsoft.gpg
sudo sh -c 'echo "deb [arch=amd64,arm64,armhf signed-by=/etc/apt/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/code stable main" > /etc/apt/sources.list.d/vscode.list'
rm -f packages.microsoft.
sudo apt-get install -y apt-transport-https
sudo apt-get update
sudo apt-get install code -y
Install Edge Stable on Ubuntu
curl https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > microsoft.gpg
sudo install -o root -g root -m 644 microsoft.gpg /etc/apt/trusted.gpg.d/
sudo sh -c 'echo "deb [arch=amd64] https://packages.microsoft.com/repos/edge stable main" > /etc/apt/sources.list.d/microsoft-edge-dev.list'
sudo rm microsoft.gpg
sudo apt-get update && sudo apt-get install microsoft-edge-stable
Install Starship
#!/usr/bin/env bash
# install DroidSansMono Nerd Font --> u can choose another at: https://www.nerdfonts.com/font-downloads
echo "[-] Downloading latest version of DroidSansMono Nerd Font [-]"
FONT_URL=$(curl -s https://api.github.com/repos/ryanoasis/nerd-fonts/releases/latest | grep -o "https://github.com/ryanoasis/nerd-fonts/releases/download/.*/DroidSansMono.zip")
curl -L $FONT_URL -o DroidSansMono.zip
unzip DroidSansMono.zip -d ~/.fonts
rm -rf DroidSansMono.zip
fc-cache -fv
echo "[-] DroidSansMono Nerd Font installation completed [-]"
curl -sS https://starship.rs/install.sh | sh && \
mkdir -p ~/.config && touch ~/.config/startship.toml && \
echo '
# Set command timeout higher
command_timeout = 10000
# Get editor completions based on the config schema
"$schema" = "https://starship.rs/config-schema.json"
# Config Azure
[azure]
disabled = false
format = "on [$symbol($subscription)]($style) "
symbol = "# "
style = "blue bold"
# Inserts a blank line between shell prompts
add_newline = true
# Replace the '❯' symbol in the prompt with '➜'
[character]
success_symbol = "[➜](bold green)"
# Disable the package module, hiding it from the prompt completely
[package]
disabled = true
' > ~/.config/startship.toml && \
echo 'eval "$(starship init bash)"' >> ~/.bashrc
Terraform Release Function
#!/usr/bin/env bash
function tfrel() {
print_success() {
lightcyan='\033[1;36m'
nocolor='\033[0m'
echo -e "${lightcyan}$1${nocolor}"
}
print_error() {
lightred='\033[1;31m'
nocolor='\033[0m'
echo -e "${lightred}$1${nocolor}"
}
print_alert() {
yellow='\033[1;33m'
nocolor='\033[0m'
echo -e "${yellow}$1${nocolor}"
}
local curdir=$(basename $(pwd))
local build_file=""
if [ -f build.tf ]; then
build_file="build.tf"
print_success "${build_file} found"
elif [ -f main.tf ]; then
build_file="main.tf"
print_success "${build_file} found"
fi
if [ "$build_file" != "" ]; then
echo "" > README.md
echo '```hcl' >> README.md
cat "$build_file" >> README.md
echo '```' >> README.md
else
print_alert "Not a build directory, no build.tf or main.tf found"
fi
terraform fmt -recursive
terraform-docs markdown . >> README.md
stfi
stfo
git add --all
git commit -m "Update module"
git push
git tag 1.0.0 --force
git push --tags --force
}
echo "Appending functions to .bashrc"
echo "" >>~/.bashrc
echo "# Define tfrel function" >>~/.bashrc
declare -f tfrel >>~/.bashrc
Install Pyenv on Ubuntu
#!/usr/bin/env bash
sudo apt-get install -y \
git \
build-essential \
gcc \
make \
openssl \
libssl-dev \
zlib1g-dev \
libbz2-dev \
libreadline-dev \
libsqlite3-dev \
python-is-python3 \
wget \
curl \
llvm \
libncursesw5-dev \
xz-utils \
tk-dev \
libxml2-dev \
libxmlsec1-dev \
libffi-dev \
liblzma-dev \
python3-pip \
unzip \
zip \
python3-tk && \
echo "done package installs" && \
git clone https://github.com/pyenv/pyenv.git ~/.pyenv && \
echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.bashrc && \
echo 'command -v pyenv >/dev/null || export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.bashrc && \
echo 'eval "$(pyenv init -)"' >> ~/.bashrc && \
echo 'export PATH=$HOME/.local:$PATH' >> ~/.bashrc
source ~/.bashrc
pyenv install 3.10
pyenv global 3.10
Install TFenv on Ubuntu
git clone --depth=1 https://github.com/tfutils/tfenv.git ~/.tfenv
echo 'export PATH=$PATH:$HOME/.tfenv/bin' >> ~/.bashrc
Install Pkenv on Ubuntu
git clone https://github.com/iamhsa/pkenv.git ${HOME}/.pkenv && \
echo 'export PATH="${HOME}/.pkenv/bin:$PATH"' >> ${HOME}/.bashrc
Install Goenv on Ubuntu
git clone https://github.com/syndbg/goenv.git ~/.goenv && \
echo 'export GOENV_ROOT="$HOME/.goenv"' >> ~/.bashrc && \
echo 'export PATH="$GOENV_ROOT/bin:$PATH"' >> ~/.bashrc && \
echo 'eval "$(goenv init -)"' >> ~/.bashrc && \
echo 'export PATH="$GOROOT/bin:$PATH"' >> ~/.bashrc && \
echo 'export PATH="$PATH:$GOPATH/bin"' >> ~/.bashrc
Install Various DevOps/Handy tools (requires other tools mentioned
#!/usr/bin/env bash
source ~/.bashrc
sudo apt-get update && sudo apt-get install -y zip unzip
pip3 install pipx && \
pipx ensurepath && \
source ~/.bashrc && \
pipx install podman-compose && \
pipx install terraform-compliance && \
pipx install checkov && \
pipx install azure-cli && \
pipx install black && \
pipx install pipenv && \
pipx install bandit && \
pipx install beautysh && \
tfenv install latest && \
tfenv use latest && \
pkenv install 1.8.6 && \
pkenv use 1.8.6 && \
goenv install 1.20.1 && \
goenv global 1.20.1 && \
brew install terraform-docs && \
echo "alias td='terraform-docs markdown . > README.md'" >> ~/.bashrc
Some handy aliases
echo "alias unsecure-update='sudo apt-get -o Acquire::https::Verify-Peer=false update'" >> ~/.bashrc
Fedora/RHEL
Update CA Certificates on Fedora
#!/usr/bin/env bash
sudo dnf install -y ca-certificates
sudo cp *.crt /etc/pki/ca-trust/source/anchors/
mkdir -p ~/.pki/nssdb/ && cp *.crt ~/.pki/nssdb/
update-ca-trust
Install Pyenv on Fedora
#!/usr/bin/env bash
sudo yum install \
zlib-devel \
bzip2-devel \
ncurses-devel \
libffi-devel \
sqlite-devel \
make \
gcc \
readline-devel \
python3-pip \
python3-tkinter \
xz-devel \
tk-devel \
git && \
echo "done package installs" && \
git clone https://github.com/pyenv/pyenv.git ~/.pyenv && \
echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.bashrc && \
echo 'command -v pyenv >/dev/null || export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.bashrc && \
echo 'eval "$(pyenv init -)"' >> ~/.bashrc && \
echo 'export PATH=$HOME/.local:$PATH' >> ~/.bashrc
WSL Cheatsheet
Set WSL workspaces
ln -s /mnt/c/Users winusers
ln -s /mnt/C/Users/craig winhome
ln -s /mnt/C/Users/craig/craig-workspace craig-worksppace
ln -s /mnt/C/Users/craig/Desktop windesktop
Set ubuntu as default shell or run shell from Windows as root user
"wsl.exe" -u root -d Ubuntu "bash"
Set WSL Resources
@"
[wsl2]
memory=8GB
processors=2
"@ | Set-Content -Path "$Env:USERPROFILE\.wslconfig"
Install WSL2 VPN Toolkit
# Download the latest release of WSL VPNKit
Invoke-WebRequest -Uri "https://github.com/sakai135/wsl-vpnkit/releases/latest/download/wsl-vpnkit.tar.gz" -OutFile "wsl-vpnkit.tar.gz" ; `
wsl --import wsl-vpnkit --version 2 $env:USERPROFILE\wsl-vpnkit wsl-vpnkit.tar.gz ; `
wsl -d wsl-vpnkit ; `
wsl.exe -d wsl-vpnkit --cd /app service wsl-vpnkit start
Source: docs/cheatsheets/linux-cheatsheet.md