OSはScientific Linux 6.3(redhat、centos、Fedoraに似ています)であり、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
そのようなエラーの原因は何ですか?どのように修正できますか?
問題は、TFTPサービスを提供するようにdnsmasq
を構成したことです(enable-tftp
のdnsmasq.conf
オプションを介して)。 TFTPのサービスポートはUDP/69であるため、dnsmasq
はそれにバインドする必要がありますが、xinetd
はすでにバインドしているため、2つの異なるプロセスが同じサービスポートにバインドすることはできません。 。
dnsmasq
でTFTPサービスを提供する場合は、xinetd
構成(/etc/xinetd.conf
など)を編集して、TFTPサービスをオフにする必要があります。または、xinetd
にTFTPサービスを提供したい場合は、enable-tftp
からdnsmasq.conf
を削除する必要があります。