diff --git a/roles/openLdapClient/tasks/configLdapClient.yml b/roles/openLdapClient/tasks/configLdapClient.yml index e50aab3a95f95c14d5251a07617200f72b39fb3d..2c3db2deb6da14a14fd99429459e78d2bd0a90cf 100644 --- a/roles/openLdapClient/tasks/configLdapClient.yml +++ b/roles/openLdapClient/tasks/configLdapClient.yml @@ -43,10 +43,6 @@ template: src=ldap.conf.j2 dest=/etc/openldap/ldap.conf sudo: true -- name: "Copy pam xserver file " - template: src=xserver.j2 dest=/etc/pam.d/xserver - sudo: true - - name: "Add LDAP server IP address to /etc/hosts" lineinfile: dest=/etc/hosts line="{{ ldapServerHostIpLine }}" state=present insertafter=EOF sudo: true diff --git a/roles/setupKnownHosts/templates/known_hosts.j2 b/roles/setupKnownHosts/templates/known_hosts.j2 index c5df8c27755da771d9fc950e19351c48f0f30a2d..aaea3a9de8b331d446960dcb4551575799c909db 100644 --- a/roles/setupKnownHosts/templates/known_hosts.j2 +++ b/roles/setupKnownHosts/templates/known_hosts.j2 @@ -10,6 +10,5 @@ {% endfor %} {% for host in nodelist|unique %} -{{ host.name }} {{ host.rsa }} -{{ host.ip }} {{ host.rsa }} +{{ host.ip }} {{ host.name }} {{ host.rsa }} {% endfor %} diff --git a/roles/slurm-provision/tasks/main.yml b/roles/slurm-provision/tasks/main.yml new file mode 100644 index 0000000000000000000000000000000000000000..4ed1e2c67327e88758d27869cb5e8ed9152aa1fe --- /dev/null +++ b/roles/slurm-provision/tasks/main.yml @@ -0,0 +1,8 @@ +--- +- name: copy slurm provision template + template: src=slurm_provision.sh.j2 dest={{ slurm_provision }} mode=755 owner=root + sudo: true + +- name: slurm cron job + cron: name=slurm-provision job={{ slurm_provision }} user=root minute=*/5 state=present + sudo: true diff --git a/roles/slurm-provision/templates/slurm_provision.sh.j2 b/roles/slurm-provision/templates/slurm_provision.sh.j2 new file mode 100644 index 0000000000000000000000000000000000000000..e1dda7c2196223c255da932fe42d1229ed27a973 --- /dev/null +++ b/roles/slurm-provision/templates/slurm_provision.sh.j2 @@ -0,0 +1,35 @@ +#!/bin/sh + +CVL_HOME="/cvl/home" +user_list=($(getent passwd | cut -d ":" -f1)) +log_file="/root/slurm.log" + +for user in ${user_list[*]}; do + uid=$(id -u ${user}) + gid=$(id -g ${user}) + user_home=${CVL_HOME}/${user} + if [[ ! -d ${user_home} && ${uid} -gt 1000 ]]; then + mkdir -p ${user_home} + cp -r /etc/skel/* ${user_home} + chown -R ${uid}:${gid} ${user_home} + chmod 700 ${user_home} + + account={{ projectname }} + cluster={{ clustername }} + + find=$(sacctmgr list cluster ${cluster} | grep ${cluster}) + if [ -z "${find}" ]; then + su slurm -c "sacctmgr -i add cluster ${cluster}" || { echo "error to create cluster ${cluster}" >> ${log_file} && exit 1; } + fi + find=$(sacctmgr list account ${account} | grep ${account}) + if [ -z "${find}" ]; then + su slurm -c "sacctmgr -i add account ${account} Description=CVL Organization=monash cluster=${cluster}" || { echo "error to create account ${account}" >> ${log_file} && exit 1; } + fi + find=$(sacctmgr list user ${username} | grep ${username}) + if [ -z "${find}" ]; then + su slurm -c "sacctmgr -i add user ${username} account=${account} cluster=${cluster}" || { echo "error to create user ${username}" >> ${log_file} && exit 1; } + fi + fi +done + + diff --git a/roles/slurm-provision/templates/slurm_provision.sh.j2.v1 b/roles/slurm-provision/templates/slurm_provision.sh.j2.v1 new file mode 100644 index 0000000000000000000000000000000000000000..2b8bf1f1c16509d40d208c1ba616c4400e13fc55 --- /dev/null +++ b/roles/slurm-provision/templates/slurm_provision.sh.j2.v1 @@ -0,0 +1,34 @@ +#!/bin/sh + +CVL_HOME="/cvl/home" +user_list=($(getent passwd | cut -d ":" -f1)) +log_file="/root/slurm.log" + +for user in ${user_list[*]}; do + uid=$(id -u ${user}) + gid=$(id -g ${user}) + user_home=${CVL_HOME}/${user} + if [ ! -d ${user_home} ]; then + mkdir -p ${user_home} + cp -r /etc/skel/* ${user_home} + chown -R ${uid}:${gid} ${user_home} + chmod 700 ${user_home} + + account={{ projectname }} + cluster={{ clustername }} + find=$(sacctmgr list cluster ${cluster} | grep ${cluster}) + if [ -z "${find}" ]; then + su slurm -c "sacctmgr -i add cluster ${cluster}" || { echo "error to create cluster ${cluster}" >> ${log_file} && exit 1; } + fi + find=$(sacctmgr list account ${account} | grep ${account}) + if [ -z "${find}" ]; then + su slurm -c "sacctmgr -i add account ${account} Description=CVL Organization=monash cluster=${cluster}" || { echo "error to create account ${account}" >> ${log_file} && exit 1; } + fi + find=$(sacctmgr list user ${username} | grep ${username}) + if [ -z "${find}" ]; then + su slurm -c "sacctmgr -i add user ${username} account=${account} cluster=${cluster}" || { echo "error to create user ${username}" >> ${log_file} && exit 1; } + fi + fi +done + + diff --git a/roles/slurm-provision/vars/readme.txt b/roles/slurm-provision/vars/readme.txt new file mode 100644 index 0000000000000000000000000000000000000000..5c0294c54811c2bc37e62769496f9d2d3bca4c5e --- /dev/null +++ b/roles/slurm-provision/vars/readme.txt @@ -0,0 +1 @@ +slurm_provision: "/usr/local/sbin/slurmu_provision.sh"