Aller au contenu principal

AWS Lambda

Contenu du Pack​

Modèles​

Le connecteur de supervision Centreon AWS Lambda apporte un modèle d'hôte :

  • Cloud-Aws-Lambda-custom

Il apporte le modèle de service suivant :

AliasModèle de serviceDescriptionDéfaut
Lambda-InvocationsCloud-Aws-Lambda-Invocations-ApiContrôle les performances du cache MemcachedX

Règles de découverte​

Ce pack propose une règle de découverte d'hôtes permettant de découvrir automatiquement des ressources AWS Backup vault :

image

Vous trouverez plus d'informations sur la découverte d'Hôtes et son fonctionnement sur la documentation du module : Découverte des hôtes

Métriques & statuts collectés​

Metric NameUnit
lambda.function.duration.millisecondsms
lambda.function.invocations.countcount
lambda.function.errors.countcount
lambda.function.deadlettererrors.countcount
lambda.function.throttles.countcount
lambda.function.iteratorage.millisecondscount

Prérequis​

Privilèges AWS​

Voici la liste des droits nécessaires au travers des access/secret key utilisées pour pouvoir utiliser le monitoring AWS/EC2:

AWS PrivilegeDescription
lamdba:ListFunctionsGet a list of Lambda function
cloudwatch:getMetricStatisticsGet metrics from the AWS/EC2 namespace on Cloudwatch.

Dépendances du Plugin​

Afin de récupérer les informations nécessaires via les APIs AWS, il est possible d'utiliser soit le binaire awscli fourni par Amazon, soit le SDK Perl paws. Le SDK est recommandé car plus performant.

Attention il n'est pas possible d'utiliser paws si la connexion s'effectue au travers d'un proxy.

yum install perl-Paws

Installation​

  1. Installez le plugin sur tous les collecteurs Centreon devant superviser des ressources AWS Lambda :
yum install centreon-plugin-Cloud-Aws-Lambda-Api
  1. Sur l'interface web de Centreon, installez le connecteur de supervision AWS Lambda depuis la page Configuration > Packs de plugins.

Configuration​

Hôte​

  • Ajoutez un hôte à Centreon depuis la page Configuration > Hôtes.
  • Remplissez le champ Adresse IP/DNS avec l'adresse 127.0.0.1.
  • Appliquez le modèle d'hôte Cloud-Aws-Lambda-custom.
  • Une fois le modèle appliqué, les Macros ci-dessous indiquées comme requises doivent être renseignées :
MandatoryNomDescription
XAWSSECRETKEYAWS Secret key of your IAM role. Password checkbox must be checked
XAWSACESSKEYAWS Access key of your IAM role. Password checkbox must be checked
XAWSREGIONRegion where the instance is running
XAWSCUSTOMMODECustom mode to get metrics, 'awscli' is the default, you can also use 'paws' perl library
PROXYURLConfigure proxy URL
FUNCTIONNAMEFunction name (Default : '.*')
EXTRAOPTIONSAny extra option you may want to add to every command line (eg. a --verbose flag)
DUMMYSTATUSHost state. Default is OK, do not modify it unless you know what you are doing
DUMMYOUTPUTHost check output. Default is 'This is a dummy check'. Customize it with your own if needed

Comment puis-je tester le plugin et que signifient les options des commandes ?​

Une fois le plugin installé, vous pouvez tester celui-ci directement en ligne de commande depuis votre collecteur Centreon en vous connectant avec l'utilisateur centreon-engine (su - centreon-engine) :

/usr/lib/centreon/plugins//centreon_aws_lambda_api.pl \
--plugin=cloud::aws::lambda::plugin \
--mode=invocations \
--custommode='awscli' \
--aws-secret-key='' \
--aws-access-key='' \
--region='eu-west-1' \
--proxyurl='' \
--filter-metric='' \
--timeframe='600' \
--period='60' \
--name='myfunctions' \
--zeroed \
--verbose

La commande devrait retourner un message de sortie similaire à :

OK: Function 'myfunctions' All metrics are ok | 'myfunctions~average#lambda.function.throttles.count'=0.00;;;; 'myfunctions~average#lambda.function.errors.count'=0.00;;;; 'myfunctions~average#lambda.function.iteratorage.milliseconds'=0.00;;;; 'myfunctions~average#lambda.function.invocations.count'=0.00;;;; 'myfunctions~average#lambda.function.deadlettererrors.count'=0.00;;;; 'myfunctions~average#lambda.function.duration.milliseconds'=0.00;;;; 'myfunctions~sum#lambda.function.throttles.count'=0.00;;;; 'myfunctions~sum#lambda.function.errors.count'=0.00;;;; 'myfunctions~sum#lambda.function.iteratorage.milliseconds'=0.00;;;; 'myfunctions~sum#lambda.function.invocations.count'=0.00;;;; 'myfunctions~sum#lambda.function.deadlettererrors.count'=0.00;;;; 'myfunctions~sum#lambda.function.duration.milliseconds'=0.00;;;;
Checking Function 'myfunctions'
Statistic 'Average' Metrics Throttles: 0.00, Errors: 0.00, Iterator Age: 0.00, Invocations: 0.00, Dead Letter Errors: 0.00, Duration: 0.00
Statistic 'Sum' Metrics Throttles: 0.00, Errors: 0.00, Iterator Age: 0.00, Invocations: 0.00, Dead Letter Errors: 0.00, Duration: 0.00

La liste de toutes les options complémentaires et leur signification peut être affichée en ajoutant le paramètre --help à la commande :

/usr/lib/centreon/plugins//centreon_aws_lambda_api.pl \
--plugin=cloud::aws::lambda::plugin \
--mode=invocations \
--help

Tous les modes disponibles peuvent être affichés en ajoutant le paramètre --list-mode à la commande :

/usr/lib/centreon/plugins//centreon_aws_lambda_api.pl \
--plugin=cloud::aws::lambda::plugin \
--list-mode

Diagnostic des erreurs communes​

Rendez-vous sur la documentation dédiée pour le diagnostic des erreurs communes des plugins Centreon.