Linux ssh命令详解

Linux ssh命令详解

什么是SSH? 简单说,SSH是一种网络协议,用于计算机之间的加密登录。        

SSH(远程连接工具)连接原理:ssh服务是一个守护进程(demon),系统后台监听客户端的连接,ssh服务端的进程名为sshd,负责实时监听客户端的请求(IP 22端口),包括公共秘钥等交换等信息。

ssh服务端由2部分组成: openssh(提供ssh服务)    openssl(提供加密的程序)

ssh的客户端可以用 XSHELL,Securecrt, Mobaxterm等工具进行连接

SSH的工作机制 

      服务器启动的时候自己产生一个密钥(768bit公钥),本地的ssh客户端发送连接请求到ssh服务器,服务器检查连接点客户端发送的数据和IP地址,确认合法后发送密钥(768bits)给客户端,此时客户端将本地私钥(256bit)和服务器的公钥(768bit)结合成密钥对key(1024bit),发回给服务器端,建立连接通过key-pair数据传输。       

SSH的加密技术

加密技术:传输过程,数据加密。             
1.SSH1没有对客户端的秘钥进行校验,很容易被植入恶意代码 
2.SSH2增加了一个确认联机正确性的Diffe_Hellman机制,每次数据的传输,Server都会检查数据来源的正确性,避免黑客入侵。                    
  SSH2支持RSA和DSA密钥    
        DSA:digital signature Algorithm  数字签名
        RSA:既可以数字签名又可以加密      

SSH知识小结           

   1.SSH是安全的加密协议,用于远程连接Linux服务器                
   2.SSH的默认端口是22,安全协议版本是SSH2                
   3.SSH服务器端主要包含2个服务功能SSH连接和SFTP服务器                
   4.SSH客户端包含ssh连接命令和远程拷贝scp命令等 

如何防止SSH登录入侵            

    1.密钥登录,更改端口                
    2.牤牛阵法                
    3.监听本地内网IP(ListenAddress 192.168.25.*)

SSH功能大全   

1.登录                   

       ssh -p22 [email protected]               

   2.直接执行命令  -->最好全路径                   

       ssh [email protected] ls -ltr /backup/data                       

           ==>ssh [email protected] /bin/ls -ltr /backup/data               

   3.查看已知主机                    

        cat /root/.ssh/known_hosts

   4.ssh远程执行sudo命令

       ssh -t [email protected] sudo rsync hosts /etc/



   5.scp               

             1.功能   -->远程文件的安全(加密)拷贝                   

                 scp -P22 -r -p /home/omd/h.txt [email protected]:/home/omd/               

             2.scp知识小结                   

                 scp是加密远程拷贝,cp为本地拷贝                   

                 可以推送过去,也可以拉过来                   

                 每次都是全量拷贝(效率不高,适合第一次),增量拷贝用rsync



   6.ssh自带的sftp功能               

             1.Window和Linux的传输工具                   

                  wincp   filezip                   

               sftp  -->基于ssh的安全加密传输                   

               samba   

             2.sftp客户端连接                   

                sftp -oPort=22 [email protected]                   

                put /etc/hosts /tmp                   

                get /etc/hosts /home/omd   

            3.sftp小结:                   

                1.linux下使用命令: sftp -oPort=22 [email protected]                   

                2.put加客户端本地路径上传                  

                3.get下载服务器端内容到本地                   

                4.远程连接默认连接用户的家目录

ssh常见命令参数

usage: ssh [-1246AaCfgKkMNnqsTtVvXxYy] [-b bind_address] [-c cipher_spec]

           [-D [bind_address:]port] [-e escape_char] [-F configfile]

           [-i identity_file] [-L [bind_address:]port:host:hostport]

           [-l login_name] [-m mac_spec] [-O ctl_cmd] [-o option] [-p port]

           [-R [bind_address:]port:host:hostport] [-S ctl_path]

           [-W host:port] [-w local_tun[:remote_tun]]

           [user@]hostname [command]

关于后台ssh服务的相关
 

# 查询openssl软件
    rpm -qa openssh openssl
# 查询sshd进程
    ps -ef | grep ssh
        --> /usr/sbin/sshd
# 查看ssh端口
    netstat -lntup | grep ssh  
    ss | grep ssh                (效果同上,同下,好用)
    netstat -a | grep ssh(记住这个)
    netstat -lnt | grep 22    ==>  查看22端口有没有开/ssh服务有没有开启
    技巧: netstat -lnt | grep ssh | wc -l -->只要大于2个就是ssh服务就是好的
# 查看ssh的秘钥目录
    ll /root/.ssh/known_hosts  # 当前用户家目录的.ssh目录下
# ssh的配置文件
    cat /etc/ssh/sshd_config   
# ssh服务的关闭
    service sshd stop
# ssh服务的开启:
    service sshd start
# ssh服务的重启
    service sshd reload    [停止进程后重启] ==> 推荐
    service sshd restart   [干掉进程后重启] ==> 不推荐
# ssh远程登录
    ssh 192.168.1.100      # 默认利用当前宿主用户的用户名登录
    ssh [email protected]  # 利用远程机的用户登录
    ssh [email protected]  -o stricthostkeychecking=no # 首次登陆免输yes登录
    ssh [email protected] "ls /home/omd"  # 当前服务器A远程登录服务器B后执行某个命令
    ssh [email protected] -t "sh /home/omd/ftl.sh"  # 当前服务器A远程登录服务器B后执行某个脚本

 

image

ssh免密设置

1、进入用户的家目录

[root@localhost ~]# cd /root/.ssh/       【root用户就在root目录下的.ssh目录】

[root@localhost ~]# cd /home/omd/.ssh/   【普通用户就是在家目录下的.ssh目录】


2、根据DSA算法生成私钥和公钥【默认建立在当前用户的家目录】image

[root@localhost .ssh]# ssh-keygen -t dsa     # 一路回车即可
                id_dsa         -->私钥(钥匙) 
                id_dsa.pub     -->公钥(锁)

3.拷贝公钥给目标服务器image

 

[root@localhost .ssh]# ssh-copy-id -i id_dsa.pub [email protected]         【 使用ssh登录的默认端口22】
[root@localhost .ssh]# ssh-copy-id -i id_dsa.pub –p 666 [email protected]  【使用ssh登录设置的端口666】

4. 查看目标服务器生成的文件

[omd@localhost .ssh]$ ll /home/omd/.ssh/authorized_keys

5. 免密码登录目标服务器

ssh [email protected]

 

6. 总结一下钥匙和锁的关系

1.多个钥匙开一把锁
      把id_dsa.pub 复制给各个服务器
 
2.一个钥匙开duobasuo
      把id_dsa 传给各个服务器
      把id_dsa 传给自己 

ssh排查问题


1.判断物理链路是否通  ping 192.168.25.130     线路 | 防火墙 | 是否同一个网的
                    ping   本身是icmp协议
2.判断服务是否正常
telnet 192.168.25.130 22

3.Linux防火墙
service iptables status ==>  /etc/init.d/iptables status  

4.打开ssh的调测进行观察
ssh -vvv [email protected]

原文地址:https://www.cnblogs.com/ftl1012/p/ssh.html

你可能感兴趣的:(Linux ssh命令详解)