如今的计算机是离不开网络的计算机了,因而我们对网络要有一基础的认识。连不上网,程序运行不正常之类的,多少都与网络有关。本文将介绍常用的工具。

网络出问题 ipconfig ping

网络连不上,首先要看看网络的配置是否正确。一般使用 ipconfig 来查看当前各个网卡的工作状态:

C:\>ipconfig

Windows IP Configuration

Wireless LAN adapter 无线网络连接:

   Connection-specific DNS Suffix  . :
Link-local IPv6 Address . . . . . : fe80::7ddd:aa0c:a65a:67d3%12
IPv4 Address. . . . . . . . . . . : 192.168.1.100
Subnet Mask . . . . . . . . . . . : 255.255.255.0
Default Gateway . . . . . . . . . : 192.168.1.1 Ethernet adapter 本地连接: Media State . . . . . . . . . . . : Media disconnected
Connection-specific DNS Suffix . :

通过这一最简单的信息,可以得知当前的计算机是 192.168.1.0 网段中的 100 号机器。该网段中,1 号机器是网关。

注:掩码&网址 即 255.255.255.0 & 192.168.1.100 = 192.168.1.0 得到网段。

确定当前机器在正确的网段,并且网关都正确了。就要使用 ping 命令:

C:\>ping www.sina.com.cn

Pinging ara.sina.com.cn [58.63.236.34] with 32 bytes of data:
Reply from 58.63.236.34: bytes=32 time=42ms TTL=56
Reply from 58.63.236.34: bytes=32 time=52ms TTL=56
Reply from 58.63.236.34: bytes=32 time=52ms TTL=56
Reply from 58.63.236.34: bytes=32 time=49ms TTL=56 Ping statistics for 58.63.236.34:
Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),
Approximate round trip times in milli-seconds:
Minimum = 42ms, Maximum = 52ms, Average = 48ms

ping 命令实际上就是发出一定的数据出去,看目标机器是否能够响应,响应要多久时间。

跟踪路由 route tracert

通过 route 命令可以查看/修改计算机的路由表。计算机依据路由表来将数据发送给其它目标。

C:\>route print -4

IPv4 Route Table
===========================================================================
Active Routes:
Network Destination Netmask Gateway Interface Metric
0.0.0.0 0.0.0.0 192.168.1.1 192.168.1.100 30
127.0.0.0 255.0.0.0 On-link 127.0.0.1 306
127.0.0.1 255.255.255.255 On-link 127.0.0.1 306
127.255.255.255 255.255.255.255 On-link 127.0.0.1 306
192.168.1.0 255.255.255.0 On-link 192.168.1.100 286
192.168.1.100 255.255.255.255 On-link 192.168.1.100 286
192.168.1.255 255.255.255.255 On-link 192.168.1.100 286

通过 tracert 命令可以跟踪网络,查看当前机器通过哪条线路连接到目标机器的。

C:\>tracert www.sina.com.cn

Tracing route to ara.sina.com.cn [58.63.236.46]
over a maximum of 30 hops: 1 60 ms 49 ms 32 ms 218.18.112.1
2 58 ms 33 ms 55 ms 218.18.112.1
3 47 ms 56 ms 41 ms 113.106.43.165
4 46 ms 70 ms 37 ms 119.145.45.205
5 41 ms 42 ms 35 ms 121.15.141.181
6 43 ms 39 ms 44 ms 113.108.208.102
7 55 ms 40 ms 67 ms 113.108.209.130
8 84 ms 40 ms 51 ms 58.63.232.197
9 53 ms 39 ms 52 ms 58.63.236.46 Trace complete.

查看物理地址 arp ipconfig

通过使用 ipconfig /all 可以查看到各个网卡的物理地址。通过 arp

C:\>ipconfig /all

Wireless LAN adapter 无线网络连接:

   Connection-specific DNS Suffix  . :
