.\" -*- coding: UTF-8 -*- '\" t .\" Copyright (c) 1983, 1991, 1993 .\" The Regents of the University of California. All rights reserved. .\" .\" SPDX-License-Identifier: BSD-4-Clause-UC .\" .\" @(#)rexec.3 8.1 (Berkeley) 6/4/93 .\" $FreeBSD: src/lib/libcompat/4.3/rexec.3,v 1.12 2004/07/02 23:52:14 ru Exp $ .\" .\" Taken from FreeBSD 5.4; not checked against Linux reality (mtk) .\" .\" 2013-06-21, mtk, Converted from mdoc to man macros .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH rexec 3 "15 декабря 2022 г." "Linux man\-pages 6.03" .SH ИМЯ rexec, rexec_af \- возвращает поток удалённой команде .SH LIBRARY Standard C library (\fIlibc\fP, \fI\-lc\fP) .SH СИНТАКСИС .nf \fB#include \fP .PP \fB[[deprecated]]\fP \fBint rexec(char **restrict \fP\fIahost\fP\fB, int \fP\fIinport\fP\fB,\fP \fB const char *restrict \fP\fIuser\fP\fB, const char *restrict \fP\fIpasswd\fP\fB,\fP \fB const char *restrict \fP\fIcmd\fP\fB, int *restrict \fP\fIfd2p\fP\fB);\fP .PP \fB[[deprecated]]\fP \fBint rexec_af(char **restrict \fP\fIahost\fP\fB, int \fP\fIinport\fP\fB,\fP \fB const char *restrict \fP\fIuser\fP\fB, const char *restrict \fP\fIpasswd\fP\fB,\fP \fB const char *restrict \fP\fIcmd\fP\fB, int *restrict \fP\fIfd2p\fP\fB,\fP \fB sa_family_t \fP\fIaf\fP\fB);\fP .fi .PP \fBrexec\fP(), \fBrexec_af\fP(): .nf начиная с glibc 2.19: _DEFAULT_SOURCE в glibc до версии 2.19 включительно: _BSD_SOURCE .fi .SH ОПИСАНИЕ Этот интерфейс устарел, используйте \fBrcmd\fP(3). .PP Функция \fBrexec\fP() ищет узел \fI*ahost\fP, используя \fBgethostbyname\fP(3), и возвращает \-1, если узел не существует. В противном случае, \fI*ahost\fP присваивается стандартное имя узла. Если указаны имя пользователя и пароль, то они используются для аутентификации на другом узле; иначе происходит поиск соответствующей информации в окружении и затем в файле \fI.netrc\fP, находящемся в домашнем каталоге пользователя. Если всё это заканчивается с ошибкой, пользователь извещается об этом. .PP В \fIinport\fP указывается, какой хорошо известный (well\-known) порт DARPA Internet нужно использовать для подключения; вызов \fIgetservbyname("exec", "tcp")\fP (смотрите \fBgetservent\fP(3)) вернёт указатель на структуру, которая содержит необходимый порт. Протокол подключения подробно описан в \fBrexecd\fP(8). .PP Если соединение успешно установлено, то вызывающему возвращается сокет в Интернет\-домене типа \fBSOCK_STREAM\fP, который для удалённой команды считается \fIstdin\fP и \fIstdout\fP. Если \fIfd2p\fP не равно нулю, то устанавливается вспомогательный канал до управляющего процесса, а его файловый дескриптор будет помещён в \fI*fd2p\fP. Управляющий процесс возвращает диагностический вывод из команды (устройства 2) в этот канал, а также принимает байты из этого канала, считая их номерами сигналов UNIX, для их пересылки группе процессов команды. Возвращаемая диагностическая информация не содержит ошибки удалённой авторизации, так как второе подключение устанавливается после прохождения авторизации. Если \fIfd2p\fP равно 0, то \fIstderr\fP (устройство 2 удалённой команды) будет работать аналогично \fIstdout\fP и для отправки произвольных сигналов в удалённый процесс ничего не будет сделано, хотя вы сможете привлечь к себе внимание, используя внеполосную передачу данных. .SS rexec_af() Функция \fBrexec\fP() работает по протоколу IPv4 (\fBAF_INET\fP). В отличие от неё, \fBrexec_af\fP() предоставляет ещё один аргумент, \fIaf\fP, который позволяет вызывающему выбрать протокол. В этом аргументе можно указать значения \fBAF_INET\fP, \fBAF_INET6\fP или \fBAF_UNSPEC\fP (чтобы позволить реализации выбирать протокол). .SH ВЕРСИИ The \fBrexec_af\fP() function was added in glibc 2.2. .SH АТРИБУТЫ Описание терминов данного раздела смотрите в \fBattributes\fP(7). .ad l .nh .TS allbox; lbx lb lb l l l. Интерфейс Атрибут Значение T{ \fBrexec\fP(), \fBrexec_af\fP() T} Безвредность в нитях MT\-Unsafe .TE .hy .ad .sp 1 .SH СТАНДАРТЫ Данные функции отсутствуют в POSIX.1. Функция \fBrexec\fP() впервые появилась в 4.2BSD, и есть в разных BSD, Solaris и других системах. Функция \fBrexec_af\fP() более новая и распространена гораздо меньше. .SH ДЕФЕКТЫ Функция \fBrexec\fP() посылает пароль через сеть в нешифрованном виде. .PP Считается, что лежащая в основе служба является большой дырой в безопасности, и поэтому не включена на большинстве сайтов; смотрите объяснение в \fBrexecd\fP(8). .SH "СМ. ТАКЖЕ" \fBrcmd\fP(3), \fBrexecd\fP(8) .PP .SH ПЕРЕВОД Русский перевод этой страницы руководства был сделан aereiae , Azamat Hackimov , Dmitriy S. Seregin , Katrin Kutepova , Lockal , Yuri Kozlov , Баринов Владимир и Иван Павлов . .PP Этот перевод является бесплатной документацией; прочитайте .UR https://www.gnu.org/licenses/gpl-3.0.html Стандартную общественную лицензию GNU версии 3 .UE или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ. .PP Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на .MT man-pages-ru-talks@lists.sourceforge.net .ME .