* [Comm] Как работает fork()?
@ 2004-08-25 9:11 AD
2004-08-25 10:20 ` Макс
` (2 more replies)
0 siblings, 3 replies; 5+ messages in thread
From: AD @ 2004-08-25 9:11 UTC (permalink / raw)
To: Community
Привет!
Поясните как работает fork().
Если не ошибаюсь, в результате вызова, дублируются, в частности, файловые
дескрипторы.
Что будет если:
1. Файл открыт для эксклюзивного доступа. Вторая копия сможет работать с
файлом?
2. Где-то в расшареной памяти есть мьютекс - используется несколькими
процессами. Процесс захватил мьютекс и вызвал fork. Каково будет состояние
мьютекса во второй копии.
3. В процессе 2 потока. Один поток ожидает получения данных: int
result=read(h, .. , .. ); Данные не готовы и драйвер устройства усыпляет
поток:
static DECLARE_WAIT_QUEUE_HEAD(wq);
...
interruptible_sleep_on(&wq);
В это время второй поток делает вызов fork. Что будет содержать result во
второй копии?
--
AD
^ permalink raw reply [flat|nested] 5+ messages in thread
* RE: [Comm] Как работает fork()?
2004-08-25 9:11 [Comm] Как работает fork()? AD
@ 2004-08-25 10:20 ` Макс
2004-08-26 8:17 ` php-coder
2004-08-27 7:57 ` Anton V. Boyarshinov
2 siblings, 0 replies; 5+ messages in thread
From: Макс @ 2004-08-25 10:20 UTC (permalink / raw)
To: community
>> Привет!
>> Поясните как работает fork().
>> Если не ошибаюсь, в результате вызова, дублируются, в частности, файловые
>> дескрипторы.
>> Что будет если:
>> 1. Файл открыт для эксклюзивного доступа. Вторая копия сможет работать с
>> файлом?
>> 2. Где-то в расшареной памяти есть мьютекс - используется несколькими
>> процессами. Процесс захватил мьютекс и вызвал fork. Каково будет
>>состояние мьютекса во второй копии.
>> 3. В процессе 2 потока. Один поток ожидает получения данных: int
>> result=read(h, .. , .. ); Данные не готовы и драйвер устройства усыпляет
>> поток:
>> static DECLARE_WAIT_QUEUE_HEAD(wq);
>>...
>> interruptible_sleep_on(&wq);
>> В это время второй поток делает вызов fork. Что будет содержать result во
>> второй копии?
Мне кажется, что:
1. да
2. Идентичное
3. Ничего, т.к. вторая копия будет тоже ждать данных из read();
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [Comm] Как работает fork()?
2004-08-25 9:11 [Comm] Как работает fork()? AD
2004-08-25 10:20 ` Макс
@ 2004-08-26 8:17 ` php-coder
2004-08-26 9:48 ` Re[2]: " AD
2004-08-27 7:57 ` Anton V. Boyarshinov
2 siblings, 1 reply; 5+ messages in thread
From: php-coder @ 2004-08-26 8:17 UTC (permalink / raw)
To: AD
0000100101011110100100101::25.08.2004::0110001001001000100111100100010
Здравствуйте, AD!
Отвечаю на Ваше письмо:
A> Поясните как работает fork().
Надеюсь, что следующая статья поможет вам разобраться как работает
fork(): http://www.linuxfocus.org/Russian/November2002/article272.shtml
--
С уважением, php-coder (mailto:php-coder[at]ngs[dot]ru)
Registered Linux User #327594
ALT Linux Master 2.2 (kernel 2.4.27)
010010010010010001010101100::Linux RuleZz!::100010010001000100010001110
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re[2]: [Comm] Как работает fork()?
2004-08-26 8:17 ` php-coder
@ 2004-08-26 9:48 ` AD
0 siblings, 0 replies; 5+ messages in thread
From: AD @ 2004-08-26 9:48 UTC (permalink / raw)
To: community
Здравствуйте!
> A> Поясните как работает fork().
>
> Надеюсь, что следующая статья поможет вам разобраться как работает
> fork(): http://www.linuxfocus.org/Russian/November2002/article272.shtml
>
Спасибо за ссылку, но меня интересуют нюансы связанные с разделением ресурсов.
Есть какой-то ресурс (захваченный мьютекс, файл открытый для эксклюзивного использования и т.п.) который может принадлежать одному и только одному процессу или, в отдельных случаях, потоку. Что происходит с этим ресурсом при клонировании (в общем случае) процесса? (Я имею ввиду именно вызов fork, а не clone).
Есть общая политика в *nix системах? Или все зависит от особенностей реализации fork в различных ядрах?
--
AD
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [Comm] Как работает fork()?
2004-08-25 9:11 [Comm] Как работает fork()? AD
2004-08-25 10:20 ` Макс
2004-08-26 8:17 ` php-coder
@ 2004-08-27 7:57 ` Anton V. Boyarshinov
2 siblings, 0 replies; 5+ messages in thread
From: Anton V. Boyarshinov @ 2004-08-27 7:57 UTC (permalink / raw)
To: community
On Wed, 25 Aug 2004 13:11:24 +0400 AD
wrote:
> 1. Файл открыт для эксклюзивного доступа. Вторая копия сможет
> работать с файлом?
А что вы под этим понимаете (под экслюзивным доступом)? Пока (кто
угодно) второй раз на файл flock не позовёт -- может рабоать с
ним сколько ему угодно.
Антон
--
mailto:boyarsh@mail.ru
mailto:boyarsh@ru.echo.fr
11:56:00 up 27 days, 10:32, 10 users, load average: 0.00,
0.04, 0.03
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2004-08-27 7:57 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2004-08-25 9:11 [Comm] Как работает fork()? AD
2004-08-25 10:20 ` Макс
2004-08-26 8:17 ` php-coder
2004-08-26 9:48 ` Re[2]: " AD
2004-08-27 7:57 ` Anton V. Boyarshinov
ALT Linux Community general discussions
This inbox may be cloned and mirrored by anyone:
git clone --mirror http://lore.altlinux.org/community/0 community/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 community community/ http://lore.altlinux.org/community \
mandrake-russian@linuxteam.iplabs.ru community@lists.altlinux.org community@lists.altlinux.ru community@lists.altlinux.com
public-inbox-index community
Example config snippet for mirrors.
Newsgroup available over NNTP:
nntp://lore.altlinux.org/org.altlinux.lists.community
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git