我用tmux有一段时间了,工作中会用到它的「会话保持」这一功能。在「跳板机」上建一个tmux会话linux操作系统介绍,之后打开多个tmuxwindow,在每位window下ssh联接到「开发机」,这是十分普遍的开发方法。上班时我只要按bind-key+d脱离会话,笔记本塞子一合就可以走人,当前机器上的多个ssh联接、打开的文档、运行的程序,都毫无「违和感」地同步「下班」。
第二天下班,我联接到「跳板机」,简单地执行2个,就可以重新快速挂载到今天的tmux会话,之前构建的多个ssh联接、打开的文档、运行地程序,又都毫无「违和感」地同步「上班」,保持着明天的状态(其实,运行着的程序没有退出的意思)。构建tmux会话时我并没有指定名称,重新挂载到会话上十分简单:
[xiaojie.zhang1@FS67 ~]$ tmux ls // 列出当前的tmux会话, ls = list session
0: 4 windows (created Wed Nov 6 18:37:38 2013) [181x50] (attached)
[xiaojie.zhang1@FS67 ~]$ tmux attach -t 0 // 挂载到第一个会话, -t 0
但是使用过程中碰到一个屏幕显示错乱的问题,在ssh连上「开发机」后,在「开发机」上用vim打开包含有英文的代码,还会出现:
万能的google会告诉我在tmux的配置文件中添加2个utf8的项:
[xiaojie.zhang1@FS67 ~]$ grep utf8 ~/.tmux.conf
setw -g utf8 on
set -g status-utf8 on
添加了以后就出现了英文「乱码」。
这2个配置项是不能解决问题的,乱码的诱因有多个的好吗!!!!
终端的编码vim的编码tmux的编码系统的locale
对于第1点,我使用的iterm2,使用的字符编码为Unicode(UTF-8),嗯,早已是utf8了。
对于第2点,用vim的人都晓得,vim读写一个文件时,使用设置项fenc配置的编码linuxtar,例如utf8;而vim显示文件内容,使用的是另一个设置项tenc配置的编码,假若这2个配置的编码不一致,就才能看见vim的乱码。我先确认vim打开文件的编码和展示都用到utf8编码,二者编码一致:
:set fenc // 在vim行下
fileencoding=utf-8 // vim命令行下的输出
:set tenc // 同上
termencoding=utf-8
虽然,不用tmux,从「跳板机」ssh连上「开发机」linux git中文乱码,再使用vim打开任何文本,都是不会乱码的(由于vim配置了正确的编码方法)。
对于第3点,tmux添加了utf8的编码也没有疗效(虽然这2个是设置tmuxwindow的好吗),tmux的显示究竟是按照那里的配置??
到了第4点,确认是系统的locale问题了linux git中文乱码,tmux依赖于这种设置。因为我是在「跳板机」上使用tmux,tmux会使用到「跳板机」上的locale参数,查看:
[xiaojie.zhang1@FS67 ~]$ locale
LANG=en_US.en
LC_CTYPE="C"
LC_NUMERIC="C"
LC_TIME="C"
LC_COLLATE="C"
LC_MONETARY="C"
LC_MESSAGES="C"
LC_PAPER="C"
LC_NAME="C"
LC_ADDRESS="C"
LC_TELEPHONE="C"
LC_MEASUREMENT="C"
LC_IDENTIFICATION="C"
LC_ALL=C
果然!!!!于是再检测「跳板机」上是否早已安装zh_cn字符集:
[xiaojie.zhang1@FS67 ~]$ locale -a | grep -i zh_cn
zh_CN
zh_CN.gb18030
zh_CN.gb2312
zh_CN.gbk
zh_CN.utf8
没让我沮丧,有zh_cn.utf8,添加到profile里吧:
[xiaojie.zhang1@FS67 ~]$ grep -i utf ~/.bash_profile
export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"
kill掉tmux当前的会话,重新登入「跳板机」,新建一个tmux会话,再度确认tmux加载到新的locale
[xiaojie.zhang1@FS67 ~]$ tmux // 新建一个tmux会话和窗口
[xiaojie.zhang1@FS67 ~]$ locale // 进入tmux的窗口,再确认一次locale
LANG=zh_CN.UTF-8
LC_CTYPE="zh_CN.UTF-8"
LC_NUMERIC="zh_CN.UTF-8"
LC_TIME="zh_CN.UTF-8"
LC_COLLATE="zh_CN.UTF-8"
LC_MONETARY="zh_CN.UTF-8"
LC_MESSAGES="zh_CN.UTF-8"
LC_PAPER="zh_CN.UTF-8"
LC_NAME="zh_CN.UTF-8"
LC_ADDRESS="zh_CN.UTF-8"
LC_TELEPHONE="zh_CN.UTF-8"
LC_MEASUREMENT="zh_CN.UTF-8"
LC_IDENTIFICATION="zh_CN.UTF-8"
LC_ALL=zh_CN.UTF-8
tmux用到了utf8了,这时再ssh联接到「开发机」,vim打开之前的文件,乱码已成旧事,其实也不会显示错乱。
也就是说,若要「乱码」已成旧事,须要4个地方的编码:
终端使用utf8编码(例如我使用iterm2,item2的终端字符集为Unicode(UTF-8))
使用tmux的机器上(例如我这儿的「跳板机」),其个人profile的locale使用utf8
[xiaojie.zhang1@FS67 ~]$ grep -i utf ~/.bash_profile
export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"
每次登入就会export这2个环境变量,因而设置locale。
开发机」上vim设置utf8编码(linux)
xiaojie.zhang1@log83 ~$ grep enc ~/.vimrc
set enc=utf8
set fencs=utf8,gbk,gb2312,gb18030,cp936
vim里虽然没必要设置tenc,它会从fencs列表中选一个适宜的编码方法。
tmux倒是可以不设置utf8
推荐一个讲解vim编码方法的普及blog:VIM乱码缘由与解决方案
–EOF–
Categories:in_mac
Tags:iterm
本文原创地址://lrxjmw.cn/lzwlmsytsxwf.html编辑:刘遄,审核员:暂无