stream_socket_pair - Создаёт пару связанных неразличимых потоковых сокетов
Вернуться к: Функции для работы с потоками
stream_socket_pair
(PHP 5 >= 5.1.0, PHP 7)
stream_socket_pair — Создаёт пару связанных неразличимых потоковых сокетов
Описание
$domain
, int $type
, int $protocol
)stream_socket_pair() создаёт пару связанных неразличимых потоковых сокетов. Эта функция обычно используется в IPC (межпроцессном взаимодействии).
Список параметров
-
domain
-
Используемое семейство протоколов:
STREAM_PF_INET
,STREAM_PF_INET6
илиSTREAM_PF_UNIX
-
type
-
Используемый тип взаимодействия:
STREAM_SOCK_DGRAM
,STREAM_SOCK_RAW
,STREAM_SOCK_RDM
,STREAM_SOCK_SEQPACKET
orSTREAM_SOCK_STREAM
-
protocol
-
Используемый протокол:
STREAM_IPPROTO_ICMP
,STREAM_IPPROTO_IP
,STREAM_IPPROTO_RAW
,STREAM_IPPROTO_TCP
orSTREAM_IPPROTO_UDP
Замечание: Пожалуйста, обратитесь к разделу Список потоковых констант за подробной информацией по каждой константе.
Возвращаемые значения
Возвращает массив array с двумя потоковыми ресурсами в случае успеха, или
FALSE
в случае неудачи.
Список изменений
Версия | Описание |
---|---|
5.3.0 | Теперь эта функция доступна на Windows платформах. |
Примеры
Пример #1 Пример использования stream_socket_pair()
Этот пример демонстрирует основы использования функции stream_socket_pair() в межпроцессном взаимодействии.
<?php
$sockets = stream_socket_pair(STREAM_PF_UNIX, STREAM_SOCK_STREAM, STREAM_IPPROTO_IP);
$pid = pcntl_fork();
if ($pid == -1) {
die('не удалось создать процесс');
} else if ($pid) {
/* родительский процесс */
fclose($sockets[0]);
fwrite($sockets[1], "дочерний PID: $pid\n");
echo fgets($sockets[1]);
fclose($sockets[1]);
} else {
/* дочерний процесс */
fclose($sockets[1]);
fwrite($sockets[0], "сообщение от дочернего процесса\n");
echo fgets($sockets[0]);
fclose($sockets[0]);
}
?>
Результатом выполнения данного примера будет что-то подобное:
дочерний PID: 1378 сообщение от дочернего процесса
Вернуться к: Функции для работы с потоками