C 插座未接收传入的数据包,在Python中工作
C++ socket not receiving incoming packets, works in Python
我找不到类似的问题,所以它去了。
我有一个通过10GBE电缆直接连接到另一台机器的Linux盒。另一端的机器将8KB UDP帧推到我的Linux盒子上的NIC。我可以使用IPTRAF查看传入的UDP数据包,并确认它们正在到达预期的NIC,IP地址和端口号。
我能够打开一个插座,并使用以下片段使用Python读取此数据:
import socket
ip = '192.168.4.5'
port = 60001
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
sock.bind((ip, port))
data = sock.recv(8192)
这没有其他问题,除了Python太慢,无论我多么紧张,我最终都会失去网络包。数据正在通过10GBE链接进行,并以全油门运行。
所以解决这个延迟问题,我决定转向C /C。
编写数据录像机#include <sys/types.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <string.h>
#include <netdb.h>
#include <stdio.h>
#include <arpa/inet.h>
#include <iostream>
void error(const char *msg)
{
perror(msg);
exit(0);
}
int main(int argc, char *argv[])
{
int sock;
ssize_t n;
socklen_t length;
in_port_t port;
const char *ip_addr;
socklen_t fromlen;
struct sockaddr_in server;
struct sockaddr_in from;
char buf[8192];
ip_addr = "192.168.4.5"; // host to listen on
port = 60001; // port to listen on
std::cout << "ip address: " << ip_addr << std::endl;
std::cout << "port: " << port << std::endl;
// create inet socket
sock = socket(AF_INET, SOCK_DGRAM, 0);
if (sock < 0) error("Opening socket");
else std::cout << "socket opened.n";
length = sizeof(server);
memset(&server, 0, length); // initialize with zeros
server.sin_family = AF_INET;
server.sin_addr.s_addr = inet_addr(ip_addr);
server.sin_port = port;
// bind to socket address and port
if (bind(sock,(struct sockaddr *)&server, length)<0)
error("binding");
else std::cout << "binding successfuln";
// check binding status
struct sockaddr_in socket_address;
socklen_t socket_addr_len;
for (int i=0; i<10; i++) {
std::cout << "iter: " << i << std::endl;
n = recv(sock, buf, 9000, 0);
if (n<0) error("recv");
std::cout << "received a datagram: ";
for (int k=0; k<10; k++){
std::cout << buf[k];
}
std::cout << std::endl;
}
return 0;
}
上面的C程序将永远悬挂在recv()
上。如果我将其进行非阻滞,那么它将返回EAGAIN
,表明没有什么可阅读的。我尝试使用getsockname
来确定插座是否实际绑定到正确的地址。是。
在我看来,当Python版本从插座上阅读没有问题时,我会对此有一个问题,我可以在视觉上确认有数据传入。我的猜测是,我的插座设置在c。
中存在问题可能相关的另一个信息是我的Linux框在同一子网上具有1个其他接口。
Linux盒上的接口
- eth1:192.168.4.1
- eth2:192.168.4.5
远程计算机上的接口
- eth0:192.168.4.10
iptraf的样本输出
UDP (8220 bytes) from 192.168.4.10:10000 to 192.168.4.5:60001 on eth2
任何指导都将不胜感激。
server.sin_port = htons (port);
相关文章:
- boost::asio UDP 广播客户端仅接收"fast"数据包
- 如何使用发送数据包所花费的时间计算两个节点之间的距离?
- 发送固定大小的 UDP 数据包
- pcap_handler回调仅在使用 NPCAP v0.9991 时包含空数据包
- 在 c++ 中解析数据包数据的最佳方法是什么?
- 接受函数在发送数据包时等待
- 如何在 omnet++ 中发送自定义数据包?
- 数据包访问实践
- 在C++中创建一个简单的数据包路由器,如何跟踪"客户端"?
- 德拉吉诺 LG01-S 收到异常数据包并停止工作
- 将数据包从C++服务器发送到NodeJs服务器时出现MessagePack解码错误
- 使用C++将UDP数据包存储在Structure中
- FFmpeg av_read_frame从音频流返回数据包
- 使用 pipe() 和 fdopen() 将数据从 Python 脚本传递到 Windows 中的C++应用程序
- 为什么操作系统正在更改我的数据包的指定传出端口
- 是否可以将多个结构作为一个数据包存储在一个函数中,然后传递给其他函数并在那里提取?
- 如何将OpenCV图像数据从Python转换为C++?
- recvfrom 只收到几个数据包,之后它进入等待状态
- 如何调试由 C++ 编写的 npm 数据包
- C 插座未接收传入的数据包,在Python中工作