Oracle
 sql >> Base de données >  >> RDS >> Oracle

Définir différentes variables d'environnement ORACLE_HOME et PATH à l'aide d'Ansible

vous pouvez définir des variables spécifiques à l'hôte pour chacun des hôtes. Vous pouvez écrire votre fichier d'inventaire comme :

[is_hosts]
greenhat ORACLE_HOME=/tmp
localhost ORACLE_HOME=/sbin

de même pour la variable PATH

puis votre tâche :

exemple de playbook illustrant les résultats :

- hosts: is_hosts
  gather_facts: false
  vars:

  tasks:
    - name: task 1
      shell: "env | grep -e PATH -e ORACLE_HOME"
      environment:
        # PATH: "{{ hostvars[inventory_hostname]['PATH']}}"
        ORACLE_HOME: "{{ hostvars[inventory_hostname]['ORACLE_HOME'] }}"
      register: shell_output

    - name: print results
      debug:
        var: shell_output.stdout_lines

exemple de sortie, vous pouvez voir que la variable ORACLE_HOME a bien été modifiée, et telle que définie par hôte :

TASK [print results] ************************************************************************************************************************************************************************************************
ok: [greenhat] => {
    "shell_output.stdout_lines": [
        "ORACLE_HOME=/tmp", 
        "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin"
    ]
}
ok: [localhost] => {
    "shell_output.stdout_lines": [
        "ORACLE_HOME=/sbin", 
        "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin"
    ]
}