Mac OSX常用网络命令(未完)

ARP

ARP协议用在局域网(LAN)内部。借用ARP协议,设备可以知道同一局域网内的IP-MAC对应关系。当我们访问一个本地IP地址时,设备根据该对应关系,与对应的MAC地址通信。通过ARP工具,我们可以知道局域网内的通信是否正常。

arp -a

显示本地存储的IP-MAC对应关系

sudo arping -I eth0 192.168.1.1

经eth0接口,发送ARP请求,查询IP为192.168.1.1设备的MAC地址

 

sudo arp-scan -l

查询整个局域网内的所有IP地址的对应MAC地址

sudo tcpdump -i en0 arp

网络层

网络层是一个广域的互联网,互联网上的设备用IP地址识别。ping是向某个IP地址发送ICMP协议的ECHO_REQUEST请求。收到该请求的设备,将返回ICMP回复。如果ping到某个IP地址,那么说明该IP地址的设备可以经网络层顺利到达。

ping 192.168.1.1

向IP地址192.168.1.255发送ICMP请求。如果该地址的ICMP没有被禁用,那么在该网上的设备将回复。

  ping 192.168.1.255

  向广播(broadcast)地址192.168.1.255发送ICMP请求。如果ICMP没有被禁用,那么在该网上的设备将回复。

需要注意的是,许多设备会禁用ICMP。如果ping不到一个设备,并不一定是网络层故障。

如果两个设备有相同的IP地址,将导致IP冲突。许多网络中是由DHCP协议自动分配IP地址的,这样可以极大的减少IP冲突的可能性。DHCP服务器与设备达成协议,设备将在一定时间内占据某个IP地址,而DHCP服务器不再把该IP地址分配给别人。

sudo ipconfig set en0 DHCP

更新DHCP租约。设备将释放IP地址,再从DHCP服务器重新获得IP地址。

sudo ipconfig set en0 INFORM 192.168.0.120

将接口en0设定为静态IP地址。

路由

局域网通过路由器,接入广域的互联网。互联网上的通信往往要经过多个路由器接力。途中路由器的故障,可能导致互联网访问异常。

netstat -nr

显示路由表。从路由表中,可以找到网关(Gateway)。网关是通向更加广域网络的出口。

traceroute 74.125.128.99

追踪到达IP目的地的全程路由。

  traceroute -I 74.125.128.99

  通过ICMP协议,追踪路由。ICMP协议经常会被禁用,所以会返回”*”的字符串。

  sudo traceroute -T -p 80 74.125.128.99

  通过TCP协议,经80端口,追踪路由。TCP协议的默认端口80很少会被禁用。

网络监听

tcpdump是一款网络抓包工具。它可以监听网络接口不同层的通信,并过滤出特定的内容,比如特定协议、特定端口等等。我们上面已经使用tcpdump监听了ARP协议通信。这里我们来看更多的监听方式。

sudo tcpdump -i en0

监听en0接口的所有通信

  sudo tcpdump -A -i en0 

  用ASCII显示en0接口的通信内容

  sudo tcpdump -i en0 ‘port 8080’

  显示en0接口的8080端口的通信

  sudo tcpdump -i eth1 src 192.168.1.200

  显示eth1接口,来自192.168.1.200的通信

  sudo tcpdump -i eth1 dst 192.168.1.101 and port 80

  显示eth1接口80端口,目的地为192.168.1.101的通信

  sudo tcpdump -w record.pcap -i lo0

  将lo0接口的通信存入文件record.pcap

域名解析

DNS是在域名和IP之间进行翻译。DNS故障会导致我们无法通过域名访问某个网址。 

host www.sina.com.cn

DNS域名解析。返回域名对应的IP地址

修改mac地址,重启后失效
sudo ifconfig en0 lladdr d0:67:e5:2e:07:f1
修改路由表,同时使用有线网卡和无线网卡
netstat -nr 查看路由表  www.2cto.com  
sudo route delete 0.0.0.0  删除默认路由
sudo route add -net 0.0.0.0 192.168.1.1 默认使用192.168.1.1网关
sudo route add 10.200.0.0 10.200.22.254 有线网卡使用该网关
sudo route add 10.0.1.0/24 10.200.22.254 其它网段指定网关

 列出所有的网络连接方式
networksetup -listallnetworkservices

给指定的网络连接方式设定DNS服务器
sudo networksetup-setdnsservers AirPort 192.168.10.200

清空DNS缓存
dscacheutil -flushcache

网卡的启动与关闭:ifconfig en0 up/down

1、配置IP地址
sudo ifconfig en0 192.168.1.33 
2、配置默认网关
sudo route add -net 0.0.0.0 192.168.1.1 配置默认网关为192.168.1.1
3、配置DNS域名:
sudo networksetup -setdnsservers networkservice DNS1 DNS2
networkservice可通过“networksetup -listallnetworkservices”命令查询,每个PC很可以不一样
如:
sudo networksetup -setdnsservers AirPort 192.168.10.200 8.8.8.8

sudo networksetup -setdnsservers Eternet 192.168.10.200 8.8.8.8

#设置Wi-Fi自动获取ip  
sudo networksetup -setdhcp “Wi-Fi”  
  
#设置Wi-Fi静态ip  
sudo networksetup -setmanual “Wi-Fi” 192.168.9.14 255.255.252.0 192.168.8.1  

可能不同的机器的网络服务名不同,可以通过下面命令查看:
#列出本机所有网络服务  
networksetup -listallnetworkservices 

参考文章:

Mac OSX网络诊断命令

 mac命令行配置网络

Published by

风君子

独自遨游何稽首 揭天掀地慰生平

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注