1

我正在尝试编写代理服务器,现在我想实现流水线。我遇到了一个问题,需要帮助。我检查了这个问题,但我认为它不适用,因为我确实有要从套接字读取的数据。

主要思想如下。对于每个连接,我创建一个处理它的线程,对于这个连接中的每个请求,我想创建一个处理该请求的线程。到目前为止,我已经设法编写了第一部分的代码并且它工作正常(线程还处理连接的所有请求)。

现在,当我尝试从请求处理线程中读取套接字时,它会挂起。我用来读取数据的功能和以前一样(在工作版本中)。

void copydata(int from, int to, int len)
{
    char tbuff[BSIZ];
    int n;
    while (len > 0)
    {
        if ((n = read(from, tbuff, BSIZ)) <= 0) break;
        if (write(to, tbuff, n) < n) break;
        len -= n;
    }
}

from、to 和 len 变量具有适当的值(我检查了它们)。有什么可以导致这种行为的吗?

PS:如果需要更多代码,请告诉我。

编辑

以下是获取 len 的方法:

int contentlength(char *header)
{
    int len = INT_MAX;
    char line[MAX_LINE];

    if (HTTPheadervalue_case(header, "Content-Length", line)) sscanf(line, "%d", &len);
    return len;
}

调用 copydata(其中 activesocket 是打开套接字的函数):

if ((srv = activesocket(host, portno)) < 0)
    {
        sprintf(reshead, "HTTP/1.1 503\r\nContent-Length: 12\r\nConnection: close\r\n\r\nNon-existent");
        write(cli, reshead, strlen(reshead));
    } else
    {
        sprintf(reqhead1, "%s %s HTTP/1.1\r\n", "GET", path);
        if (HTTPheadervalue_case(reqhead1, "Connection", result)) if (strcasecmp(result, "close") == 0) cli_terminate[cli] = TRUE;
        strcat(reqhead1, reqhead);
        write(srv, reqhead1, strlen(reqhead1));
        while (completed[cli] != id)
            ;
        copydata(cli, srv, contentlength(reqhead));
        parseResponse(&srv, cli);
        completed[cli] = (completed[cli] + 1) % ULONG_MAX;
    }

编辑

一个示例请求标头如下:

Host: www.google.com
User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-GB; rv:1.9.1.16) Gecko/20120421 Iceweasel/3.5.16 (like Firefox/3.5.16)
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-gb,en;q=0.5
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive: 300
Proxy-Connection: keep-alive
Cookie: cookie content

我也试图去掉 keep-alive 标志,但仍然发生同样的情况。

4

1 回答 1

2

我猜这是你的问题(来自accept(2)):

在 Linux 上,返回的新套接字不会accept()侦听套接字继承文件状态标志。O_NONBLOCKO_ASYNC

即,您需要明确地使每个新接受的套接字都成为非阻塞的。

于 2012-05-08T14:37:59.667 回答