sendfile system call in FreeBSD

From
Alex Semenyaka (2:461/640.640)
To
Andrey Ushakov
Date
2006-11-20T18:47:56Z
Area
RU.UNIX.BSD
Hello Andrey!

20 Nov 06 16:44, you wrote to Valentin Davydov:

 VD>> Дык, заверни на сервере read(2) в цикл и читай до тех пор, пока не
 VD>> вернёт 0  либо ошибку.
 AU> Не получается так сделать. Дело в том что на этом диалог не завершается
 AU> У меня дальше ещё вот:
 AU> if((rc = recv(s, buf, sizeof(buf), MSG_WAITALL)) < 0)
 AU> {
 AU> printf("stcpcl: delivererd failed");
 AU> exit(1);
 AU> }
 AU> Я жду уведомления о доставке.
 AU> Я пробовал после того как отправлю файл послать ещё маленькое сообщение
 AU> серверу типа:
 AU> if((rc = send(s, "endf", 4, 0)) < 0)
 AU> Почему-то воспринимает и данные передаваемого файла и последующего
 AU> маленького сообщения как один и тот же поток. По моему это непрвильно.

Да, не выиграть тебе конкурс. Ты явно не представляешь себе, как происходит
передача данных по TCP. Крайне рекомендую срочно почитать чего-нибудь по TCP.

 AU> Либо это sendfile такой странный, либо я чё-то не понимаю =\

Это ты довольно многого не понимаешь. Если коротко, то:

Поток TCP представляет собой неструктурированный поток байтов. В нём нет
отметок о границах записей, файлов или ещё каких-то единиц, существующих на
уровне твоей ОС. Ты можешь делать эти отметки, но их надо ставить тебе самому,
стандартный API такой возможности не предоставляет, ибо нефиг.

Другими словами, три записи в поток могут породить 1, 2 или 3 пакета, и на
другой стороне могут быть прочитаны как одним, двумя, тремя или восмьюста
операциями чтения. У пользователя нет способа в стандартном API понять, сколько
операций записи проводилось.

Аналогично, sendfile(2) не формирует никаких отметок о том, что он посылает
файл как объект. Он тупо берёт и шлёт байты из указанного файла потоком. Всё,
что ты пошлёшь вслед, ляжет в тот же поток. Способа у получателя отличить
посланное с помощью sendfile(2) от дописанного любым способом позже нет. Если
он тебе нужен - ты должен реализовывать свой собственный механизм для этого.

Alex

--- IMHO в последней инстанции
 * Origin: ...можжевеловых... (2:461/640.640)
SEEN-BY: 50/12 400/814 450/159 1024 452/35 461/43 132 640 1024 469/999 4616/3
SEEN-BY: 4625/8 4641/444 5000/76 5000 5006/1 5007/1 5010/70 5011/13 5012/46
SEEN-BY: 5015/28 5019/31 5020/18 175 194 400 545 982 1057 1909 1922 2238 2395
SEEN-BY: 5020/2871 4441 5021/29 5025/3 5026/14 45 5027/12 5030/1080 1957
SEEN-BY: 5034/10 13 5035/3 38 5036/1 5045/7 5049/1 5051/12 15 5054/1 4 8 9 11
SEEN-BY: 5054/28 35 36 37 45 63 66 67 70 75 84 85 5059/9 5060/88 5061/15
SEEN-BY: 5062/10 5063/3 5064/7 5066/18 5075/5 5076/1 5077/70 5080/1003 5084/9
SEEN-BY: 5085/13 5095/20 5096/18 6001/10
PATH: 461/640 5020/400 545 5054/1 37