putty解决乱码.docx
《putty解决乱码.docx》由会员分享,可在线阅读,更多相关《putty解决乱码.docx(59页珍藏版)》请在冰豆网上搜索。
putty解决乱码
putty中文乱码问题解决
用putty从windowsxp连接ubuntuserver或者FreeBSD系统,其中中文部分乱码,经常遇到这个问题的时候,会觉得很郁闷。
现共享一些解决这个问题的方法。
###方法一:
打开putty主程序,选择window-〉Appearance-〉Fontsettings-〉ChangeSettings,选择Fixedsys字体,字符集选择CHINESE。
在window-〉Appearance-〉Translation中,Receiveddataassumedtobeinwhichcharacterset中,把Usefontencoding改为UTF-8
如果经常使用,把这些设置保存在session里面.
保存方法:
再做完以上操作的同时选中以下两项:
在window-〉Appearance-〉Translation中,选中:
TReatCJKambiguouscharactersaswide和CapsLockactsasCyrillicswitch即可。
###方法二:
编辑/etc/sysconfig/i18n
把第1句“LANG=”zh_CN.UTF-8″”改为“LANG=”zh_CN.GB18030″”,完成后保存重新登录即可。
##方法三:
打开putty,登录成功后,在shell中输入
#exportLC_ALL=‘zh_CN.utf8′
#vi~/.bash_profile
LANG=zh_CN.GB18030
LANGUAGE=zh_CN.GB18030:
zh_CN.GB2312:
zh_CN
exportLANGLANGUAGE
精彩PuTTY中文教程(解决乱码、X窗口、自动登陆等问题)
PuTTY中文教程
作者:
柴锋 2006年11月
Web:
[url][/url]
email:
putty-tutorial[0x40]chaifeng[0x2E]com
Links:
[url]
更新记录
∙2006-11-29
初步完成想写的这些东西
∙2007-06-11
PuTTY的最新版本到了0.6;修改了一下SSH隧道;添加了SSH反向隧道;添加了用SSH做代理服务器;
版权声明
ThisdocumentislicensedunderaCreativeCommonsLicense.
CreativeCommonsDeed署名2.5
CreativeCommonsAttribution2.5
您可自由:
∙复制、发行、展览、表演、放映、广播或通过信息网络传播本作品
∙创作演绎作品
∙对本作品进行商业性使用
惟须遵守下列条件:
署名.您必须按照作者或者许可人指定的方式对作品进行署名。
∙对任何再使用或者发行,您都必须向他人清楚地展示本作品使用的许可协议条款。
∙如果得到著作权人的许可,您可以不受任何这些条件的限制。
您的合理使用以及其他权利不受上述规定的影响。
这是一份普通人可以理解的法律文本(许可协议全文)的概要。
免责声明
序言
懒,是一个优点,有些时候还是要学一学才能会了的。
——柴锋(1979- )
我的这些文字是从这几年来的PuTTY使用经验中慢慢得来的,也不仅仅是介绍PuTTY,还包括了一些相关的软件,比如:
优秀的FTP工具FileZilla、功能强大的SFTP客户端WinSCP。
杂七杂八的乱说了一些,这里把大致内容罗列如下:
∙最简单的使用,登录SSH主机
∙中文乱码的处理
∙PuTTY常用配置的说明
o复制、粘贴
o保存会话
o注销
o自动登录用户名
o自动设置环境变量
o设置代理服务器
o自动执行命令
o备份、删除PuTTY的设置
∙PuTTY的X11转发
∙如何用PuTTY建立SSH隧道
∙如何用PuTTY建立反向的SSH隧道,像个特洛伊木马一样突破防火墙
∙把PuTTY作为一个安全的代理服务器
o安全的上网不被嗅探
o避免MSN等聊天工具被监听
∙怎样用PSCP、PSFTP安全的传输文件
o功能强大的SFTP客户端WinSCP
∙用PuTTYgen生成密钥,登录SSH主机不再需要口令
∙Pagent代理密钥,每次开机只需要输入一次密钥口令
∙Plink简单而又迅速的执行SSH主机上的程序
∙常见问题
除了上面的这些,还夹杂了一些PuTTY使用上的技巧、服务器配置的一些安全建议。
说起来这是一些有关PuTTY的使用教程,其实也就是SSH的参考教程,绝大多数的内容在其他系统或软件上也都是一样的。
不同的是参数、配置、命令行之类的,只要会了一个,其他也就触类旁通了。
一些基本知识
如果你已经知道SSH、Telnet、Rlogin这是什么,就跳过这一部分,看下面的吧。
(以后补充,暂时空下)
简介
PuTTY的官方网站:
[url]http:
//www.chiark.greenend.org.uk/~sgtatham/putty/[/url],截止到2006年11月,发布的最高稳定版本是0.582007年6月,发布的最高稳定版本是0.6。
PuTTY是一个跨平台的远程登录工具,包含了一组程序,包括:
∙PuTTY(Telnet和SSH客户端)
∙PSCP(SCP客户端,命令行下通过SSH拷贝文件,类似于Unix/Linux下的scp命令)
∙PSFTP(SFTP的命令行客户端,类似于FTP的文件传输,只不过使用的是SSH的22端口,而非FTP的21端口,类似于Unix/Linux下的sftp命令)
∙PuTTYtel(仅仅是一个Telnet客户端)
∙Plink(命令行工具,执行远程服务器上的命令)
∙Pageant(PuTTY、PSCP、Plink的SSH认证代理,用这个可以不用每次都输入口令了)
∙PuTTYgen(用来生成RSA和DSA密钥的工具).
虽然包含了这么多,但平时经常见到只是用PuTTY登录服务器,完全没有发挥出PuTTY的强大功能。
PuTTY作为一个组件也存在于很多的软件中,比如FileZilla、WinSCP
在后面的文字中,如非特别说明,默认的登录的协议是SSH。
毕竟用PuTTY主要就是登录SSH主机,用Telnet、RLogin没法体现出PuTTY的强大功能。
安装
下载页面在这里:
[url]http:
//www.chiark.greenend.org.uk/~sgtatham/putty/download.html[/url]
PuTTY需要安装么?
需要么?
需要么?
真的需要么?
不需要。
PuTTY是一个准绿色软件,说它绿色是因为直接就能使用,完全没有任何的安装程序。
准绿色是指PuTTY的所有配置都保存到了注册表,如果不记得备份注册表中的相关内容,下次重装机器所有配置就没了,而且配置也不方便用闪存盘随身携带。
但是PuTTY的配置删除还是蛮方便的,运行时指定个参数-cleanup就可以清除PuTTY的所有配置信息。
第一印象,开始登录一台远程主机
运行PuTTY就可以看到下面这个界面
在这里输入服务器的IP或主机名,选择好登录协议,还有协议的端口,如果希望把这次的输入保存起来,以后就不需要再重新输入了,就在第4步输入好会话保存的名称,比如:
mail-server,或者干脆就是主机的地址,点击保存就可以了。
最后点下面的Open按钮,输入正确的用户名和口令,就可以登录服务器了。
首次登录一台主机时
第一次登录时,会看到这个对话框
这是要告诉你登录的主机密钥指纹,点Yes就保存起来,以后就不会再弹出这个窗口,然后就正常登录。
点No不保存,下次还是要提示你,然后也可以正常登录。
如果一台主机我们只是临时登录一下,当然就是点No了。
Cancel就是取消,也就是取消了这次登录。
如果你曾经登录过这台主机,但是又弹出来这个对话框,可能有以下几种情形:
∙主机重新安装了操作系统
∙这台主机可能有多个IP,这次用的是另外一个IP
∙有其他不怀好意的主机来冒充,诱骗我们登录,窃取隐秘信息
前两个情形很常见,一般点Yes就行了。
后面这个嘛……唔……唔……,点No/Cancel,再去询问相关的主机管理人员。
又看到了中文乱码
成功登录主机后,输入命令,这……这……显示,又是乱码。
唉,中文乱码是一个老生常谈的问题,提起来就头大。
原因嘛,不外乎字符集、终端编码之类的,还是可以解决的。
PuTTY的默认字体和字符集并不适合中文显示,在窗口标题上点击右键,选择ChangeSettings...
在打开的配置窗口左边选择Appearance,在右边点Fontsettings里面的Change按钮,选择好中文字体,比如:
宋体、新宋体之类的
字体选择好了,还要确定字符集。
选择配置窗口左边的Translation,在右边的Receiveddataassumedtobeinwhichcharacterset下拉列表中选择最后一个“Usefontencoding”,最后点下面的Apply按钮就生效了。
重新执行命令ls-l,就可以正常看到中文了
怎么还是乱码?
如果还是乱码的话,就执行以下命令,看看系统的字符集
echo$LANG$LANGUAGE
哦,原来系统的字符集是UTF-8呀。
重新返回上面选择字符集的那一步,选择配置窗口左边的Translation,在右边的Receiveddataassumedtobeinwhichcharacterset下拉列表中选择“UTF-8”
这下99%的情形下,汉字是不会有乱码了。
最后,总之一下PuTTY中乱码的解决办法:
先看看系统的字符集,如果是UTF-8的,那就简单了,选择好中文字体,然后编码选择UTF-8就行了。
如果编码是GB2312、GBK、GB18030,当然也包括BIG5这些,在PuTTY的编码选择中看不到这些编码,那就选择最后一个“Usefontencoding”,绝大部分情况下这样就没啥问题了,反正我是没碰到有什么例外的情况。
现在的Linux如果默认语言选择为中文,默认的编码就是UTF-8了。
以前安装RedhatAS3时,语言选择为中文,默认的编码是zh_CN.gb2312,zh_CN.gb18030,好像从AS3update6开始,包括现在的AS4、AS5,中文的默认编码都成了zh_CN.utf8。
至于Debian、Ubuntu等等这些上面,好像一直都是UTF-8。
至于是使用UTF-8呢,还是用GB2312、GBK或者GB18030呢?
我个人还是倾向于UTF-8。
毕竟我们使用的大多数软件都是国外的,处理中文编码多多少少有些问题,PuTTY自然也不例外。
下面的这个图上,我把终端编码修改为zh_CN.utf8,然后也按照前面的所说的方法把PuTTY的字符集修改为UTF-8。
然后在终端中输入汉字“柴锋”,按左方向键,可以看到汉字显示很正常。
我重新把终端的编码修改为zh_CN.gb2312,同样的,把PuTTY的字符集修改为最后一个“Usefontencoding”。
还是在终端上输入汉字“柴锋”,按下左方向键以后,会看到汉字乱码了。
至于用哪个编码,主要还是看领导的决定了,我们的领导就喜欢GBK,连GB18030都不行。
以前在用Debian的时候,好像默认都不支持GBK编码。
这几年公司的开发在汉字编码问题上出过几次麻烦,还不就是在ISO8859-1,GB2312/GBK/GB18030和UTF-8上折腾来折腾去。
给大家看一张emacs的截图,看看上面的这么多语言的文字共同显示,这个会是用GB2312/GBK/GB18030的编码么?
用UTF-8也不是为了要在一个屏幕上显示好几种不认识的文字,也不一定非要是跟国际接轨弄个外包给老外开发程序做个其他语言的界面让老外用,起码不要在那么多编码里折腾了,顶多两个ISO8859-1和UTF-8。
发发牢骚,下面继续……
在PuTTY里面怎样选中,复制和粘贴?
在PuTTY的窗口里面复制、粘贴可不能用Windows里的这些Ctrl+C,Ctrl+Ins,Ctrl+V这些快捷键,Ctrl+C在控制台上可是终止当前的命令执行。
PuTTY的选择、复制、粘贴这些操作都是通过鼠标来完成的。
在Window-〉Selection这里可以设置复制和粘贴的方式。
默认的Actionofmousebuttons(鼠标按键的功能)的选项是Compromise,这种方式下选中有两种方式,一是直接用鼠标左键拖拉选中就可以了,二是用鼠标中键单击选中区域的开头,用滚动条拖拉到期望选中区域的末尾,再用鼠标中键单击,就可以选中了。
选中以后,单击鼠标左键就把选中部分复制到剪贴板了。
粘贴也很简单,单击鼠标右键。
Actionofmousebuttons的第一个选项是Windows(Windows方式的),鼠标中键的操作跟前面提到的一样。
右键不是粘贴了,而是打开了右键菜单。
其实这个右键菜单在标题栏上点击,也都可以看得到。
第三个选项是xterm(xterm方式),这个跟默认的Compromise方式相反的,中键和右键的操作调换了一下,就不多说了。
下面那个Shiftoverridesapplication'suseofmouse是和Shift键有关的。
有些RogueLike的程序,比如mc、links、Lynx、VIM等等,都支持鼠标操作,想在用鼠标在上面选择或粘贴就不行了。
这个选项默认是选中的,在支持鼠标操作的RogueLike界面下,按住Shift键,就可以像前面的那样用鼠标来选择、复制、粘贴了。
看下面的这个图片,用Links打开了Google的首页,用鼠标去选中顶部中间的Google,我们会发现,弹出了保存的对话框。
按住Shift键重新操作一次,哈哈,这次选中了。
在Controluseofmouse里面还有个Defaultselectionmode(默认的选择模式),默认是Normal,就像文字处理工具里这样的选择
另外一个是Rectangularblock(块选择方式),至于用哪种方式就看自己的选择了。
实时保存会话
这次更改配置参数了,关闭窗口后,下次使用还是要重新选择的,麻烦。
还是回到上面修改配置的哪个地方,选择左边的Session,在右边选择要覆盖的会话名称,或者重新输入一个新的名称,点击Save按钮保存。
关于注销登录的一些事情
成功登录主机后,也能正常看到中文了。
这样,我们就可以完成大部分的工作。
最后要关闭窗口了,该怎么办呢?
我见过很多人,包括我们公司负责专职维护的同事,都是直接点击窗口上的关闭按钮,完全没有理会弹出警告窗口,直接点击了Yes。
这样做是不对的,首先这不是正确的注销方式,应该输入命令exit来正常注销;其次直接关闭窗口后,你的登录其实还在服务器上,如果一连多次的这样强制关闭窗口,用命令w或者who命令查看时,可以看到很多的用户还在系统上登录,占用了系统的资源。
最重要的是,你的这次登录可能只是为了启动一下WebLogic或者其他什么应用服务器,直接关闭窗口后,可能会导致你的业务在随后的几分钟内也被终止,这应该不是你所希望看到的吧。
如果上述的理由是每次要输入exit然后回车,比较麻烦。
你可以用快捷键Ctrl+d来注销登录,一般情况下,快捷键一按窗口都直接关闭了,还省了两次鼠标点击。
在前面说道保存会话时,大家或许也注意到,下面有个Closewindowonexit有三个选项:
∙Always(不管怎样,窗口总是要关闭的)
∙Never(无论是否有程序还在运行,都不要关闭窗口)
∙Onlyonclearexit(这个是默认选中的,只有在本次登录中运行的程序都正常终止或者在后台运行,窗口才关闭)
有的程序在执行时,虽然在命令最后面加上“&”就能放到后台运行。
但是正常注销登录后,窗口没有被自动关闭,还能看到程序的输出,这时强制关闭窗口还是可以的。
为了避免这种情形,可以使用nohup命令。
用法嘛就是:
nohup命令命令参数,这样就可以了。
窗口保存的输出有点少,前面的都看不到了
执行了一个命令,输出了好多东西,但是默认的配置下,PuTTY只保存了最后200行的内容,满足不了我们的需求。
还是在标题栏上点右键选择Changesettings...,在配置窗口的左边选择Window,修改右边的Linesofscrollback,改大点,比如20000、80000的
在上面的Setthesizeofthewindow里设置的是窗口显示的行数和列数,默认是24行、80列,根据自己的需要来修改吧。
Whenwindowisresized这个选项配置的是,当窗口大小发生改变时该采取什么动作。
∙Changethenumberofrowsandcolumns(这个是默认的,改变窗口大小时,自动修改行数和列数)
∙Changethesizeofthefont(这个是根据窗口的大小来修改字体的大小,窗口最大化的时候,字都是很大的)
∙Changefontsizeonlywhenmaximised(只有在窗口最大化的时候才改变字体大小)
∙Forbidresizingcompletely(完全禁止改变窗口大小,一了百了)
在现代的Unix/Linux主机上,默认选项已经不存在任何问题了。
如果是Solaris8这样的老式Unix上最好用第2或第4个选项。
第3个选项嘛,要求你的屏幕不是宽屏的,选中这个选项以后,大家可以先把窗口往窄的缩一下,然后最大化窗口,哈哈,满足一下不是宽屏的虚荣心。
顺便说一下,在PuTTY中的前后翻页,与Linux终端一样,用Shift+PageUp/PageDown来上下翻页,而Ctrl+PageUp/PageDown则是一行一行的。
新建一个会话时,还有些东西再啰嗦一下
前面把如何用PuTTY登录一台主机到注销的过程聊了一遍,但是在新建会话时还是有些东西需要再啰嗦一下的。
保持连接,不要自动断开
在Connection里面有个Secondsbetweenkeepaliaves,这里就是每间隔指定的秒数,就给服务器发送一个空的数据包,来保持连接。
以免登录的主机那边在长时间没接到数据后,会自动断开SSH的连接。
默认输入0是禁用保持连接,在这里我习惯的设置了10。
下面的那两个复选框都保持默认选中吧。
自动登录用户
在Connection-〉Data里面有个Auto-loginusername,可以指定默认的登录用户。
如果每次登录主机都是用同一个用户,不妨在这里设置一下。
SSH、Telnet、Rlogin这三种协议都支持,但不是所有的Telnet服务器支持自动登录用户
自动设置环境变量
还是前面的那个界面,下面有个Environmentvariables,在Variable输入环境变量的名称,Value里设置上环境变量的值,登录主机后就会自动设置上,但是这个不一定能用,有些主机为了安全,可能会禁用这个特性,一旦登录就会收到这样一个错误提示:
Serverrefusedtosetenvironmentvariables
设置代理服务器
这个经常用到,设置方法大同小异,注意选择好Proxytype(代理服务器的类型)就可以了。
代理服务器的地址填写到Proxyhostname这里,Port就是代理服务的端口(HTTP代理常用端口有3128、8080,Socks5代理常用端口有1080)
ExcludeHosts/IPs这里是填写排除的主机地址和IP,有些地址不需要代理,就在这里填写。
有些代理需要认证,用户名填写到Username,密码则填写到下面的Password。
自动执行一个命令
在Connection-〉SSH里有个Remotecommand,在这里面填写上远程服务器上的某个命令,比如:
df,登录后就会自动执行。
我们在Unix上用ssh登录主机时用的命令ssh,在ssh的最后面加上远程主机上的命令,就跟这个一样。
但是……,先别着急,一旦设置上这个选项,你会发现在登录成功后,窗口一下就关闭了,嘿,怎么啦?
什么也没看见。
因为命令执行完毕的同时,本次SSH登录连接也随之关闭。
你可以把远程自动执行的命令修改成sleep10,然后重新登录,再看看效果。
登录成功后,没有出现命令提示符,10秒钟后,窗口自动关闭。
这也验证了刚才我说的,命令执行完毕后,SSH连接自动断开。
冰雪聪明的你一定会想到,如果每次登录主机,都是要重新启动一下tomcat,那这里就可以填写上这样的命令:
exportCATALINA_HOME="~/apache-tomcat-5.5.17";exportJAVA_HOME="~/jdk1.5.0_07";exportPATH=$JAVA_HOME/bin;$PATH;cd$CATALINA_HOME/bin;./shutdown.sh;./startup.sh;tail-f$CATALINA_HOME/logs/catalina.out
(上面的命令是一行的哦)
先自动设置一下环境变量(前面有提到,服务器可能会禁用自动设置环境变量,为了保险起见,在这里设置了一下),然后进入tomcat的bin目录,用shutdown.sh停止tomcat,然后再startup.sh启动tomcat,最后tail命令持续观察tomcat的日志输出,不想看了,就直接Ctrl+C就可以终止SSH的会话了。
哈哈,是不是很方便?
不过前面提到的命令sleep10,只是建立了SSH连接,然后10秒钟后自动断开。
是不是觉得很无聊没什么用途啊?
其实这