概述
nc是netcat的简写,有着网络界的瑞士军刀美誉。因为它短小精悍、功能实用,被设计为一个简单、可靠的网络工具
作用
- 实现任意TCP/UDP端口的侦听,nc可以作为server以TCP或UDP方式侦听指定端口
- 端口的扫描,nc可以作为client发起TCP或UDP连接
- 机器之间传输文件
- 机器之间网络测速
安装
使用前,如果还未进行安装,可以执行以下命令进行安装。(Centos)
yum install -y nc
基本语法
版本参数简介:
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输入/输出模式,只在扫描通信端口时使用。
检测端口是否占用
# nc -v -w 10 %IP% -z %PORT%
例1:扫描指定的80端口
# nc -v -w 10 -z 127.0.0.1 80
Connection to 127.0.0.1 80 port [tcp/http] succeeded!
例2:扫描范围内端口使用情况
# nc -w 3 -z 127.0.0.1 1-65535
Connection to 127.0.0.1 22 port [tcp/ssh] succeeded!
Connection to 127.0.0.1 25 port [tcp/smtp] succeeded!
Connection to 127.0.0.1 80 port [tcp/http] succeeded!
Connection to 127.0.0.1 443 port [tcp/https] succeeded!
Connection to 127.0.0.1 465 port [tcp/urd] succeeded!
Connection to 127.0.0.1 587 port [tcp/submission] succeeded!
Connection to 127.0.0.1 3306 port [tcp/mysql] succeeded!
CentOS7新版的nc命令已取消了-z, 需输入重定向 < /dev/null 才能成功
观测实时网络
[root@localhost test]# dstat
----total-cpu-usage---- -dsk/total- -net/total- ---paging-- ---system--
usr sys idl wai hiq siq| read writ| recv send| in out | int csw
1 0 99 0 0 0| 20k 15k| 0 0 | 0 0 | 241 519
1 0 99 0 0 0| 0 0 | 54B 704B| 0 0 | 242 475
0 1 99 0 0 0| 0 0 | 54B 838B| 0 0 | 249 493
1 0 99 0 0 0| 0 0 | 54B 358B| 0 0 | 229 478
0 0 100 0 0 0| 0 0 | 54B 358B| 0 0 | 224 472
0 0 100 0 0 0| 0 0 | 54B 358B| 0 0 | 228 482
0 0 99 1 0 0| 0 408k| 54B 358B| 0 0 | 236 488
1 1 98 0 0 0| 0 0 | 54B 358B| 0 0 | 236 488