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