实现ssh自动登陆的三种方式

要实现ssh自动登录,
主要有三种方法:
1、生成公私钥。
2、编写expect脚本。
3、用sshpass。
用法:

    sshpass 参数 SSH命令(ssh,sftp,scp等)。
    参数:
        -p password    //将参数password作为密码。
        -f passwordfile //提取文件passwordfile的第一行作为密码。
        -e        //将环境变量SSHPASS作为密码。

    比如说:
        scp [email protected]:/home/xxx/test /root   这个命令的作用是将服务器端文件test传到本地文件夹/root下。
        利用sshpass,假设密码为efghi,则可写作:
        ssh -p efghi scp [email protected]:/home/xxx/test /root

另外,对于ssh的第一次登陆,会提示:“Are you sure you want to continue connecting (yes/no)”,这时用sshpass会不好使,解决方法:
1.可以在ssh命令后面加上 -o StrictHostKeyChecking=no来解决。比如说上面的命令,就可以写作ssh -p efghi scp [email protected]:/home/xxx/test /root -o StrictHostKeyChecking=no。
2.或者写入配置文件:把 StrictHostKeyChecking no 加到/etc/ssh/ssh config 可以让ssh客户端自动接受新主机的hostkey,不用每次都自己输入yes
 
 
交叉编译arm版本,
在sshpass目录执行:
./configure
./make CC=arm-linux-gcc
 
自动传文件:
./sshpass -p 111111 ./scp -S ./ssh -o StrictHostKeyChecking=no  -r ./test.file [email protected]:./
 
 

sshpass依赖pts,若pst没有加载,则执行

Bash代码

  1. mknod -m 666 /dev/ptmx c 5 2  
  2. #chmod 666 /dev/ptmx  
  3. mkdir /dev/pts       
  4.          
  5. #编辑/etc/fstab,加入:  
  6.       none             /dev/pts         devpts         gid=5,mode=620    0 0  
  7.   
  8. mount /dev/pts  

你可能感兴趣的:(c,服务器,脚本,ssh,bash)