| Scroll Ignore | ||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| ||||||||||||||
|
Description
Le module de source ldap-import permet d’interroger un serveur Active Directory ou OpenLDAP afin de récupérer toutes les informations disponibles des hôtes, groupes d'hôtes, utilisateurs et groupes d'utilisateurs présents.
Il est possible d'importer uniquement des hôtes ou des contacts, depuis certains endroits seulement.
Activation du collecteur
Vous pouvez essayer ce type de source soit en activant le collecteur active-dir-example présent par défaut ou en activant vos propres collecteurs de type ldap-import .
Activer le collecteur Active Directory livré par défaut
Par défaut, l’installation ou la mise à jour de Shinken Entreprise va mettre à disposition une définition de collecteur Active Directory.
- La configuration de ce collecteur se trouve par défaut dans le fichier : /etc/shinken/sources/active-dir-hosts.cfg
- Vérifier que le nom "active-dir-example" est présent dans le paramètre sources du fichier /etc/shinken/synchronizers/synchronizer-master.cfg ( ou le .cfg que vous utilisez pour définir les options du Synchronizer ).
- Ce collecteur est normalement présent dans la liste des sources livrées par défaut.
S'il n'y est pas ( car modifié ), vous pouvez le rajouter pour qu'il soit de nouveau actif.
Exemple :
Code Block language js theme bashConfluence define synchronizer { [...] sources Source 1, Source 2, Source 3, active-dir-example [...] }
Si vous avez rajouté la source, redémarrez le Synchronizer pour qu'il puisse prendre en compte cette nouvelle source.
Code Block language bashtext theme ConfluenceEmacs service shinken-synchronizer restart
Ajouter un autre collecteur Active Directory
Vous pouvez avoir plusieurs sources du type ldap-import, pour par exemple se connecter à plusieurs serveurs Open LDAP.
Choisissez un nom pour ce nouveau collecteur.
- Pour l'exemple, nous allons l'appeler "Mon-Collecteur-Active-Directory".
- Remplacer dans l'exemple le mot "Mon-Collecteur-Active-Directory" par le nom que vous aurez choisi.
Pour ajouter une autre source, vous devez :
Créer un répertoire pour contenir les fichiers de configuration de la source :
Code Block language bashtext theme ConfluenceEmacs mkdir -p /etc/shinken-user/source-data/source-data__Mon-Collecteur-Active-Directory/_configuration
Copier les fichiers d'exemple dans le répertoire de configuration de la source :
Code Block language bashtext theme ConfluenceEmacs cp /etc/shinken-user-example/sources/active-directory/active-directory-* /etc/shinken-user/source-data/source-data__Mon-Collecteur-Active-Directory/_configuration/
Copier le fichier de définition de la source d'exemple : /etc/shinken/sources/active-dir-hosts.cfg dans le répertoire de définition des sources /etc/shinken/sources/ et modifier son nom pour qu'il soit différent de l'autre source de type ldap-import.
( Exemple : /etc/shinken/sources/Mon-Collecteur-Active-Directory.cfg )Code Block language bashtext theme ConfluenceEmacs cp /etc/shinken/sources/active-dir-hosts.cfg /etc/shinken/sources/collector__ldap-import__Mon-Collecteur-Active-Directory.cfg
Dans ce nouveau fichier, changer le nom de la source et faire correspondre les chemins vers les fichiers de configurations précédemment copiés :
Code Block language bashjs theme Confluence ... #======== source identity ========= # Source name. Must be unique source_name serveur_AD_France ... # Configuration file for your Active Directory connection (server, user, password, ...)a connection_configuration_file /etc/shinken-user/source-data/source-data__Mon-Collecteur-Active-Directory/_configuration/active-directory-connection.json # Configuration file for your import rules (like OU=>template rules) rules_configuration_file /etc/shinken-user/source-data/source-data__Mon-Collecteur-Active-Directory/_configuration/active-directory-rules.json # Configuration file for your ldap fields mapping (like for openldap users) mapping_configuration_file /etc/shinken-user/source-data/source-data__Mon-Collecteur-Active-Directory/_configuration/active-directory-mapping.json ...Vous trouverez plus de détail sur ces fichiers dans la page Collecteur (de type ldap-import ) Import depuis un serveur ( pour Active Directory ).
Une fois que le fichier a été édité, vérifiez que le fichier possède comme droits utilisateurs shinken. Si ce n'est pas le cas, effectuez la commande suivante :
Code Block language text theme Emacs chown -R shinken:shinken /etc/shinken/sources/collector__ldap-import__Mon-Collecteur-Active-Directory.cfg
Faire pareil avec les fichiers de configurations de la source et leur ajouter les droits d'écriture :
Code Block language bashtext theme ConfluenceEmacs chown -R shinken:shinken /etc/shinken-user/source-data/source-data__Mon-Collecteur-Active-Directory/_configuration chmod -R 664 /etc/shinken-user/source-data/source-data__Mon-Collecteur-Active-Directory/_configuration/
Ajouter le nom de la nouvelle source au Synchronizer en modifiant le paramètre sources du fichier /etc/shinken/synchronizers/synchronizer-master.cfg .
Code Block language bashjs theme Confluence sources syncui,cfg-file-shinken,active-dir-example,cfg-file-nagios,discovery,openldap-example,synchronizer-collector-vmware,Mon-Collecteur-Active-Directory
Redémarrez le Synchronizer pour qu'il puisse prendre en compte cette nouvelle source
Code Block language bashtext theme ConfluenceEmacs service shinken-synchronizer restart
Configuration
Voici le détail de fichier de configuration de la source se trouve :
- Soit le fichier /etc/shinken/sources/active-dir-hosts.cfg
- Soit dans le fichier que vous venez de créer en ajoutant le module ( par exemple /etc/shinken/sources/serveur_AD_France.cfg )
Exemple de fichier de configuration
Vous trouverez un exemple dans /etc/shinken-user-example/configuration/daemons/synchronizers/sources/active-dir-hosts/active-dir-hosts-example.cfg
| Code Block | ||||
|---|---|---|---|---|
| ||||
#===============================================================================
# active-dir-example
#===============================================================================
# Daemons that can load this source:
# - synchronizer
# This source import hosts and contacts from an Active Directory server
#===============================================================================
define source {
#===# Shinken Enterprise. Lines added by import core. Do not remove it, it's used by Shinken Enterprise to update your objects if you re-import them.
_SE_UUID core-source-ae7394945adc11e580e6080027f08538
_SE_UUID_HASH d1d512d1e37aae8486d6c2060cada8fd
# End of Shinken Enterprise part
#======== source identity =========
# Source name. Must be unique
source_name active-dir-example
# Module type (to load module code). Do not edit.
module_type ldap-import
# order: source order for a source imply if a source is before another source when merging data
order 2
# import_interval: in minutes, what is the schedule import interval for this source.
# note: 0 = don't schedule this source, will run only if an administrator launch it from the interface
import_interval 5
# enabled: is this source enabled or not
enabled 0
# description: display a description on the interface for this source
description This source is about loading hosts from active directories
# Connection mode:
# - ad: active directory
# - openldap: openldap.
mode ad
#======== Active directory access and data mapping =========
# In order to configure this source, you must copy or edit the sample active-directory source-data available in the directory
# /etc/shinken-user/source-data/source-data-active-directory-sample/ with theses files:
# * _configuration/active-directory-connection.json ==> how to connect to your active directory server
# * _configuration/active-directory-rules.json ==> what are the import rule to setup (like OU=>template rules)
# * _configuration/active-directory-mapping.json ==> if you have custom Ldap fields, you can defined them in this file (ex: for openldap users)
#
# Note: If a file is commented, the configuration will be load from the default directory /etc/shinken/_default/sources/active-directory-source
# Configuration file for your Active Directory connection (server, user, password, ...)
connection_configuration_file /etc/shinken-user/source-data/source-data-active-directory-sample/_configuration/active-directory-connection.json
# Configuration file for your import rules (like OU=>template rules)
rules_configuration_file /etc/shinken-user/source-data/source-data-active-directory-sample/_configuration/active-directory-rules.json
# Configuration file for your ldap fields mapping (like for openldap users)
mapping_configuration_file /etc/shinken-user/source-data/source-data-active-directory-sample/_configuration/active-directory-mapping.json
#======== Synchronization keys =========
# The list of properties to be used as sync_keys in addition to the item name and the SE_UUID. Properties not managed by Shinken can be added here.
# properties_used_as_synckey_for_hosthosts host_name, address
# properties_used_as_synckey_for_hostgrouphostgroups hostgroup_name
# properties_used_as_synckey_for_contactgroupcontactgroups contactgroup_name
# For the contact, you can add the "short_name" to add the email's part before the "@" into the sync_key
# properties_used_as_synckey_for_contactcontacts contact_name, email
}
|
Détails des sections composant le fichier de configuration
Identification du module
Il est possible de définir plusieurs instances de module de type ldap-import dans votre architecture Shinken.
- Chaque instance devra avoir un nom unique.
| Scroll Title | ||||
|---|---|---|---|---|
| ||||
|
|
|
|
|
Fonctionnement de la source
| Code Block | ||||
|---|---|---|---|---|
| ||||
define source {
...
order 3
import_interval 5
enabled 0
description This source is about loading hosts from active directories
...
} |
| Scroll Title | ||||
|---|---|---|---|---|
| ||||
|
|
|
|
|
|
|
|
Options du module
| Code Block | ||||
|---|---|---|---|---|
| ||||
define source {
...
# Connection mode:
# - ad: active directory
# - openldap: openldap.
mode ad
#======== Active directory access and data mapping =========
# In order to configure this source, you must copy or edit the sample active-directory source-data available in the directory
# /etc/shinken-user/source-data/source-data-active-directory-sample/ with theses files:
# * _configuration/active-directory-connection.json ==> how to connect to your active directory server
# * _configuration/active-directory-rules.json ==> what are the import rule to setup (like OU=>template rules)
# * _configuration/active-directory-mapping.json ==> if you have custom Ldap fields, you can defined them in this file (ex: for openldap users)
#
# Note: If a file is commented, the configuration will be load from the default directory /etc/shinken/_default/sources/active-directory-source
# Configuration file for your Active Directory connection (server, user, password, ...)
connection_configuration_file /etc/shinken-user/source-data/source-data-active-directory-sample/_configuration/active-directory-connection.json
# Configuration file for your import rules (like OU=>template rules)
rules_configuration_file /etc/shinken-user/source-data/source-data-active-directory-sample/_configuration/active-directory-rules.json
# Configuration file for your ldap fields mapping (like for openldap users)
mapping_configuration_file /etc/shinken-user/source-data/source-data-active-directory-sample/_configuration/active-directory-mapping.json
...
} |
| Scroll Title | ||||
|---|---|---|---|---|
| ||||
|
|
|
|
|
|
|
Clés de synchronisation ( sync_key )
| Code Block | ||||
|---|---|---|---|---|
| ||||
define source {
...
#======== Synchronization keys =========
# The list of properties to be used as sync_keys in addition to the item name and the SE_UUID. Properties not managed by Shinken can be added here.
# properties_used_as_synckey_for_host hosts host_name, address
# properties_used_as_synckey_for_hostgroup hostgroups hostgroup_name
# properties_used_as_synckey_for_contactgroup contactgroups contactgroup_name
# For the contact, you can add the "short_name" to add the email's part before the "@" into the sync_key
# properties_used_as_synckey_for_contact contacts contact_name, email
...
} |
Défini la liste des propriétés qui seront utilisées pour générer les clés de synchronisation pour chaque type d'éléments importés.
| Info |
|---|
À noter : On ne peut pas supprimer le nom et le _SE_UUID, mais on peut les compléter. |
| Scroll Title | ||||
|---|---|---|---|---|
| ||||
|
|
|
|
|
|
|
|
|
|
Propriétés non récupérées
Il est possible de définir des propriétés que la source ne devra pas récupérer.
- Dans le cas de cette source, si possible nous conseillons de ne pas utiliser cette option, car il est possible de choisir les champs collecter par cette source.
- En choisissant les champs collectés, vous gagnerez en performances, car ces informations ne seront pas importées puis supprimées.
- C'est pour ça que cette option n'est pas par défaut dans le fichier de configuration de la source.
| Scroll Title | ||||
|---|---|---|---|---|
| ||||
|
|
|