netconsole is a kernel module that sends all kernel log messages (i.e. dmesg) over the network to another computer, without involving user space (e.g. syslogd). Name "netconsole" is a misnomer because it's not really a "console", more like a remote logging service.
It can be used either built-in or as a module. Built-in netconsole initializes immediately after NIC cards and will bring up the specified interface as soon as possible. The module is mainly used for capturing kernel panic output from a headless machine, or in other situations where the user space is no more functional.
Documentation is available in the Linux kernel tree under Documentation/networking/netconsole.txt.
Netconsole can be configured via the
netconsole kernel parameter in the following format:
where the fields have the following meaning:
src-port— source for UDP packets (defaults to 6665)
src-ip— source IP to use (interface address)
dev— network interface (eth0)
tgt-port— port for logging agent (6666)
tgt-ip— IP address for logging agent
tgt-macaddr— ethernet MAC address for logging agent (broadcast)
The logging level can be set with the
loglevel kernel parameter, e.g.:
Netconsole can be loaded as kernel module manually after boot or automatically during boot depending on the module configuration (see Kernel modules for details).
To load the
netconsole module manually any time after boot:
# set log level for kernel messages dmesg -n 8 modprobe configfs modprobe netconsole mount none -t configfs /sys/kernel/config # 'netconsole' dir is auto created if the module is loaded mkdir /sys/kernel/config/netconsole/target1 cd /sys/kernel/config/netconsole/target1 # set local IP address echo 192.168.0.111 > local_ip # set destination IP address echo 192.168.0.17 > remote_ip # set local network device name (find it trough ifconfig, examples: eth0, eno1, wlan0) echo eno1 > dev_name # find destination MAC address arping -I $(cat dev_name) $(cat remote_ip) -f | grep -o ..:..:..:..:..:.. > remote_mac echo 1 > enabled
Netconsole should now be configured. To verify, run
dmesg | tail and you should see "netconsole: network logging started". Check available log levels by running
Install official repositories.or from the
nc -u -l 6666
nc -u -l -p 6666
Logging is done by your Arch Linux set logger like syslog-ng, so available loglevels (output details) are defined in that logger docs, and may differ for each log type. One can also pass netconsole string parameters at kernel runtime (no config file required), then start two netconsole instances on the monitoring PC (one to read output, another for input), and restart it on the PC or device you are logging as shown in Dynamic Configuration:
# set log level for kernel messages dmesg -n 8 email@example.com/eth0,firstname.lastname@example.org/00:13:32:20:r9:a5
nc -l -u -p 6666 & nc -u 192.168.1.28 6666 # socat as alternative to nc in one command socat - udp4-datagram:192.168.1.28:6666,bind=6666
One may need to switch off PC and router firewall, and setup proper router port forwarding to monitor and input data in Netconsole. A more flexible configuration can be achieved if netconsole is setup on a different subnet so that if the device is moved to a different network IP's won't clash, however it may require a more complex setup on the receiver with aliased ethernet interface.
netconsole is a kernel module which sends kernel logs over the network, which is useful for debugging slower computers. The setup process is:
- Set up another computer (running Arch) to accept syslog requests on a remote port using
- View the logs using your
- On the computer you are debugging, add a kernel paramter like
email@example.com/12:34:56:78:9a:bc(along with whatever debugging parameters you want)
- Restart the computer and view the logs