在开发过程中,因为网络环境的原因,需要通过某一台服务器访问其他服务器的一些端口,这里就涉及到linux端口映射的问题。在linux服务器上,1024以下的linux端口映射是禁止非root用户使用的。所以如果想要使用80端口访问tomcat,则修改conf/server.xml的端口为80,那么只能使用root用户;但是linux端口映射为了安全起见,一般都是使用其他用户启动tomcat,可以采用端口映射的方式,比如映射80到8080端口。

什么是linux端口映射?

linux端口映射又称端口转发,是将外部主机的IP地址的端口映射到Intranet中的一台计算机,以提供相应的服务。

当用户访问外网IP的这个端口时,服务器自动将请求映射到对应局域网内部的机器上。

端口映射可以通过使用动态或固定的公共网络IP路由ADSL宽带路由器来实现。ADSL直接连接到集线器或交换机,以允许计算机共享互联网。

若用户访问提供映射端口的linux主机的端口时,服务器会向LAN中提供此特定服务的主机发送请求。外部IP地址机的多个端口也可以映射到内部网络中不同计算机上的不同端口。端口映射还可以执行一些特定的代理功能。

端口映射分为动态和静态。动态端口映射:内网中的一台电脑要访问网站,会向NAT网关发送数据包,包头中包括对方网站IP、端口和本机IP、端口,NAT网关会把本机IP、端口替换成自己的公网IP、一个未使用的端口,并且会记下这个映射关系,为以后转发数据包使用。

怎么进行端口映射

可任意使用iptables进行端口映射 :

第一步 : 打开端口映射功能 :

方法一 : (允许数据包转发)

1

 

sudo echo '1' > /proc/sys/net/ipv4/ip_forward

 

方法二 :

1

2

3

4

 

vim /etc/sysctl.conf

将 ;net.ipv4.ip_forward = 0 这一行的注视去掉 , 并将 0 改为 1

修改后的结果为 :

net.ipv4.ip_forward = 1

 

第二步 : 进行映射 :

DNAT

1

 

iptables -t nat -A PREROUTING -d 本机IP -p tcp --dport 本机端口 -j DNAT --to-destination 目标机IP:目标机端口

 

SNAT

1

 

iptables -t nat -A PREROUTING -d 本机IP -p tcp --dport 本机端口 -j SNAT --to-destination 目标机IP:目标机端口

 

 

它通过发送ICMP ECHO_REQUEST数据包到网络主机(send ICMP ECHO_REQUEST to network hosts),并显示响应情况,这样我们就可以根据它输出的信息来确定目标主机是否可访问(但这不是绝对的)。有些服务器为了防止通过ping探测到,通过防火墙设置了禁止ping或者在内核参数中禁止ping,这样就不能通过ping确定该主机是否还处于开启状态。

linux下的ping和windows下的ping稍有区别,linux下ping不会自动终止,需要按ctrl+c终止或者用参数-c指定要求完成的回应次数。

1.命令格式:

ping [参数] [主机名或IP地址]

2.命令功能:

ping命令用于:确定网络和各外部主机的状态;跟踪和隔离硬件和软件问题;测试、评估和管理网络。如果主机正在运行并连在网上,它就对回送信号进行响应。每个回送信号请求包含一个网际协议(IP)和 ICMP 头,后面紧跟一个 tim 结构,以及来填写这个信息包的足够的字节。缺省情况是连续发送回送信号请求直到接收到中断信号(Ctrl-C)。

ping 命令每秒发送一个数据报并且为每个接收到的响应打印一行输出。ping 命令计算信号往返时间和(信息)包丢失情况的统计信息,并且在完成之后显示一个简要总结。ping 命令在程序超时或当接收到 SIGINT 信号时结束。Host 参数或者是一个有效的主机名或者是因特网地址。

3.命令参数:

-d 使用Socket的SO_DEBUG功能。

-f 极限检测。大量且快速地送网络封包给一台机器,看它的回应。

-n 只输出数值。

-q 不显示任何传送封包的信息,只显示最后的结果。

-r 忽略普通的Routing Table,直接将数据包送到远端主机上。通常是查看本机的网络接口是否有问题。

-R 记录路由过程。

-v 详细显示指令的执行过程。

-c 数目:在发送指定数目的包后停止。

-i 秒数:设定间隔几秒送一个网络封包给一台机器,预设值是一秒送一次。

-I 网络界面:使用指定的网络界面送出数据包。

-l 前置载入:设置在送出要求信息之前,先行发出的数据包。

-p 范本样式:设置填满数据包的范本样式。

-s 字节数:指定发送的数据字节数,预设值是56,加上8字节的ICMP头,一共是64ICMP数据字节。

-t 存活数值:设置存活数值TTL的大小。

4.使用实例:

实例1:ping的通的情况

命令:ping 192.168.120.205

输出:

复制代码

代码如下:

[root@localhost ~]# ping 192.168.120.205 PING 192.168.120.205 (192.168.120.205) 56(84) bytes of data. 64 bytes from 192.168.120.205: icmp_seq=1 ttl=64 time=0.720 ms 64 bytes from 192.168.120.205: icmp_seq=2 ttl=64 time=0.181 ms 64 bytes from 192.168.120.205: icmp_seq=3 ttl=64 time=0.191 ms 64 bytes from 192.168.120.205: icmp_seq=4 ttl=64 time=0.188 ms 64 bytes from 192.168.120.205: icmp_seq=5 ttl=64 time=0.189 ms

--- 192.168.120.205 ping statistics --- 5 packets transmitted, 5 received, 0% packet loss, time 4000ms rtt min/avg/max/mdev = 0.181/0.293/0.720/0.214 ms [root@localhost ~]#

实例2:ping不通的情况

命令:ping 192.168.120.202

输出:

复制代码

代码如下:

[root@localhost ~]# ping 192.168.120.202 PING 192.168.120.202 (192.168.120.202) 56(84) bytes of data. From 192.168.120.204 icmp_seq=1 Destination Host Unreachable From 192.168.120.204 icmp_seq=2 Destination Host Unreachable From 192.168.120.204 icmp_seq=3 Destination Host Unreachable From 192.168.120.204 icmp_seq=4 Destination Host Unreachable From 192.168.120.204 icmp_seq=5 Destination Host Unreachable From 192.168.120.204 icmp_seq=6 Destination Host Unreachable

--- 192.168.120.202 ping statistics --- 8 packets transmitted, 0 received, +6 errors, 100% packet loss, time 7005ms , pipe 4 [root@localhost ~]#

实例3:ping网关

命令:ping -b 192.168.120.1

输出:

复制代码

代码如下:

[root@localhost ~]# route Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use Iface 192.168.120.0 * 255.255.255.0 U 0 0 0 eth0 192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0 default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0 [root@localhost ~]# ping -b 192.168.120.1 PING 192.168.120.1 (192.168.120.1) 56(84) bytes of data. 64 bytes from 192.168.120.1: icmp_seq=1 ttl=255 time=2.02 ms 64 bytes from 192.168.120.1: icmp_seq=2 ttl=255 time=1.83 ms 64 bytes from 192.168.120.1: icmp_seq=3 ttl=255 time=1.68 ms 64 bytes from 192.168.120.1: icmp_seq=4 ttl=255 time=1.98 ms 64 bytes from 192.168.120.1: icmp_seq=5 ttl=255 time=1.88 ms

--- 192.168.120.1 ping statistics --- 5 packets transmitted, 5 received, 0% packet loss, time 4000ms rtt min/avg/max/mdev = 1.682/1.880/2.020/0.129 ms

实例4:ping指定次数

命令:ping -c 10 192.168.120.206

输出:

复制代码

代码如下:

[root@localhost ~]# ping -c 10 192.168.120.206 PING 192.168.120.206 (192.168.120.206) 56(84) bytes of data. 64 bytes from 192.168.120.206: icmp_seq=1 ttl=64 time=1.25 ms 64 bytes from 192.168.120.206: icmp_seq=2 ttl=64 time=0.260 ms 64 bytes from 192.168.120.206: icmp_seq=3 ttl=64 time=0.242 ms 64 bytes from 192.168.120.206: icmp_seq=4 ttl=64 time=0.271 ms 64 bytes from 192.168.120.206: icmp_seq=5 ttl=64 time=0.274 ms 64 bytes from 192.168.120.206: icmp_seq=6 ttl=64 time=0.295 ms 64 bytes from 192.168.120.206: icmp_seq=7 ttl=64 time=0.269 ms 64 bytes from 192.168.120.206: icmp_seq=8 ttl=64 time=0.270 ms 64 bytes from 192.168.120.206: icmp_seq=9 ttl=64 time=0.253 ms 64 bytes from 192.168.120.206: icmp_seq=10 ttl=64 time=0.289 ms

--- 192.168.120.206 ping statistics --- 10 packets transmitted, 10 received, 0% packet loss, time 9000ms rtt min/avg/max/mdev = 0.242/0.367/1.251/0.295 ms [root@localhost ~]#

实例5:时间间隔和次数限制的ping

命令:ping -c 10 -i 0.5 192.168.120.206

输出:

复制代码

代码如下:

[root@localhost ~]# ping -c 10 -i 0.5 192.168.120.206 PING 192.168.120.206 (192.168.120.206) 56(84) bytes of data. 64 bytes from 192.168.120.206: icmp_seq=1 ttl=64 time=1.24 ms 64 bytes from 192.168.120.206: icmp_seq=2 ttl=64 time=0.235 ms 64 bytes from 192.168.120.206: icmp_seq=3 ttl=64 time=0.244 ms 64 bytes from 192.168.120.206: icmp_seq=4 ttl=64 time=0.300 ms 64 bytes from 192.168.120.206: icmp_seq=5 ttl=64 time=0.255 ms 64 bytes from 192.168.120.206: icmp_seq=6 ttl=64 time=0.264 ms 64 bytes from 192.168.120.206: icmp_seq=7 ttl=64 time=0.263 ms 64 bytes from 192.168.120.206: icmp_seq=8 ttl=64 time=0.331 ms 64 bytes from 192.168.120.206: icmp_seq=9 ttl=64 time=0.247 ms 64 bytes from 192.168.120.206: icmp_seq=10 ttl=64 time=0.244 ms

--- 192.168.120.206 ping statistics --- 10 packets transmitted, 10 received, 0% packet loss, time 4499ms rtt min/avg/max/mdev = 0.235/0.362/1.241/0.294 ms [root@localhost ~]# ping -c 10 -i 0.01 192.168.120.206 PING 192.168.120.206 (192.168.120.206) 56(84) bytes of data. 64 bytes from 192.168.120.206: icmp_seq=1 ttl=64 time=0.244 ms 64 bytes from 192.168.120.206: icmp_seq=2 ttl=64 time=0.195 ms 64 bytes from 192.168.120.206: icmp_seq=3 ttl=64 time=0.219 ms 64 bytes from 192.168.120.206: icmp_seq=4 ttl=64 time=0.204 ms 64 bytes from 192.168.120.206: icmp_seq=5 ttl=64 time=3.56 ms 64 bytes from 192.168.120.206: icmp_seq=6 ttl=64 time=1.93 ms 64 bytes from 192.168.120.206: icmp_seq=7 ttl=64 time=0.193 ms 64 bytes from 192.168.120.206: icmp_seq=8 ttl=64 time=0.193 ms 64 bytes from 192.168.120.206: icmp_seq=9 ttl=64 time=0.202 ms 64 bytes from 192.168.120.206: icmp_seq=10 ttl=64 time=0.211 ms

--- 192.168.120.206 ping statistics --- 10 packets transmitted, 10 received, 0% packet loss, time 90ms rtt min/avg/max/mdev = 0.193/0.716/3.564/1.080 ms [root@localhost ~]#

实例6:通过域名ping公网上的站点

命令:ping -c 5 www.58.com

输出:

复制代码

代码如下:

peida-VirtualBox ~ # ping -c 5 www.58.com PING www.58.com (211.151.111.30) 56(84) bytes of data. 64 bytes from 211.151.111.30: icmp_req=1 ttl=49 time=14.7 ms 64 bytes from 211.151.111.30: icmp_req=2 ttl=49 time=16.4 ms 64 bytes from 211.151.111.30: icmp_req=3 ttl=49 time=15.2 ms 64 bytes from 211.151.111.30: icmp_req=4 ttl=49 time=14.6 ms 64 bytes from 211.151.111.30: icmp_req=5 ttl=49 time=19.9 ms

--- www.58.com ping statistics --- 5 packets transmitted, 5 received, 0% packet loss, time 20101ms rtt min/avg/max/mdev = 14.618/16.192/19.917/1.965 ms peida-VirtualBox ~ #

实例7:多参数使用

命令:ping -i 3 -s 1024 -t 255 192.168.120.206

输出:

复制代码

代码如下:

[root@localhost ~]# ping -i 3 -s 1024 -t 255 192.168.120.206 PING 192.168.120.206 (192.168.120.206) 1024(1052) bytes of data. 1032 bytes from 192.168.120.206: icmp_seq=1 ttl=64 time=1.99 ms 1032 bytes from 192.168.120.206: icmp_seq=2 ttl=64 time=0.694 ms 1032 bytes from 192.168.120.206: icmp_seq=3 ttl=64 time=0.300 ms 1032 bytes from 192.168.120.206: icmp_seq=4 ttl=64 time=0.481 ms 1032 bytes from 192.168.120.206: icmp_seq=5 ttl=64 time=0.415 ms 1032 bytes from 192.168.120.206: icmp_seq=6 ttl=64 time=0.600 ms 1032 bytes from 192.168.120.206: icmp_seq=7 ttl=64 time=0.411 ms 1032 bytes from 192.168.120.206: icmp_seq=8 ttl=64 time=0.281 ms 1032 bytes from 192.168.120.206: icmp_seq=9 ttl=64 time=0.318 ms 1032 bytes from 192.168.120.206: icmp_seq=10 ttl=64 time=0.362 ms 1032 bytes from 192.168.120.206: icmp_seq=11 ttl=64 time=0.408 ms 1032 bytes from 192.168.120.206: icmp_seq=12 ttl=64 time=0.445 ms 1032 bytes from 192.168.120.206: icmp_seq=13 ttl=64 time=0.397 ms 1032 bytes from 192.168.120.206: icmp_seq=14 ttl=64 time=0.406 ms 1032 bytes from 192.168.120.206: icmp_seq=15 ttl=64 time=0.458 ms

--- 192.168.120.206 ping statistics --- 15 packets transmitted, 15 received, 0% packet loss, time 41999ms rtt min/avg/max/mdev = 0.281/0.531/1.993/0.404 ms [root@localhost ~]#

说明:-i 3 发送周期为 3秒 -s 设置发送包的大小为1024 -t 设置TTL值为 255

关键词: linux中什么叫端口映射 linux如何ping地址通不通 ping命令详解和使用例子 linux端口映射