Chinaunix首页 | 论坛 | 博客
  • 博客访问: 536113
  • 博文数量: 55
  • 博客积分: 1520
  • 博客等级: 上尉
  • 技术积分: 661
  • 用 户 组: 普通用户
  • 注册时间: 2009-04-19 22:01
文章存档

2013年(1)

2012年(1)

2011年(7)

2010年(16)

2009年(30)

我的朋友

分类: LINUX

2009-07-01 10:37:20

CU上一位网友的问题如下:
        以前一直用windows,最近工作原因换Ubuntu了,但是windows下的SSH客户端(我用的是Netsarang公司的 Xshell,Xftp,Xmanager),linux没有相应版本,尝试了下putty,觉得很不好用,最重要的是要保存10多个服务器的密码。说明一下,密码是系统产生的随机长串,无法记忆的,公司的运维统一管理的,所以别跟我说什么更换成key文件之类的,我就要找个Linux下可以保存密码的 SSH客户端,命令行还是图形化界面都无所谓,谢谢大家!

        我第一次看到问题时还在纳闷,Linux自带ssh命令,还需要ssh客户端干什?后来一看,这位朋友是想记住服务器的密码。
        懒人!!
        懒人有懒人的福,解决方案还是有的。


        我的解决方案如下:
        1. 先安装sshpass
        下载:wget
        安装:
        tar -zxvf sshpass-1.04.tar.gz
        cd sshpass-1.04
        ./configure
        make && make install
        
        2. 再写一个管理sshpass的BASH脚本.
        脚本文件名为:/opt/program/bash/test.sh
        脚本内容如下:
                #!/bin/bash
                cat <                        1) localhost
                        2) 192.168.100.100
                        3) 加上你的主机
                MENU
                echo -n "Your choose:"
                read host
                case "$host" in
                        1)
                                exec /usr/local/bin/sshpass -p 123456(这是我机器的密码) ssh huabo@localhost
                                ;;
                        2)
                                exec /usr/local/bin/sshpass -p 123456 ssh huabo@192.168.100.100
                                ;;
                        3)
                                你的登录命令
                                ;;
                        *)
                                echo "Error, No host"
                                ;;
                esac


        3.测试一下
                [root@server bash]# ./test.sh
                        1) localhost
                        2) 192.168.100.100
                Your choose:2
                Last login: Mon Jun 29 02:34:49 2009 from 192.168.100.100
                [huabo@server ~]$ ls
                opera.exe  zabbix-1.6.4  zabbix-1.6.4.tar.gz
                [huabo@server ~]$
        测试成功!你只需把密码写到脚本里面,执行此脚本,选择相应的主机就行了.
        此脚本还可优化一下,搞成:test.sh localhost这种形式更方便。
        此外还要注意一点,你需要先手动登录一次,因为第一次登录时会提示:
                Are you sure you want to continue connecting (yes/no)?
        (脚本没考虑这点)

       
        PS:你自己把密码存脚本里的哈,出了问题不要怪我.
        (先前的expect脚本不对,这是第二版,放心用吧。非常感谢 seaquester,推荐一下他的BASH脚本http://blog.chinaunix.net/u2/73823/showart.php?id=1982819)
阅读(5858) | 评论(7) | 转发(0) |
0

上一篇:BASH学习手册

下一篇:很牛的vim使用技巧

给主人留下些什么吧!~~

chinaunix网友2009-07-08 18:21:42

哈哈。不好意思。linux记住ssh密码的还没用过。 windows的是secureCRT .

chinaunix网友2009-07-05 17:04:56

使用SecureCRT ssh客户端就可以保存密码啊。 还去写个脚本

chinaunix网友2009-07-03 09:03:21

我密码全一样,123

chinaunix网友2009-07-02 07:17:11

好,学习了。

seaquester2009-07-01 14:35:32

我试着写了一个,比较简陋,仅供参考: http://blog.chinaunix.net/u2/73823/showart.php?id=1982819