Skip to main content
La version française est une traduction automatique. La version anglaise prévaut sur la française en cas de divergence.

Style NATIF

Contributeurs

SnapCenter prend en charge les langages de programmation ou de script non PERL pour créer des plug-ins. Il s'agit d'une programmation DE type NATIF, qui peut être un fichier script ou BATCH.

Les plug-ins DE style NATIF doivent respecter certaines conventions ci-dessous :

Le plug-in doit être exécutable

  • Pour les systèmes Unix, l'utilisateur qui exécute l'agent doit disposer de privilèges d'exécution sur le plug-in

  • Pour les systèmes Windows, les plug-ins PowerShell doivent avoir le suffixe .ps1, les autres scripts Windows doivent avoir le suffixe .cmd ou .bat et doivent être exécutables par l'utilisateur

  • Les plug-ins doivent réagir à l'argument de ligne de commande comme «-quiesce », «-unquiesce »

  • Les plug-ins doivent renvoyer le code de sortie 99 si une opération ou une fonction n'est pas implémentée

  • Les plug-ins doivent utiliser une syntaxe spécifique pour renvoyer les résultats au serveur

Manipulation générale du plug-in

Journalisation des messages d'erreur

Chaque opération peut renvoyer des messages au serveur, qui affiche et stocke le contenu. Un message contient le niveau du message, un horodatage et un texte de message. Les messages multilignes sont pris en charge.

Format :

SC_MSG#<level>#<timestamp>#<message>
SC_MESSAGE#<level>#<timestamp>#<message>

Utilisation de stubs enfichables

Les plug-ins SnapCenter doivent être en place avec des stubs plug-in. Ce sont des méthodes que le serveur SnapCenter appelle en fonction d'un flux de travail spécifique.

Embout enfichable Facultatif/requis Objectif

mise au repos

obligatoire

Ce segment d'accroche est responsable de l'exécution d'une mise en veille. Il place le Dans un état où nous pouvons créer une copie Snapshot. Ce processus est appelé avant l'opération Snapshot de stockage.

mise au repos

obligatoire

Ce segment d'accroche est responsable de l'exécution d'une mise au repos. Il place l'application dans un état normal. Ce processus est appelé après le stockage Opération de copie Snapshot.

clone_pre

facultatif

Ce stub est responsable de l'exécution des tâches de pré-clonage. Cela suppose que vous utilisez l'interface intégrée de clonage SnapCenter et que vous êtes également déclenché uniquement lors de l'exécution de l'action clone_vol ou clone_lun.

clone_post

Facultatif

Ce stub est responsable de l'exécution des tâches post-clone. Cela suppose que vous utilisez l'interface intégrée de clonage SnapCenter et que vous êtes uniquement déclenché lors des opérations clone_vol ou clone_lun.

restore_pre

Facultatif

Ce stub est responsable de l'exécution des tâches de pré-restauration. Cela suppose que vous utilisez l'interface intégrée de restauration SnapCenter et qu'elle n'est déclenchée que lorsque vous effectuez l'opération de restauration.

restaurer

facultatif

Ce stub est chargé d'effectuer toutes les actions de restauration. Cela suppose que vous n'utilisez pas l'interface de restauration intégrée. Il est déclenché lors de l'opération de restauration.

Exemples

Windows PowerShell

Vérifiez si le script peut être exécuté sur votre système. Si vous ne pouvez pas exécuter le script, définissez le contournement Set-ExecutionPolicy pour le script et relancez l'opération.

if ($args.length -ne 1) {
  write-warning "You must specify a method";
  break;
}
function log ($level, $message) {
  $d = get-date
  echo "SC_MSG#$level#$d#$message"
}
function quiesce {
  $app_name = (get-item env:APP_NAME).value
  log "INFO" "Quiescing application using script $app_name";
  log "INFO" "Quiescing application finished successfully"
}
function unquiesce {
  $app_name = (get-item env:APP_NAME).value
  log "INFO" "Unquiescing application using script $app_name";
  log "INFO" "Unquiescing application finished successfully"
}
  switch ($args[0]) {
    "-quiesce" {
    quiesce;
}
"-unquiesce" {
    unquiesce;
}
default {
    write-error "Function $args[0] is not implemented";
    exit 99;
  }
}
exit 0;