ОС является Научным Linux 6.3 (который подобен Redhat, песням и мягкой фетровой шляпе), и я установил dnsmasq со следующей конфигурацией
interface=eth1
domain=hpclab
expand-hosts
dhcp-range=10.0.2.51,10.0.2.100,static
dhcp-option=42,0.0.0.0
dhcp-boot=pxelinux.0
enable-tftp
tftp-root=/var/lib/tftpboot
dhcp-host=08:00:27:69:73:7A,ws04,10.0.2.51
и текущий узел (который выполняет dnsmasq) имеет этот IP
eth1 Link encap:Ethernet HWaddr 08:00:27:A9:20:C0
inet addr:10.0.2.15 Bcast:10.0.2.255 Mask:255.255.255.0
inet6 addr: fe80::a00:27ff:fea9:20c0/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
Однако я получаю ошибку при попытке запустить dnsmasq сервис
[root@localhost mahmood]# /etc/init.d/dnsmasq status
dnsmasq is stopped
[root@localhost mahmood]# /etc/init.d/dnsmasq start
Starting dnsmasq:
dnsmasq: failed to create listening socket: Address already in use
[FAILED]
команда netstat показывает следующую информацию
[root@localhost mahmood]# netstat -anlp | grep -w LISTEN
tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN 1252/rpcbind
tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN 1445/cupsd
tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 1685/master
tcp 0 0 0.0.0.0:46556 0.0.0.0:* LISTEN 1348/rpc.statd
tcp 0 0 :::111 :::* LISTEN 1252/rpcbind
tcp 0 0 :::80 :::* LISTEN 4884/httpd
tcp 0 0 ::1:631 :::* LISTEN 1445/cupsd
tcp 0 0 :::51096 :::* LISTEN 1348/rpc.statd
и
[root@localhost mahmood]# netstat -aunp
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
udp 0 0 0.0.0.0:69 0.0.0.0:* 5110/xinetd
udp 0 0 0.0.0.0:34136 0.0.0.0:* 1323/avahi-daemon
udp 0 0 0.0.0.0:38756 0.0.0.0:* 1348/rpc.statd
udp 0 0 0.0.0.0:5353 0.0.0.0:* 1323/avahi-daemon
udp 0 0 0.0.0.0:1003 0.0.0.0:* 1252/rpcbind
udp 0 0 0.0.0.0:111 0.0.0.0:* 1252/rpcbind
udp 0 0 0.0.0.0:631 0.0.0.0:* 1445/cupsd
udp 0 0 0.0.0.0:676 0.0.0.0:* 1348/rpc.statd
udp 0 0 0.0.0.0:68 0.0.0.0:* 5189/dhclient
udp 0 0 :::1003 :::* 1252/rpcbind
udp 0 0 :::111 :::* 1252/rpcbind
udp 0 0 :::43248 :::* 1348/rpc.statd
Что может вызвать такую ошибку и как я могу зафиксировать это?
Проблема в том, что вы настроили dnsmasq
на предоставление услуги TFTP (с помощью опции enable-tftp
в dnsmasq.conf
). Порт для TFTP - UDP/69, поэтому dnsmasq
хочет к нему привязаться, но xinetd
уже сделал это, и два разных процесса не могут привязываться к одному и тому же порту.
Если вы хотите, чтобы dnsmasq
предоставлял услугу TFTP, вам нужно изменить конфигурацию xinetd
(скорее всего, /etc/xinetd.conf
), чтобы отключить его TFTP-службу. Или, если вы предпочитаете, чтобы xinetd
предоставлял услугу TFTP, то необходимо удалить enable-tftp
из dnsmasq.conf
.