Tmux 学习摘要3--使用脚本定制 tmux 环境

使用脚本为每一个项目定制一个 tmux 环境:建立会话,分割窗口,自动开启项目要用到的程序等。mysql

使用 tmux 命令建立定制设置

能够使用 tmux 命令在一个会话中分割窗口,改变布局,甚至开启程序。完成这些操做的关键是使用 -t target 开关。git

当有一个命名 tmux 会话后,能够这样与它进行关联:sql

$ tmux attach -t [session_name]

咱们使用 -t 开关将命令导向到相应的 tmux 会话。假设新建了一个命名为 development 的会话:shell

$ tmux new -s development

能够经过 tmux 命令对其窗口进行水平分割:数据库

$ tmux split-window -h -t development

当与该会话关联后,能够看到该会话的窗口被分割成了水平两个窗格了。vim

使用脚本配置项目开发环境

经过脚原本建立一个会话,建立窗口和窗格,而后在每一个窗格中启动一些程序。windows

先在 home 目录下建立一个 development 的脚本,并设置为可执行:api

$touch ~/development
$chmod +x ~/development

在该脚本文件中,首先建立一个命名为 development 的 tmux 会话:bash

# scripting/development
tmux new-session -s development -n editor -d

使用 -s 开关指定会话的名字为 development,使用 -n 开关指定该会话的初始窗口名称为 editor,使用 -d 开关使得建立后当即与其脱离。服务器

当启动会话后,将工做目录切换到项目目录上,如 devproject。在脚本文件中使用 tmux 的 send-keys 来改变目录:

# scripting/development
tmux send-keys -t development 'cd ~/devproject' C-m

行末的 C-mCTRL-m ,表示发送一个回车键。相似地,能够在该窗口中开启一个 Vim 编辑器:

# scripting/development
tmux send-keys -t development 'vim' C-m

分割主编辑器窗口,使其下面有一个小的终端窗口,能够使用 split-window 命令:

# scripting/development
tmux split-window -v -t development

也能够指定分割窗格所占的百分比:

# scripting/development
tmux split-window -v -p 10 -t development

也能够选择窗口使用的布局:

# scripting/development
tmux select-layout -t development main-horizontal

此时,能够对首窗口进行分割和发送命令了。

向指定的窗口和窗格发送命令

每一个窗口都有一个编号,其基编号由 set base-index 设置,而窗口中的每一个窗格也有一个编号,其基编号由 setw pane-base-index 设置。要指定特定的窗口和窗格,使用格式: [session]:[window].[pane],如 development:1.2。所以,在会话的首窗口的第二个窗格中切换到项目目录:

# scripting/development
tmux send-keys -t development:1.2 'cd ~/devproject' C-m

建立和选择窗口

建立一个全屏的终端窗口,使用 new-window 命令:

# scripting/development
tmux new-window -n console -t development
tmux send-keys -t development:2 'cd ~/devproject' C-m

在新建窗口后,进行了目录切换,因为新窗口只有一个窗格,因此无需指定窗格号。

当开启会话后,须要将首个窗口显示出来,使用 select-window 命令:

# scripting/development
tmux select-window -t development:1
tmux attach -t development

在该脚本中,能够继续增长内容:增长窗口和窗格,开启到服务器的远程链接、打开日志文件、开启数据库命令行、更新代码库,……

该例中的脚本所有内容以下:

tmux new-session -s development -n editor -d
tmux send-keys -t development 'cd ~/devproject' C-m
tmux send-keys -t development 'vim' C-m
tmux split-window -v -t development
tmux select-layout -t development main-horizontal
tmux send-keys -t development:1.2 'cd ~/devproject' C-m
tmux new-window -n console -t development
tmux send-keys -t development:2 'cd ~/devproject' C-m
tmux select-window -t development:1
tmux attach -t development

并用如下命令执行:

$ ~/development

该脚本每次运行都会生成一个新的会话,当该会话存在时,再运行该脚本会出错,能够用 has-session 命令解决:

tmux has-session -t development
if [ $? !=0 ]
    tmux new-session -s development -n editor -d
    tmux send-keys -t development 'cd ~/devproject' C-m
    tmux send-keys -t development 'vim' C-m
    tmux split-window -v -t development
    tmux select-layout -t development main-horizontal
    tmux send-keys -t development:1.2 'cd ~/devproject' C-m
    tmux new-window -n console -t development
    tmux send-keys -t development:2 'cd ~/devproject' C-m
    tmux select-window -t development:1
fi
tmux attach -t development

该方式只适用于某个具体项目。

经过 tmux 配置文件设置项目开发环境

.tmux.conf 文件自己能够包含命令来设置默认环境。经过上面相同的命令,能够在配置文件中设置每一个开发环境的通用配置。

tmux 还能够经过 -f 开关来指定配置文件,从而咱们能够在每一个项目中建立一个专门的配置文件,并在其中设置窗口窗格、快捷键等。

