La principal fuerza impulsora detrás de la existencia de esta convención de nomenclatura de directorios es la administración más sencilla de paquetes de archivos de configuración. Ya sea rpm, deb o lo que sea, es mucho más fácil (y probablemente más seguro) poder soltar un archivo en un directorio para que se incluya automáticamente en la configuración de un programa en lugar de intentar editar un archivo de configuración global.
Un buen ejemplo de esto es logrotate. En el directorio /etc/logrotate.d hay archivos de configuración para prácticamente todas las aplicaciones que ha instalado que mantienen un registro en / var / log . Algunos están agrupados en la configuración de syslog porque casi todos los sistemas tienen un archivo de mensajes, wtmp y lastlog. Pero si instala Apache en su sistema, necesita una manera fácil de agregar automáticamente la configuración para rotar los registros de Apache, por lo que simplemente suelta un archivo de configuración llamado httpd en /etc/logrotate.dy logrotate está configurado para incluir los archivos en ese directorio. Cada uno es propiedad del paquete para el demonio y si elimina el paquete, eliminará el archivo. Básicamente es una forma de modularizar los archivos de configuración. Tenga en cuenta que esto debe ser compatible con el programa, no es algo automático que el sistema hace por usted o algo así. Por lo general, los programas que lo hacen tienen una directiva de configuración llamada include que especifica dónde se encuentra ese directorio en el sistema de archivos.
logrotate.d podría incluso ser el primer lugar donde se usó esta convención fuera de los directorios init.d y rc.d para los scripts de inicio.