我正在努力使用UDP套接字。我想基准时间在两台机器之间交换某种类型的数据。
我很快在C中编写了这个项目https://github.com/nowox/udp-test,我有一个简单的客户端:
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <fcntl.h>
#include <netdb.h>
#include <sys/time.h>
#include <arpa/inet.h>
#include <time.h>
#include <errno.h>
#define PORT (3000)
#define SUBIMAGES (1000)
#define FRAMES_PER_SUBIMAGES (23)
#define UDP_FRAME (1442)
#define SERVERADDRESS "127.0.0.1" // 138.131.156.36"
#define BUFFER_SIZE (SUBIMAGES * FRAMES_PER_SUBIMAGES * UDP_FRAME)
char buffer[BUFFER_SIZE];
/**
* Populate the buffer with random data.
*/
void build(uint8_t* buffer, size_t length)
{
for (size_t i = 0; i < length; i++)
{
buffer[i] = (rand() % 255) + 1;
}
}
int main(int argc, char **argv)
{
struct timespec start, end;
int sockfd;
struct sockaddr_in server;
printf("Build Data...\n");
build(buffer, sizeof(buffer));
printf("Configure socket...\n");
sockfd = socket(AF_INET, SOCK_DGRAM, 0);
if (sockfd < 0)
{
fprintf(stderr, "Error opening socket");
return EXIT_FAILURE;
}
bzero((char*)&server, sizeof(server));
server.sin_family = AF_INET;
server.sin_addr.s_addr = inet_addr(SERVERADDRESS);
server.sin_port = htons(PORT);
printf("Send UDP data...\n");
clock_gettime(CLOCK_MONOTONIC_RAW, &start);
for (size_t i = 0; i < BUFFER_SIZE; i += UDP_FRAME)
{
if (sendto(sockfd, &buffer[i], UDP_FRAME, 0,
(const struct sockaddr*)&server, sizeof(server)) < 0)
{
fprintf(stderr, "Error in sendto()\n");
return EXIT_FAILURE;
}
}
clock_gettime(CLOCK_MONOTONIC_RAW, &end);
uint64_t delta_us = (end.tv_sec - start.tv_sec) * 1000000 +
(end.tv_nsec - start.tv_nsec) / 1000;
printf("Time to send %d subimages: %f[s]\n", SUBIMAGES, delta_us / 1e6f);
printf("Finished...\n");
return EXIT_SUCCESS;
}
我期待将UDP数据帧看到Wireshark,但似乎我什么也看不见。
初步问题:为什么我的套接字没有发送任何内容?
我发现这是因为WSL(适用于Linux的Windows子系统)。所以我搬到了Ubuntu
第二个问题:为什么我的服务器没有收到任何东西?
答案 0 :(得分:1)
您将客户端绑定到与服务器相同的端口。这是无效的。你不需要绑定你的客户端。
在客户端注释掉你的绑定调用,数据包将从随机选择的端口发送到服务器。您的服务器将收到它们,但您的服务器中的退出条件还有另一个错误,因此在收到框架时添加一些打印输出以查看它实际上正在发生。