Description . . . . . . . . . . . : Broadcom 802.11g Network Adapter
Physical Address. . . . . . . . . : 00-24-00-C2-8D-F0
DHCP Enabled. . . . . . . . . . . : Yes
Autoconfiguration Enabled . . . . : Yes
Link-local IPv6 Address . . . . . : fe80::7ddd:aa0c:a65a:67d3%12(Preferred)
IPv4 Address. . . . . . . . . . . : 192.168.1.100(Preferred)
Subnet Mask . . . . . . . . . . . : 255.255.255.0
Lease Obtained. . . . . . . . . . : 2012?10?25? 20:08:32
Lease Expires . . . . . . . . . . : 2012?10?26? 1:08:31
Default Gateway . . . . . . . . . : 192.168.1.1
DHCP Server . . . . . . . . . . . : 192.168.1.1
DHCPv6 IAID . . . . . . . . . . . : 218112256
DHCPv6 Client DUID. . . . . . . . : 00-01-00-01-14-E7-E7-A8-00-23-5A-35-E3-E3
DNS Servers . . . . . . . . . . . : 202.96.128.166
202.96.134.133
NetBIOS over Tcpip. . . . . . . . : Enabled

通过 arp 命令可以查看到目前本机上知道的 IP 与主机物理地址的对应关系

C:\>arp -a

Interface: 192.168.1.100 --- 0xc
Internet Address Physical Address Type
192.168.1.1 00-25-86-fc-3b-04 dynamic

arp 欺骗,是指将 IP 与物理地址的对应关系改变,让计算机找不到目标主机的真实物理机器。

抓包 windump

windump 是一个抓包命令,可以抓取 TCP/IP 的数据包,以便于分析传输的数据。windows 下默认不带该命令,可以下载 tcpdump

# 查看当前所有的网络接口(网卡)
windump -D
# 打印目标 tcp 端口为 80 的数据,0x0050 是 80
windump -i 3 tcp[2:2] == 0x0050
windump -i 3 tcp[2:2] == 80
windump -i 3 tcp dst port 80
# 打印所有的数据(默认只打印部分)
windump -xs 0 -i 3 host www.1si2.com and tcp port 80
# 打印数据到 d:/aaa 文件中(可以使用 wireshark 分析)
windump -w d:/aaa -xs 0 -i 3 host www.1si2.com and tcp port 80
# 打印数据时,只打印 IP 地址,不打印域名:
windump -n -i 3 host www.1si2.com and tcp port 80

在分析 HTTP 数据时,如果数据使用 gzip 压缩,数据以 1F8B 开头,可以以此来取出数据解压。

linux 系统

linux 系统也有对应的工具:ifconfig ping route traceroute arp tcpdump

在 linux 系统下,有一个防火墙 iptables 服务。其命令格式如下:

iptables -t 表 操作 链 规则描述

iptables 有四个表:

  • filters 默认过滤表,包含 INPUT, FORWARD, OUTPUT 三个链,分别过滤输入,处理,输出三个过程中的数据
  • nat
  • mangle
  • raw

有以下主要操作:

  • -A 添加
  • -D 删除
  • -R 替换
  • -I 插入
  • -L 列表

规则定义包括以下:

  • [!] -p 协议。包括 tcp, udp, icmp, all 等
  • [!] -s 源地址及掩码。如:192.168.1.0/24, 192.168.1.100
  • [!] -d 目标地址及掩码。
  • [!] -i 输入数据的网络接口卡
  • [!] -o 输出数据的网络接口卡
  • -j 满足规则后,执行的操作

举例如下:

# 禁止 192.168.1.0 子网的机器访问 TCP 22(SSH) 端口
iptables -I INPUT -s 192.168.1.0/24 -p tcp --dport 22 -j DROP
# 删除第1条规则
iptables -D INPUT 1
# 列表所有规则
iptables -L

与 iptables 相关的配置文件是 /etc/sysconfig/iptables,在 RH 下可以通过 service iptables save 来保存刚刚修改的规则。

