eth0, mon interface interne, a une adresse statique de 10.0.0.1. J'ai également une interface p4p1, agissant comme mon interface externe. Si cela est important, mon interface externe n'est pas physiquement connectée et iptablesest éteinte / en cours d'écriture.
/etc/sysconfig/dhcpd:
DHCPDARGS=eth0
clause de sous-réseau de /etc/dhcpd.conf:
subnet 10.0.0.0 netmask 255.255.255.0 {
  option routers 10.0.0.1;
  option domain-name-servers 10.0.0.1;
  option ntp-servers 10.0.0.1;
  default-lease-time 86400; # 1 day 
  max-lease-time 604800;    # 7 days
  use-host-decl-names on;
  ddns-updates on;
  use-host-decl-names on;
  allow unknown-clients;
  ignore client-updates;
  option domain-name "localdomain";
  ddns-domainname "localdomain";
  next-server 10.0.0.1;
  filename "pxelinux.0";
  group # known hosts
  {
    host host1.localdomain  {hardware ethernet [REDACTED]; fixed-address host1.localdomain;}
    host host2.localdomain  {hardware ethernet [REDACTED]; fixed-address host2.localdomain;}
  {
  pool
  {
    one-lease-per-client true;
    ping-check true;
    range 10.0.0.51 10.0.0.60;
  }
}
Alors, pourquoi reçois-je toujours le message d'erreur "Aucune déclaration de sous-réseau" au lancement?
No subnet declaration for eth0 (10.0.0.1).
** Ignoring requests on eth0.  If this is not what
   you want, please write a subnet declaration
   in your dhcpd.conf file for the network segment
   to which interface eth0 is attached. **
MISE À JOUR 4/1 1900h
Avant les expériences de ce soir:
[root@father ~]# ip addr show dev eth0
3: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 90:e2:ba:2d:92:4d brd ff:ff:ff:ff:ff:ff
    inet 10.0.0.1/24 brd 10.0.0.255 scope global eth0
    inet6 fe80::92e2:baff:fe2d:924d/64 scope link 
       valid_lft forever preferred_lft forever
J'ai changé mes adresses IP de réseau interne 192.168.100.0/24avec des modifications correspondantes /etc/dhcpd.confpour aucun changement de comportement.
[root@father ~]# ip addr show dev eth0
3: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 90:e2:ba:2d:92:4d brd ff:ff:ff:ff:ff:ff
    inet 192.168.100.1/24 brd 192.168.100.255 scope global eth0
    inet6 fe80::92e2:baff:fe2d:924d/64 scope link 
       valid_lft forever preferred_lft forever
[root@father ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.100.0   0.0.0.0         255.255.255.0   U     0      0        0 eth0
192.168.0.0     0.0.0.0         255.255.255.0   U     0      0        0 p4p1
169.254.0.0     0.0.0.0         255.255.0.0     U     1002   0        0 p4p1
169.254.0.0     0.0.0.0         255.255.0.0     U     1003   0        0 eth0
Oh hey! Pas de passerelle là-bas! C'est facile à corriger avec un GATEWAY=192.168.0.1dans les fichiers ifcfg-eth0et ifcfg-p4p1. service network restartet...
[root@father ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.100.0   0.0.0.0         255.255.255.0   U     0      0        0 eth0
192.168.0.0     0.0.0.0         255.255.255.0   U     0      0        0 p4p1
169.254.0.0     0.0.0.0         255.255.0.0     U     1002   0        0 p4p1
169.254.0.0     0.0.0.0         255.255.0.0     U     1003   0        0 eth0
0.0.0.0         192.168.0.1     0.0.0.0         UG    0      0        0 p4p1
J'ai donc une passerelle, mais service dhcpd startéchoue avec la même erreur.
Autres notes:
- p4p1n'est pas physiquement connecté.
- service dhcpd configtestdit- Syntax: OK. Donc, ce n'est certainement pas le cas d'une attelle mal placée.
systemd: vous pouvez faire une copie/lib/systemd/system/dhcpd.serviceà/etc/systemd/system/et spécifiez l'interface dans la Exec ligne:ExecStart=/usr/sbin/dhcpd -f -cf /etc/dhcp/dhcpd.conf -user dhcpd -group dhcpd --no-pid eth0