所持している複数サーバに一括して新たなユーザーアカウントの作成とパスワードの設定を行うBシェルを作成したいです。
アドバイスお願いいたします。
OSはcentos7です。
======================================================================================================
現在自分でシェルスクリプトを組んでみたのですが2点で躓いています。宜しければアドバイスお願いします。
1 ファイル内を1行づつ読み込むシェルを作成したつもりが一度に読み込まれている為、単体のノードの設定の場合は問題なく処理できているが
複数ノードを一気に設定しようとした所失敗してしまう
2 既定のパスワードで記号(>や\など)が入ってしまっているノードに対しては単体の設定でもキチンとパスワードが入力されずssh接続が出来ない
=======================================================================================================
#!/bin/bash
アカウント作成対象サーバでの設定ファイルの配置パス
FILE_U='/tmp/addusers.txt'
アカウント作成対象サーバのパスワードファイルのパス
FILE_P='/etc/passwd'
アカウント作成対象サーバのrootユーザのパスワードを記載するファイルパス
TEXT='/usr/local/tools/adduser/pass.txt'
データを読み込ませるための変数
LIST=cat $TEXT
while read line
do
アカウント作成対象サーバのIPを取り出す変数
IP=cat $TEXT | awk '{print $1}'
echo 'IP='"${IP}" >> /usr/local/tools/adduser/log.txt
アカウント作成対象サーバのパスワードを取り出す変数
PASSWORD=cat $TEXT | awk '{print $2}'
echo 'PASSWORD='"${PASSWORD}" >> /usr/local/tools/adduser/log.txt
#記号入りのパスワードを文字列として認識させるための変数
PASS=printf %q "$PASSWORD"
echo 'PASS='"${PASS}" >> /usr/local/tools/adduser/log.txt
アカウント作成対象サーバへ設定ファイルを移送する
sshpass -p "$PASS" scp -o "StrictHostKeyChecking=no" /usr/local/tools/adduser/addusers.txt root@$IP:/tmp
アカウント作成対象サーバで設定ファイルに記載のあるユーザー作成を実施する
sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP newusers $FILE_U
作成されたhomeディレクトリ配下のディレクトリにデフォルトの構成内容を配置する
for line in `sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP cat $FILE_U` do user_name=`sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP echo $line | cut -d ':' -f 1` txt=`sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP cat $FILE_P | grep -e "^$user_name"` user_id=`sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP echo $txt | cut -d ':' -f 3` group_id=`sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP echo $txt | cut -d ':' -f 4` home_dir=`sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP echo $txt | cut -d ':' -f 6` sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP echo "USER_ID:${user_id} GROUP:${group_id} HOME_DIR:$home_dir" sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP cp -rf /etc/skel/. $home_dir/ sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP chown -R $user_id $home_dir sshpass -p "$PASS" ssh -o "StrictHostKeyChecking=no" root@$IP chgrp -R $group_id $home_dir done
done << FILE
$LIST
FILE
※addusers.txtの中身
test1❌:::/home/test1:/bin/bash
※pass.txtの中身
ノードIP パスワード
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/07/09 01:40
2018/07/09 03:57
2018/07/11 06:41