常用网络工具 ipconfig arp traceroute的更多相关文章

  1. Linux常用网络工具:路由扫描之traceroute

    之前两篇<Linux常用网络工具:fping主机扫描>和<Linux常用网络工具:hping高级主机扫描>都是关于主机扫描的,本篇介绍Linux下常用的路由扫描工具tracer ...

  2. Linux常用网络工具:路由扫描之mtr

    除了上一篇<Linux常用网络工具:路由扫描之traceroute>介绍的traceroute之外,一般Linux还内置了另一个常用的路由扫描工具mtr. mtr在某些方面比tracero ...

  3. Linux常用网络工具:hping高级主机扫描

    之前介绍了主机扫描工具fping,可以参考我写的<Linux常用网络工具:fping主机扫描>. hping是一款更高级的主机扫描工具,它支持TCP/IP数据包构造.分析,在某些防火墙配置 ...

  4. Linux常用网络工具:批量主机服务扫描之netcat

    netcat又叫做瑞士军刀,是黑客和系统管理员常用的网络工具,最初开发的目的是文件传输,后来发展出很多强大的功能,比如也可以完成批量主机服务扫描. 之前介绍了另一个更常用的批量主机服务扫描工具:nma ...

  5. Linux常用网络工具:批量主机服务扫描之nmap

    Linux下有很多强大网络扫描工具,网络扫描工具可以分为:主机扫描.主机服务扫描.路由扫描等. 之前已经写过常用的主机扫描和路由扫描工具,nmap支持批量主机扫描和主机服务扫描. nmap的安装直接使 ...

  6. Linux常用网络工具:fping主机扫描

    Linux下有很多强大网络扫描工具,网络扫描工具可以分为:主机扫描.主机服务扫描.路由扫描等. fping是一个主机扫描工具,相比于ping工具可以批量扫描主机. fping官方网站:http://f ...

  7. Linux常用网络工具:Http压力测试之ab

    ab的全称是Apache Bench,是Apache自带的网络压力测试工具,相比于LR.JMeter,是我所知道的 Http 压力测试工具中最简单.最通用的. ab命令对发出负载的计算机要求很低,不会 ...

  8. DOS下常用网络命令技巧

    DOS,即使对于许多自称了解计算机的人而言,也是一个比较陌生的词汇.然而,在网络管理过程中,DOS命令却是一个不可逾越的障碍,几乎所有的网络命令都运行在DOS界面.对初级用户而言,掌握一些常用网络命令 ...

  9. linux配置网卡IP地址命令详细介绍及一些常用网络配置命令

    linux配置网卡IP地址命令详细介绍及一些常用网络配置命令2010-- 个评论 收藏 我要投稿 Linux命令行下配置IP地址不像图形界面下那么方 便,完全需要我们手动配置,下面就给大家介绍几种配置 ...

随机推荐

  1. JSON对象格式美化

    JSON.stringify(obh, null, "\t"); 这段代码就可以对某个js对象美化输出

  2. PyQt5+Python3.5.2-32bit开发环境搭建

      1.基本环境. Window 8.1 64bit Python3.5.2-32bit.exe PyQt5 2.安装python. 去官网下载32位版本的python3.5.2(就是x86那个) 备 ...

  3. WorkFlowHelper

    /* # Microshaoft /r:System.Xaml.dll /r:System.Activities.dll /r:System.Activities.DurableInstancing. ...

  4. 使用Redis的INCR、Hsetnx、Hincrby的命令生成序列号

    Redis INCR命令 用于由一个递增key的整数值.如果该key不存在,它被设置为0执行操作之前.如果key包含了错误类型的值或包含不能被表示为整数,字符串,则返回错误.该操作被限制为64位带符号 ...

  5. 1.Linux中安装LNMP过程

    第一步安装mysql过程 安装包mysql-5.0.22.tar.gz,解压tar -zxvf  mysql-5.0.22.tar.gz cd mysql-5.0.22 进行源码安装./configu ...

  6. 【统计学习】主成分分析PCA(Princple Component Analysis)从原理到实现

    [引言]--PCA降维的作用 面对海量的.多维(可能有成百上千维)的数据,我们应该如何高效去除某些维度间相关的信息,保留对我们"有用"的信息,这是个问题. PCA给出了我们一种解决 ...

  7. C++-Qt【5】-QT的QString,char*,QByteArray转化以及中文乱码的问题

    引用:http://blog.sina.com.cn/s/blog_a7e2c7490101oatt.html QTextCodec *codec = QTextCodec::codecForName ...

  8. [8.3] Magic Index

    A magic index in an array A[0...n-1] is defined to be an index such that A[i] = i. Given a sorted ar ...

  9. 弱省互测#0 t2

    题意 给定两个字符串 A 和 B,求下面四个问题的答案: 1.在 A 的子串中,不是 B 的子串的字符串的数量. 2.在 A 的子串中,不是 B 的子序列的字符串的数量. 3.在 A 的子序列中,不是 ...

  10. 斯考特·杨(Scott Young)快速学习方法

    上午在网上看到了斯考特·杨(Scott Young)的快速学习方法,感觉很受鼓舞. 现在已经读研究生了,可是发现自己自从上大学以来到现在,发现自己的学习方法有很大的问题. 我是个特别喜欢读书的人,在大 ...