Le système d'exploitation est scientifique Linux 6.3 (qui est similaire à Redhat, Centos et Fedora) et j'ai installé DNSMASQ avec la configuration suivante
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
et le nœud actuel (qui exécute dnsmasq) a cette adresse 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
Cependant, je reçois une erreur lorsque j'essaie de démarrer le service 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]
la commande netstat montre les informations suivantes
[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
et
[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
Que peut causer une telle erreur et comment puis-je résoudre ce problème?
Le problème est que vous avez configuré dnsmasq
pour fournir un service TFTP (via enable-tftp
option dans dnsmasq.conf
). Le port de service pour TFTP est UDP/69, alors dnsmasq
veut le lier, mais xinetd
l'a déjà fait, et il est impossible pour deux processus différents de se lier au même port de service. .
Si vous voulez dnsmasq
Pour fournir le service TFTP, vous devrez modifier la configuration xinetd
(probable /etc/xinetd.conf
) Pour éteindre son service TFTP. Ou si vous préférez avoir xinetd
fournir le service TFTP, vous devrez alors supprimer enable-tftp
de dnsmasq.conf
.