zoukankan      html  css  js  c++  java
  • nc命令详解

    NetCat,在网络工具中有“瑞士军刀”美誉,其有Windows和Linux的版本。因为它短小精悍(1.84版本也不过25k,旧版本或缩减版甚至更小)、功能实用,被设计为一个简单、可靠的网络工具,可通过TCP或UDP协议传输读写数据。同时,它还是一个网络应用Debug分析器,因为它可以根据需要创建各种不同类型的网络连接。

    通常的Linux发行版中都带有NetCat(简称nc),但不同的版本,其参数的使用略有差异。

    NetCat 官方地址:http://netcat.sourceforge.net/

    安装

    [root@server ~]# yum install -y nc
    [root@server ~]# rpm -q nc
    nc-1.84-22.el6.x86_64

    版本参数简介
    语  法:nc [-hlnruz][-g<网关...>][-G<指向器数目>][-i<延迟秒数>][-o<输出文件>][-p<通信端口>][-s<来源地址>][-v...][-w<超时秒数>][主机名称][通信端口...]

    补充说明:执行本指令可设置路由器的相关参数。

    参  数:

    -g<网关> 设置路由器跃程通信网关,最多可设置8个。

    -G<指向器数目> 设置来源路由指向器,其数值为4的倍数。

    -h 在线帮助。

    -i<延迟秒数> 设置时间间隔,以便传送信息及扫描通信端口。

    -l 使用监听模式,管控传入的资料。

    -n 直接使用IP地址,而不通过域名服务器。

    -o<输出文件> 指定文件名称,把往来传输的数据以16进制字码倾倒成该文件保存。

    -p<通信端口> 设置本地主机使用的通信端口。

    -r 乱数指定本地与远端主机的通信端口。

    -s<来源地址> 设置本地主机送出数据包的IP地址。

    -u 使用UDP传输协议。

    -v 显示指令执行过程。

    -w<超时秒数> 设置等待连线的时间。

    -z 使用0输入/输出模式,只在扫描通信端口时使用。

    远程拷贝文件

    从server1拷贝文件到server2上。需要先在server2上,用nc激活监听。

    server2:

    [root@server2 ~]# nc -l 1234 > 1234.txt

    server1:

    [root@server1 ~]# cat abc.txt 
    abc.txtabc.txtabc.txtabc.txtabc.txtabc.txtabc.txtabc.txtabc.txt
    [root@server1 ~]# nc -w 1 192.168.200.27 1234 < abc.txt

    已经传送到server2

    [root@server2 ~]# cat 1234.txt 
    abc.txtabc.txtabc.txtabc.txtabc.txtabc.txtabc.txtabc.txtabc.txt

    克隆硬盘或分区

    操作与上面的拷贝是雷同的,只需要由dd获得硬盘或分区的数据,然后传输即可。

    克隆硬盘或分区的操作,不应在已经mount的的系统上进行。

    #server2上进行类似的监听动作:

    [root@server2 ~]# nc -l -p 1234 | dd of=/dev/sda

    #server1上执行传输,即可完成从server1克隆sda硬盘到server2的任务:

    [root@server1 ~]# dd if=/dev/sda | nc 192.168.200.27 1234

    端口扫描

    复制代码
    [root@backup ~]# nc -v -w 1 192.168.200.29 -z 20-30
    nc: connect to 192.168.200.29 port 20 (tcp) failed: Connection refused
    nc: connect to 192.168.200.29 port 21 (tcp) failed: Connection refused
    Connection to 192.168.200.29 22 port [tcp/ssh] succeeded!
    nc: connect to 192.168.200.29 port 23 (tcp) failed: Connection refused
    nc: connect to 192.168.200.29 port 24 (tcp) failed: Connection refused
    nc: connect to 192.168.200.29 port 25 (tcp) failed: Connection refused
    nc: connect to 192.168.200.29 port 26 (tcp) failed: Connection refused
    nc: connect to 192.168.200.29 port 27 (tcp) failed: Connection refused
    nc: connect to 192.168.200.29 port 28 (tcp) failed: Connection refused
    nc: connect to 192.168.200.29 port 29 (tcp) failed: Connection refused
    nc: connect to 192.168.200.29 port 30 (tcp) failed: Connection refused
    复制代码

    聊天(呵呵,挺方便的。像QQ哦)

    server2:

    [root@server2 ~]# nc -l 1234 
    hello!
    hi!

    server1:

    [root@server1 ~]# nc  192.168.200.27 1234 
    hello!
    hi!
  • 相关阅读:
    Haproxy+Keepalived高可用环境部署梳理(主主和主从模式)
    使用nginx sticky实现基于cookie的负载均衡
    CENTOS 6.6初始化SHELL脚本
    Java 开源博客 Solo 1.2.0 发布
    Java 开源博客 Solo 1.2.0 发布
    Java多线程-synchronized关键字
    Maven项目pom.xml配置详解
    4.0 苹果系统安装之黑苹果(4)
    3.0 Windows和Linux双系统安装(3)
    2.0 Linux系统的安装之Fedora安装单系统(2)
  • 原文地址:https://www.cnblogs.com/wangmo/p/8696335.html
Copyright © 2011-2022 走看看