I love working on Linux terminals
Rewind a decade or so, and you'd find me ensconced within the embrace of a Linux terminal for the duration of my day. Here, amidst the digital ebb and flow, I thrived—maneuvering files and folders with finesse, weaving code in Vim, orchestrating services maintenance, decoding kernel dumps, and seamlessly transitioning across a mosaic of tmux sessions.
The graphical user interface? A distant thought, unnecessary for the tapestry of tasks at hand.
Like all geeks, every tech enthusiast harbors a unique sanctuary of productivity—a bespoke digital workshop where code flows like poetry, and ideas ignite with the spark of creativity. It’s a realm where custom tools and secret utilities interlace, forming the backbone of unparalleled efficiency and innovation.
Today, I'm pulling back the curtain to reveal the intricacies of my personal setup on Mac.
I invite you on this meticulous journey through the configuration of my Mac-based development sanctuary.
Together, let's traverse this path, transforming the mundane into the magnificent, one command, one tool, one revelation at a time.
iTerm2
After account setup on Mac, the initial terminal looks like this when I logged in:
data:image/s3,"s3://crabby-images/41d14/41d1466ca2f2ede1ae89dac353d28af573439ecf" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 3 image"
data:image/s3,"s3://crabby-images/99df6/99df6e52e6eabda979a6d4333213ba76e30dd700" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 4 boss kid boring01"
Let's equip it with iTerm2!
data:image/s3,"s3://crabby-images/efe66/efe66b2dc7de282b98045f936890ca50204d3364" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 5 image 3"
What is iTerm2?
iTerm2 is a replacement for Terminal and the successor to iTerm. It works on Macs with macOS 10.14 or newer. iTerm2 brings the terminal into the modern age with features you never knew you always wanted.
Why Do I Want It?
Check out the impressive features and screenshots. If you spend a lot of time in a terminal, then you'll appreciate all the little things that add up to a lot. It is free software and you can find the source code on Github.
How Do I Use It?
Try the FAQ or the documentation. Got problems or ideas? Report them in the bug tracker, take it to the forum, or send me email (gnachman at gmail dot com).
Go ahead to https://iterm2.com/ download it and finish installation. Open it:
data:image/s3,"s3://crabby-images/29964/299649304eb2276472999dcc5e45a1d808ee234c" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 6 image 1"
Well, still not impressive. But, now you have got all advanced features from iTerm!
This blog post is not focus on iTerm2, we can discuss later. So I am not going through those fancy features right now, please explore on the official website.
Let's start to customize on it.
Wait, Nerd ... Font
Before we jump on the customization on iTerm2, I want to introduce you Nerd Font.
It will be required and installed by https://github.com/romkatv/powerlevel10k which we will talk later.
data:image/s3,"s3://crabby-images/4040c/4040ca0b4e0ca46c5d4c9bf2ddb4512a75613fe2" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 7 image 2"
This project aims to enhance the usability and aesthetic appeal of the development environment without sacrificing the functionality or readability of the text. The added icons can represent common actions or tools in the development workflow, allowing for a more intuitive and visually engaging interface.
By incorporating icons directly into the fonts, Nerd Fonts allows developers to use these icons across different applications and tools seamlessly, without needing to rely on external libraries or tool-specific extensions. This can simplify setup and configuration across tools and platforms, providing a consistent and enriched visual experience.
Customize iTerm2
Just follow me:
data:image/s3,"s3://crabby-images/6cddf/6cddfda98e5d2929cf7285ee542a0dc983aae114" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 8 image 4"
data:image/s3,"s3://crabby-images/3984a/3984abe2ab3e3f994709c2c0ff56af394f5be792" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 9 image 5"
Set your favorite character as background image if you like:
data:image/s3,"s3://crabby-images/cac44/cac44dfebc9f02ac1988ce1b9ee9c7c808090671" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 10 image 6"
Let's compare previous and now:
![]() |
![]() |
Oh-my-zsh and powerlevel10k
Install https://github.com/ohmyzsh/ohmyzsh (to manage zsh):
sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
data:image/s3,"s3://crabby-images/444b4/444b4648d91a8419b0b43da7465be14e0fcbd6ed" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 13 image 9"
Install https://github.com/romkatv/powerlevel10k for ohmyzsh and configure it (powerlevel10k is a theme of zsh).
git clone --depth=1 https://github.com/romkatv/powerlevel10k.git ${ZSH_CUSTOM:-$HOME/.oh-my-zsh/custom}/themes/powerlevel10k
Set environment:
echo "source ~/.oh-my-zsh/custom/themes/powerlevel10k/powerlevel10k.zsh-theme" >> ~/.zshrc
Restart Zsh with exec zsh
.
You should see:
data:image/s3,"s3://crabby-images/843bb/843bb1db289c4ad595eaf1ebf2fbb30ee45f4467" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 14 image 10"
Let's install the fonts and follow the wizard, choose whatever you like!
Now it looks much better!
data:image/s3,"s3://crabby-images/5d99e/5d99e432f2308776be15ce2d58ddb2e445716e6c" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 15 image 12"
Much better, but still not meet my expectation!
Let’s begin working with our adaptable TMUX expert now!
data:image/s3,"s3://crabby-images/6d776/6d77627a37604af9cc7aa69ad42a2a55b76d3dee" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 16 image 13"
tmux is a terminal multiplexer. It lets you switch easily between several programs in one terminal, detach them (they keep running in the background) and reattach them to a different terminal.
Tmux should have been installed by default, type tmux, you should see:
data:image/s3,"s3://crabby-images/fa14a/fa14a2cfe7b4c6696a5047a6552423de7ca9be31" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 17 image 14"
data:image/s3,"s3://crabby-images/99df6/99df6e52e6eabda979a6d4333213ba76e30dd700" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 4 boss kid boring01"
Can't wait to customize it!
I am using https://github.com/gpakosz/.tmux.git:
It's a Self-contained, pretty and versatile
.tmux.conf
configuration file.
cd ~ rm -fr .tmux git clone https://github.com/gpakosz/.tmux.git ln -s -f .tmux/.tmux.conf cp .tmux/.tmux.conf.local .
Append below into .tmux.conf.local
before the line "# -- custom variables
":
# increase history size set -g history-limit 9999999 # start with mouse mode enabled set -g mouse on bind-key -n C-S-Left swap-window -t -1\; select-window -t -1 bind-key -n C-S-Right swap-window -t +1\; select-window -t +1 # -- custom variables ----------------------------------------------------------
I am a fan of Vi/Vim, must enable Vi mode in "~/.tmux.conf.local
":
data:image/s3,"s3://crabby-images/54746/5474644bb6f80cdcf682d98e21fd0c61502029a3" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 19 image 16"
Customize status bar:
tmux_conf_theme_status_right_fg="$tmux_conf_theme_colour_12,$tmux_conf_theme_colour_14,$tmux_conf_theme_colour_6" tmux_conf_theme_status_right_bg="$tmux_conf_theme_colour_15,$tmux_conf_theme_colour_17,$tmux_conf_theme_colour_9"
data:image/s3,"s3://crabby-images/af9a7/af9a757b2f703ac304a63ff37d4f6202e0aa2711" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 20 image 17"
tmux_conf_theme_left_separator_main='\uE0B0' tmux_conf_theme_left_separator_sub='\uE0B1' tmux_conf_theme_right_separator_main='\uE0B2' tmux_conf_theme_right_separator_sub='\uE0B3'
data:image/s3,"s3://crabby-images/1f506/1f506bcdb56d0e63e5c1875798d5a2107afc8c16" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 21 image 18"
Find below lines in "~/.tmux.conf.local
" and uncomment them to enable:
data:image/s3,"s3://crabby-images/e37fb/e37fbaae93d1f66219a02fedc83f3bc69c644269" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 22 image 19"
Set a icon for the left status:
data:image/s3,"s3://crabby-images/50de8/50de8fe401127cf05d8d889388095189be26f48b" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 23 image 20"
Now reload configuration:
tmux source ~/.tmux.conf
Check it now!
data:image/s3,"s3://crabby-images/bd208/bd2083667bec11fd93cd8d0bbbcc78bcee90aee2" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 24 image 22"
I have a script to launch Tmux when starting iTerm2, here you go:
#!/bin/zsh tmux ls|grep kongfu | grep -q attached if [[ $? != 0 ]] ; then tmux attach -t kongfu || tmux new-session -s kongfu else echo "********************************************************************************" echo "* Ignore attaching tmux kongfu session as it has been attached already. *" echo "********************************************************************************" fi
Save it "~/bin/tmux_init.sh
" and "chmod 755 ~/bin/tmux_init.sh
", configure it in iTerm2 default profile:
data:image/s3,"s3://crabby-images/6f2f3/6f2f3ebdea54cc3d79d976de5fe26d3af45a8123" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 25 image 23"
Customize P10K Status Bar for Anaconda and Node.js
I have Anaconda and Node.js environments.
I am not satisfied with the default color settings for Anaconda and node.js. It's ugly.
Open your ~/.p10k.zsh
, make below changes:
data:image/s3,"s3://crabby-images/a2ae0/a2ae0b6fc2e4f786579194fbdca92f79e4040f30" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 26 image 24"
data:image/s3,"s3://crabby-images/7d527/7d527d71f54c4996f324c020beb72305c8c33d67" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 27 image 25"
data:image/s3,"s3://crabby-images/dc857/dc8573fc3c29de6e594d39f27caa5739257b8362" alt="Terminal Mastery: Crafting a Productivity Environment with iTerm, tmux, and Beyond - 28 image 26"
Now resource the file:
source ~/.p10k.zsh
Show time!
I recorded this to show you how it looks like on my environment: