我正在开发一个由两部分组成的应用程序,其中一侧发送 ICMP 数据包,另一侧侦听 ICMP 数据包并在收到它们时采取操作。问题是,我不确定如何让侦听器无限期地保持活动状态(只是希望它处于循环中,仅在收到数据包时才采取行动)。
目前,我可以使用 go-fastping 库,并且如果是双向通信,则可以发送和接收数据包(我发送,他们响应,我处理远程响应)。问题是如何使其不对称?
我对听众的尝试是:
for {
conn, err := icmp.ListenPacket("ip4:icmp", "192.168.1.8")
if err != nil {
fmt.Println(err)
}
}
但这不起作用。我的逻辑是,我想要一个
while true
循环来保持侦听器处于活动状态(在本例中是 for {
),然后我使用 ICMP 的 ListenPacket
监听新数据包,但我似乎没有使用任何东西这种方法。
任何想法或帮助将不胜感激。预先感谢您的时间和帮助。
icmp.ListenPacket()
创建一个 *icmp.PacketConn
- 换句话说,一个监听器。您正在无限循环中创建侦听器!由于您甚至没有关闭它们,您的程序将开始抱怨 too many open files
的速度比您说“ping”的速度还要快。
这是一个工作监听器的示例
package main
import (
"golang.org/x/net/icmp"
"log"
)
func main() {
conn, err := icmp.ListenPacket("ip4:icmp", "192.168.0.12")
if err != nil {
log.Fatal(err)
}
for {
var msg []byte
length, sourceIP, err := conn.ReadFrom(msg)
if err != nil {
log.Println(err)
continue
}
log.Printf("message = '%s', length = %d, source-ip = %s", string(msg), length, sourceIP)
}
_ = conn.Close()
}
这会产生:
2015/10/26 10:35:00 message = '', length = 0, source-ip = 192.168.0.7
2015/10/26 10:35:00 message = '', length = 0, source-ip = 192.168.0.25
2015/10/26 10:35:01 message = '', length = 0, source-ip = 192.168.0.7
2015/10/26 10:35:01 message = '', length = 0, source-ip = 192.168.0.25
2015/10/26 10:35:02 message = '', length = 0, source-ip = 192.168.0.7
2015/10/26 10:35:02 message = '', length = 0, source-ip = 192.168.0.25
我同时从 2 台主机 ping 主机。
如果需要,您可以选择丢弃传入消息和其他返回值。