首先建立一个新的配置文件 app.conf,并使用上面相似的命令。因为当前是在一个 tmux 配置文件中,因此全部的命令都再也不须要使用 tmux 前缀。配置文件的内容:

# scripting/app.conf
source-file ~/.tmux.conf
new-session -s development -n editor -d
send-keys -t development 'cd ~/devproject' C-m
send-keys -t development 'vim' C-m
split-window -v -t development
select-layout -t development main-horizontal
send-keys -t development:1.2 'cd ~/devproject' C-m
new-window -n console -t development
send-keys -t development:2 'cd ~/devproject' C-m
select-window -t development:1

首行经过加载默认的 ~/.tmux.conf 文件,完成了全部的默认配置。

开启命令:

$ tmux -f app.conf attach

上面的 tmux 最后有 attach 命令是由于: tmux 开启时默认老是会运行 new-session 命令,可是咱们的配置文件中已经新建了一个会话,所以经过使用 attach 避免会出现两个会话。

这种方法比较灵活,可是配置文件会较多。

使用 tmuxinator 管理配置

tmuxinator 是一个用于编写和管理不一样 tmux 配置文件的小工具。咱们在 YAML 文件中定义窗口布局和命令,而后用 tmuxinator 来加载。tmuxinator 能够对配置文件进行集中管理,而且易于建立复杂布局。经过它还能够指定每一个窗口开启前需执行的命令。

tmuxinator 依赖 Ruby。

经过 Rubygems 安装:

$sudo gem install tmuxinator

tmuxinator 须要有 EDITOR 环境变量,能够在 Linux 的 .bashrc 或 OS X 的 .bash_profile 上设置:

export EDITOR=vim

建立一个 tmuxinator 项目 development:

$ tmuxinator open development

执行后会用你的编辑器显示项目的默认配置信息,如:

#scripting/default.yaml
project_name: Tmuxinator
project_root: ~/code/rails_project
socket_name: foo # Not needed. Remove to use default socket
rvm: 1.9.2@rails_project
pre: sudo /etc/rc.d/mysqld start
tabs:
  - editor:
    layout: main-vertical
    panes:
      - vim
      - #empty, will just run plain bash
      - top
  - shell: git pull
  - database: rails db
  - server: rails s
  - logs: tail -f logs/development.log
  - console: rails c
  - capistrano:
  - server: ssh me@myhost

该 YAML 文件定义了一个 tmux 会话,其中有 8 个窗口。第一个窗口中有 3 个窗格,使用 main-vertical 布局。其它的窗口都开启和运行了各类的服务和程序。同时,还能够指定在每一个窗口加载时会自动运行的命令。

先建立一个开发环境,其中 Vim 在上面,一个终端在下面:

#scripting/development.yaml, Tmuxinator 0.8.1
name: devproject
root: ~/devproject
windows:
  - editor:
      layout: main-horizontal
      panes:
        - vim
        - #empty, will just run plain bash
  - console: # empty

YAML 文件使用 2 个空格表示缩进。

开启该环境:

$tmuxinator development

tmuxinator 会自动加载默认的 .tmux.conf 文件,而后再执行咱们在 YAML 文件中指定的配置信息。

从新打开配置文件修改:

$tmuxinator open development

配置文件默认都存放在 ~/.tmuxinator/ 目录下。tmuxinator 实质上是根据咱们的配置文件生成脚本命令文件,而后再一一执行其中的命令。

总结

可用于脚本中的 tmux 命令

命令 描述
tmux new-session -s development -n editor 建立一个命名为 development 的会话,而且命名首窗口为 editor
tmux attach -t development 关联到命名窗口 development
tmux send-keys -t development '[keys]' C-m 向命名会话 development 中的活动窗口或窗格发送按键,C-m 至关于回车键
tmux send-keys -t development:1.0 '[keys]' C-m 向命名会话 development 中的第 1 个窗口中的第 0 个 窗格发送按键,C-m 至关于回车键
tmux select-window -t development:1 使命名会话 development 中的第 1 个窗口成为活动窗口
tmux split-window -v -p 10 -t development 将命名会话 development 中的当前窗口垂直分割,其中下面的窗格高度占 10%
tmux select-layout -t development main-horizontal 为命名会话 development 选择布局
tmux -f app.conf attach 加载 app.conf 配置文件,并关联到该配置文件生成的会话

tmuxinator 命令

命令 描述
tmuxinator open [name] 在默认编辑器中打开或建立一个项目配置文件
tmuxinator [name] 加载并运行该项目配置文件,建立(若是尚未建立)并关联建立的会话
tmuxinator list 列出当前全部的项目
tmuxinator copy [source] [destination] 复制项目配置文件
tmuxinator delete [name] 删除项目配置文件
tmuxinator implode 删除全部当前的项目配置文件
tmuxinator doctor 诊断 tmuxinator 及系统中的配置文件

参考资源:

tmux: Productive Mouse-Free Development

相关文章
相关标签/搜索