Difference between revisions of "UsingSyslog"
m (→Calling syslog method from your C source code) |
(→Basis) |
||
(2 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
+ | = Basis = | ||
+ | ==Calling syslog method from shell== | ||
+ | To do that, use '''logger''' command : | ||
+ | <pre class="target"> | ||
+ | # logger -t "MYTAGNAME" "I like otters with cream" | ||
+ | </pre> | ||
+ | |||
+ | You can then see the message in /var/log/messages: | ||
+ | <pre class="target"> | ||
+ | # tail /var/log/messages | ||
+ | ... | ||
+ | Oct 16 16:50:13 armadeus user.notice MYTAGNAME: I like otters with cream | ||
+ | </pre> | ||
+ | |||
==Calling syslog method from your C source code== | ==Calling syslog method from your C source code== | ||
This part is quite simple, but we need to correctly use each parameter. | This part is quite simple, but we need to correctly use each parameter. | ||
Line 50: | Line 64: | ||
</pre> | </pre> | ||
We can notice, that the lines contain program_name[PID] pattern showing us the name we have specified in openlog and the pid of the process because we ask it with LOG_PID argument. | We can notice, that the lines contain program_name[PID] pattern showing us the name we have specified in openlog and the pid of the process because we ask it with LOG_PID argument. | ||
+ | |||
+ | = Packages = | ||
+ | |||
+ | == Busybox == | ||
+ | |||
+ | By default, syslog is managed by busybox, it can be configured using menuconfig : | ||
+ | |||
+ | <pre class="host"> | ||
+ | $ make busybox-menuconfig | ||
+ | </pre> | ||
+ | |||
+ | The configuration menu can be found here : | ||
+ | |||
+ | <pre class="config"> | ||
+ | System Logging Utilities ---> | ||
+ | </pre> | ||
+ | |||
+ | == Buildroot packages == | ||
+ | |||
+ | Some other packages are available under buildroot. To see it launch buildroot menuconfig : | ||
+ | |||
+ | <pre class="host"> | ||
+ | $ make menuconfig | ||
+ | </pre> | ||
+ | |||
+ | Select option : | ||
+ | <pre class="config"> | ||
+ | Package Selection for the target ---> | ||
+ | [*] Show packages that are also provided by busybox | ||
+ | </pre> | ||
+ | |||
+ | Then go to following menu : | ||
+ | <pre class="config"> | ||
+ | Package Selection for the target ---> | ||
+ | System tools ---> | ||
+ | ... | ||
+ | [ ] rsyslog | ||
+ | [ ] syslogd & klogd | ||
+ | ... | ||
+ | </pre> |
Latest revision as of 15:51, 16 October 2013
Contents
Basis
Calling syslog method from shell
To do that, use logger command :
# logger -t "MYTAGNAME" "I like otters with cream"
You can then see the message in /var/log/messages:
# tail /var/log/messages ... Oct 16 16:50:13 armadeus user.notice MYTAGNAME: I like otters with cream
Calling syslog method from your C source code
This part is quite simple, but we need to correctly use each parameter. First step is to declare us as syslog client :
...
#include <syslog.h>
int main(int argc, char *argv[])
{
...
openlog("program_name", LOG_PID, LOG_USER);
...
closelog();
...
}
Then, you can call syslog from your code using printf like format :
...
syslog(LOG_INFO, "%s called with %d arguments\n", argv[0], argc);
...
If you compile the source file:
// log_syslog.c
#include <syslog.h>
int main(int argc, char *argv[])
{
openlog("program_name", LOG_PID, LOG_USER);
syslog(LOG_INFO, "%s called with %d arguments", argv[0], argc - 1);
closelog();
return 0;
}
With the command :
itsme@mycomputer:~/log_syslog$ gcc log_syslog.c -o log-syslog
Then run it 2 times :
itsme@mycomputer:~/log_syslog$ ./log_syslog itsme@mycomputer:~/log_syslog$ ./log_syslog pim pam poum
You will probably obtain no result in shell, but you can take a look in your system log (/var/log/syslog or /var/log/messages)
itsme@mycomputer:~/log_syslog$ tail -n 2 /var/log/syslog Sep 19 18:46:49 mycomputer program_name[3022]: ./log_syslog called with 0 arguments Sep 19 18:46:53 mycomputer program_name[3023]: ./log_syslog called with 3 arguments
We can notice, that the lines contain program_name[PID] pattern showing us the name we have specified in openlog and the pid of the process because we ask it with LOG_PID argument.
Packages
Busybox
By default, syslog is managed by busybox, it can be configured using menuconfig :
$ make busybox-menuconfig
The configuration menu can be found here :
System Logging Utilities --->
Buildroot packages
Some other packages are available under buildroot. To see it launch buildroot menuconfig :
$ make menuconfig
Select option :
Package Selection for the target ---> [*] Show packages that are also provided by busybox
Then go to following menu :
Package Selection for the target ---> System tools ---> ... [ ] rsyslog [ ] syslogd & klogd ...