我有我希望的一个问题是一个错误,因为我有点新来的Linux C.ç3G文件传输客户端/服务器的Linux
我有一个服务器,发送文件到客户端。该代码完全适用于有线连接,每次都能100%成功。但是,当我尝试通过-65dB(强)的3G USB连接运行相同的代码时,客户端通常只会接收文件的前1或2千字节。 (请原谅的语法错误,不会让我的空间正常)
// CLIENT CODE
char* fs_name = "/target/to/send";
char sdbuf[LENGTH]; // Send buffer, LENGTH == 512
printf("Sending %s to the Client... \n", fs_name);
FILE *fs = fopen(fs_name, "r");
if(fs == NULL)
{
fprintf(stderr, "ERROR: File %s not found on server. (errno = %d)\n", fs_name, errno);
exit(1);
}
bzero(sdbuf, LENGTH);
int fs_block_sz;
while((fs_block_sz = fread(sdbuf, sizeof(char), LENGTH, fs))>0)
{
if(send(client, sdbuf, fs_block_sz, 0) < 0)
{
fprintf(stderr, "ERROR: Failed to send file %s. (errno = %d)\n", fs_name, errno);
exit(1);
}
bzero(sdbuf, LENGTH);
}
printf("File send Success\n");
// SERVER CODE
char* fr_name = "/home/file/to/save";
FILE *fr = fopen(fr_name, "a");
if(fr == NULL)
printf("File %s Cannot be opened.\n", fr_name);
else
{
// zero out bytes
bzero(revbuf, LENGTH);
int fr_block_sz = 0;
while((fr_block_sz = recv(sd, revbuf, LENGTH, 0)) > 0) //LENGTH == 512
{
int write_sz = fwrite(revbuf, sizeof(char), fr_block_sz, fr);
if(write_sz < fr_block_sz)
{
error("File write failed.\n");
}
bzero(revbuf, LENGTH);
if (fr_block_sz == 0 || fr_block_sz != 512)
{
break;
}
}
// error checking
if(fr_block_sz < 0)
{
if (errno == EAGAIN)
{
printf("recv() timed out.\n");
}
else
{
fprintf(stderr, "recv() failed due to errno = %d\n", errno);
}
fclose(fr);
如果有任何人可以对我在做什么错了,我会最欣赏一些启发。谢谢阅读。
编辑:服务器是Ubuntu 10.04,客户端是Arch Linux ARM,发送的文件类型是ARM二进制文件。
为什么客户端,有什么回报RECV在周期的退出?如果rect返回<0打印fprintf(stderr,“recv返回错误:%s \ n”,sterror(errno))? – fghj
如果我正确理解你的意思,客户端不会收到错误。客户端简单地保存文件,就好像它是完整的东西,并没有提供错误信息,服务器也没有。然后我必须手动调整该文件的大小以查找xfer失败。它有时可以工作,但可能有15%的时间。也许我需要以1000字节块发送文件,然后在客户端重新组装它或其他东西?不幸的是,我注意到3G与电线有点不同。 – 4r4r4r
你谈论某种魔术。如果您有TCP连接,并且从一边发送100MB文件块在另一边您收到或100MB或连接断开。可能你使用UDP? – fghj