.\" -*- coding: UTF-8 -*- '\" t .\" Written Feb 1994 by Steve Greenland (stevegr@neosoft.com) .\" and Copyright 2001, 2017 Michael Kerrisk .\" .\" SPDX-License-Identifier: Linux-man-pages-copyleft .\" .\" Updated 1999.12.19 by Karl M. Hegbloom .\" .\" Updated 13 Oct 2001, Michael Kerrisk .\" Added description of vsyslog .\" Added descriptions of LOG_ODELAY and LOG_NOWAIT .\" Added brief description of facility and option arguments .\" Added CONFORMING TO section .\" 2001-10-13, aeb, minor changes .\" Modified 13 Dec 2001, Martin Schulze .\" Modified 3 Jan 2002, Michael Kerrisk .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH syslog 3 "2 мая 2024 г." "Linux man\-pages 6.8" .SH ИМЯ closelog, openlog, syslog, vsyslog \- отправка сообщений в службу журналирования .SH LIBRARY Standard C library (\fIlibc\fP, \fI\-lc\fP) .SH СИНТАКСИС .nf \fB#include \fP .P \fBvoid openlog(const char *\fP\fIident\fP\fB, int \fP\fIoption\fP\fB, int \fP\fIfacility\fP\fB);\fP \fBvoid syslog(int \fP\fIpriority\fP\fB, const char *\fP\fIformat\fP\fB, ...);\fP \fBvoid closelog(void);\fP .P \fBvoid vsyslog(int \fP\fIpriority\fP\fB, const char *\fP\fIformat\fP\fB, va_list \fP\fIap\fP\fB);\fP .fi .P .RS -4 Требования макроса тестирования свойств для glibc (см. \fBfeature_test_macros\fP(7)): .RE .P \fBvsyslog\fP(): .nf Начиная с glibc 2.19: _DEFAULT_SOURCE В версии glibc 2.19 и более ранних: _BSD_SOURCE .fi .SH ОПИСАНИЕ .SS openlog() Функция \fBopenlog\fP() открывает для программы соединение со службой журналирования. .P Строка, на которую указывает \fIident\fP, будет предварять каждое сообщение, обычно это имя программы. Если значение \fIident\fP равно NULL, то используется имя программы (в POSIX.1\-2008 не указано, что случается, если \fIident\fP равно NULL). .P В аргументе \fIoption\fP указываются флаги, контролирующие действия \fBopenlog\fP() и последующих вызовов \fBsyslog\fP(). Аргумент \fIfacility\fP устанавливает значения по умолчанию, если не будет указано другое в последующих вызовах \fBsyslog\fP(). Значения для \fIoption\fP и \fIfacility\fP представлены ниже. .P .\" Использование \fBopenlog\fP() не обязательно; она будет вызвана \fBsyslog\fP() в случае необходимости (в этом случае по умолчанию \fIident\fP будет установлено в NULL). .SS "syslog() и vsyslog()" Функция \fBsyslog\fP() генерирует сообщение журнала, которое будет передавать \fBsyslogd\fP(8). .P Аргумент \fIpriority\fP составляется из объединения значений \fIfacility\fP и \fIlevel\fP (описано ниже). Если значения \fIfacility\fP нет в \fIpriority\fP, то по умолчанию используется значение, заданное \fBopenlog\fP(), или, если до этого \fBopenlog\fP() не вызывался, используется значение \fBLOG_USER\fP. .P Оставшиеся аргументы — \fIformat\fP, задаются в формате как у \fBprintf\fP(3) (а также аргументы, необходимые для \fIformat\fP) за исключением последовательности двух символов \fB%m\fP, которые заменяются строкой ошибки \fIstrerror\fP(\fIerrno\fP). В строку формата не нужно включать конечный символ новой строки. .P .\" Функция \fBvsyslog\fP() выполняет то же самое, что и \fBsyslog\fP() с той лишь разницей, что она принимает набор аргументов, получаемых с использованием списка макросов \fBstdarg\fP(3). .SS closelog() .\" Функция \fBcloselog\fP() закрывает файловый дескриптор, использованный для записи в службу журналирования. Использование \fBcloselog\fP() не обязательно. .SS "Значения \fIoption\fP" Аргумент \fIoption\fP у \fBopenlog\fP() представляет собой битовую маску объединённых следующих значений: .TP 15 \fBLOG_CONS\fP Писать напрямую в системную консоль, если при отправке в систему журналирования возникла ошибка. .TP \fBLOG_NDELAY\fP Немедленно открыть соединение (обычно соединение открывается при первом сообщении). Например, это может быть полезно, если последующий \fBchroot\fP(2) делает недоступным путь, используемый внутри свойства протоколирования. .TP \fBLOG_NOWAIT\fP Не ждать дочерних процессов, которые могут быть созданы во время журналирования сообщения (библиотека GNU C не создаёт дочерних процессов, так что в Linux этот параметр не действует). .TP \fBLOG_ODELAY\fP Противоположен \fBLOG_NDELAY\fP; открытие подключения откладывается, пока не будет вызван \fBsyslog\fP() (этот параметр используется по умолчанию, нет необходимости выставлять его вручную). .TP \fBLOG_PERROR\fP (нет в POSIX.1\-2001 или POSIX.1\-2008) Также протоколировать сообщение в \fIstderr\fP. .TP \fBLOG_PID\fP .\" Включать PID вызывающего в каждое сообщение. .SS "Значения \fIfacility\fP" Аргумент \fIfacility\fP используется для указания типа программы, записывающей сообщение. Благодаря этому с помощью файла настройки можно по\-разному обрабатывать сообщения от разных объектов. .TP 15 \fBLOG_AUTH\fP сообщения безопасности/авторизации .TP \fBLOG_AUTHPRIV\fP сообщения безопасности/авторизации (private) .TP \fBLOG_CRON\fP планировщик заданий (\fBcron\fP и \fBat\fP) .TP \fBLOG_DAEMON\fP системные службы без определенного значения объекта .TP \fBLOG_FTP\fP служба FTP .TP \fBLOG_KERN\fP .\" LOG_KERN has the value 0; if used as a facility, zero translates to: .\" "use the default facility". сообщения ядра (не могут быть созданы пользовательскими процессами) .TP с \fBLOG_LOCAL0\fP по \fBLOG_LOCAL7\fP зарезервировано для локального использования .TP \fBLOG_LPR\fP подсистема печати .TP \fBLOG_MAIL\fP почтовая подсистема .TP \fBLOG_NEWS\fP подсистема новостей USENET .TP \fBLOG_SYSLOG\fP сообщения, сгенерированные самой службой \fBsyslogd\fP(8) .TP \fBLOG_USER\fP (по умолчанию) обычные сообщения пользовательского уровня .TP \fBLOG_UUCP\fP .\" подсистема UUCP .SS "Значения \fIlevel\fP" Определяет важность сообщения. Ниже указаны уровни по уменьшению важности: .TP 15 \fBLOG_EMERG\fP система в нерабочем состоянии .TP \fBLOG_ALERT\fP необходимо срочное вмешательство .TP \fBLOG_CRIT\fP критические состояния .TP \fBLOG_ERR\fP ошибки .TP \fBLOG_WARNING\fP предупреждения .TP \fBLOG_NOTICE\fP обычные, но важные сообщения .TP \fBLOG_INFO\fP информационные сообщения .TP \fBLOG_DEBUG\fP сообщения уровня отладки .P Для ограничения журналирования только в определенные уровни можно использовать функцию \fBsetlogmask\fP(3). .SH АТРИБУТЫ Описание терминов данного раздела смотрите в \fBattributes\fP(7). .TS allbox; lbx lb lb l l l. Интерфейс Атрибут Значение T{ .na .nh \fBopenlog\fP(), \fBcloselog\fP() T} Безвредность в нитях MT\-Safe T{ .na .nh \fBsyslog\fP(), \fBvsyslog\fP() T} Безвредность в нитях MT\-Safe env locale .TE .SH СТАНДАРТЫ .TP \fBsyslog\fP() .TQ \fBopenlog\fP() .TQ \fBcloselog\fP() POSIX.1\-2008. .TP \fBvsyslog\fP() None. .SH ИСТОРИЯ .TP \fBsyslog\fP() 4.2BSD, SUSv2, POSIX.1\-2001. .TP \fBopenlog\fP() .TQ \fBcloselog\fP() .\" .SH HISTORY .\" 4.3BSD documents .\" .BR setlogmask (). 4.3BSD, SUSv2, POSIX.1\-2001. .TP \fBvsyslog\fP() .\" Of course early v* functions used the .\" .I .\" mechanism, which is not compatible with .\" .IR . 4.3BSD\-Reno. .P В POSIX.1\-2001 для \fIfacility\fP описаны только значения \fBLOG_USER\fP и \fBLOG_LOCAL*\fP. Однако, за исключением \fBLOG_AUTHPRIV\fP и \fBLOG_FTP\fP, остальные значения \fIfacility\fP присутствуют в большинстве систем UNIX. .P Значение \fBLOG_PERROR\fP для \fIoption\fP не описано в POSIX.1\-2001 или POSIX.1\-2008, однако доступно в большинстве версий UNIX. .SH ПРИМЕЧАНИЯ Аргумент \fIident\fP при вызове \fBopenlog\fP() сохраняется как есть. Поэтому, если строка меняется, \fBsyslog\fP() может начать добавлять уже изменённую строку. Если строка перестаёт существовать, то это может привести к непредвиденным результатам. Наиболее переносимый способ в данном случае \(em использовать строковую константу. .P Никогда не подставляйте пользовательские данные в качестве формата представления, используйте вместо этого: .P .in +4n .EX syslog(priority, "%s", string); .EE .in .SH "СМОТРИТЕ ТАКЖЕ" \fBjournalctl\fP(1), \fBlogger\fP(1), \fBsetlogmask\fP(3), \fBsyslog.conf\fP(5), \fBsyslogd\fP(8) .PP .SH ПЕРЕВОД Русский перевод этой страницы руководства разработал Alexander Golubev , Azamat Hackimov , Hotellook, Nikita , Spiros Georgaras , Vladislav , Yuri Kozlov и Иван Павлов . .PP Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, .UR https://www.gnu.org/licenses/gpl-3.0.html .UE версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ. .PP Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику по его адресу электронной почты или по адресу .MT списка рассылки русских переводчиков .ME .