Tmux

(terminal multiplexer) is Article description::a program that enables a number of terminals (or windows), each running a separate program, to be created, accessed, and controlled from a single screen or terminal window. may be detached from a screen and continue running in the background, then later reattached.

Users familiar with GNU Screen may find tmux as a suitable alternative.

Emerge
Install :

Configuration
Standard installation of will not install a global  or user  configuration file. Examples are provided in the file and can be copied to a user and system locations.

Example config
To reload the configuration file from a terminal run:

Alternatively, modifications to the file can be loaded from within tmux via:

Automatic connection
Running tmux with and the   options will cause tmux to replace the current shell and create a session, or if one exists connect to it and both detach and exit the other client. This provides a very consistent way of working with remote sessions, and it can be run automatically:

Bash

Fish

Plugins
A few plugins are available for. See the sections below for available options.

tpm
is a plugin manager. See the tpm sub-article for more details on the installation process.

tmux-mem-cpu-load
is a small program designed to monitor system activity in the status line of. See the Tmux/plugins/tmux-mem-cpu-load sub-article for more details on the installation process.

Tmux Resurrect
persists environments across system restarts. See the resurrect sub-article for more details on the installation process.

Key bindings
tmux can be controlled from an attached client by using a key combination of a prefix key stroke (+ by default) followed by a command key.

After pressing + the following key combinations can be used:

General

 * = List all key bindings.
 * = Detach the current client.
 * = Enter the tmux command prompt.

Creating and managing windows

 * = Create a new window
 * = Change to the next window.
 * = Change to the previous window.
 * = Move to the previously selected window.
 * = Select windows 0 to 9.
 * = Prompt for a window index to select. Then enter a number or title to switch to that window.
 * = Rename the current window.
 * = Choose the current window interactively.
 * , then type list-windows = Display the list of windows.

Creating and managing panes

 * = Split the current pane into two, top and bottom.
 * = Split the current pane into two, left and right.
 * = Select the next pane in the current window.
 * = Move to the previously active pane.
 * {{Key|{}} = Swap the current pane with the previous pane.
 * {{Key| } }} = Swap the current pane with the next pane.
 * + = Rotate the panes in the current window forwards.
 * + to + = Arrange panes in one of the five preset layouts: even-horizontal, even-vertical, main-horizontal, main-vertical, or tiled.
 * = Kill the current pane.
 * = Break the current pane out of the window.

Copy, paste, and scroll operations
The keys available depend on whether emacs (default) or vi mode is selected. The mode-keys option can be set in for vi mode.


 * = Enter copy mode to copy text or view output history via the scrollback buffer. Once in copy mode, pressing or  will move the cursor down or up lines respectively, while  and  will move down or up on in per-paragraph chunks.
 * = Paste the most recently copied buffer of text.
 * = List all paste buffers.
 * = Delete the most recently copied buffer of text.

Start session
Once started creates a socket for the session in

can be started with the following command:

Or, to give the session a name on start up, run:

Listing sessions
List sessions to see existing session information:

When listing sessions the name of the session should appear as the first item in the session information line. It is possible to see from the output above the session was created without a name, hence the session is to be referenced as.

Another way to list sessions is by typing out the long  argument.

The exact same output as the previous list command is displayed.

Renaming a session
Simply using to start a session will not provide the session with a nice, human readable name.

If the default session name is not descriptive enough ( does not tend to describe much), then a session can be renamed. Suppose Larry the cow started without specifying a session name on start up. He begins working on compiling a new version of Portage, and wants to change the session name to reflect his current task. To change the session name he would first assume control of by pressing the magic key stroke: +, then  which will drop focus into the  control line. By default the line should turn yellow. Once there he would issue:

Where  is the existing (default) session name and   is the desired new name for the session. To rename when detached from a session issue:

Resuming a session
After the session is detached, all the active terminals remain active and so do commands that did not finish yet. To resume a session use.

Or use the long way of attaching to an existing session:

Daemon-like operation
To start a command in a session without attaching to the session (like a daemon) use   followed by the command to execute in quotes:

External resources

 * https://tmuxcheatsheet.com/.
 * An excellent primer.
 * The Tao of tmux, ebook by Tony Narlock, creator of libtmux and tmuxp.
 * gpakosz/.tmux To make things eaiser.