在这种情况下,我们已经开始添加一批新的服务器,因为我们正在获得新的客户端,因此,我们需要为我们获得的每一个新客户端提供新的服务器,然后我们需要在这些服务器上创建具有特权和其他所有内容的用户。因此,我基本上需要在每台新服务器上执行以下步骤:
sudo adduser Johnsudo usermod -aG sudo Johnsudo su Johncd /home/Johnmkdir .sshchmod 700 .ssh/touch .ssh/authorized_keyschmod 600 .ssh/authorized_keys当您必须在每个服务器上创建4-5个用户时,这是非常乏味的。我现在正在做的是创建一个脚本,它使用一个简单的命令为我执行所有这些步骤
./create_users.sh John Jim Jill Peter
因此,到目前为止,我得到的是:
for i in "$@"; do
echo creating user: "$i"
sudo adduser $i
echo add user to sudo group
sudo usermod -aG sudo $i
echo creating ssh folder and authorized_keys
sudo su $i
cd /home/$i
mkdir .ssh
chmod 700 .ssh/
touch .ssh/authorized_keys
chmod 600 .ssh/authorized_keys
done我还没有试过它,但我知道它不会工作,因为我必须为每个用户传递一个密码。所以我的问题是我该怎么做?现在,只要设置一些标准密码(比如1Password )就可以了,因为他们无论如何都需要更改密码。
是否可以使用脚本和/或不建议这样做。
EDIT 1
啊,好吧,如果我运行这个程序,我实际上会被提示为每个用户设置密码,现在我遇到麻烦的唯一一件事似乎是“非常好”,那就是我cd /home/$i的步骤--它似乎不起作用--我得到了以下错误:
mkdir: cannot create directory ‘.ssh’: Permission denied
chmod: cannot access '.ssh/': No such file or directory
touch: cannot touch '.ssh/authorized_keys': No such file or directory
chmod: cannot access '.ssh/authorized_keys': No such file or directory这是有意义的,因为我不在正确的目录中。所以我不明白为什么我的cd /home/$i不能工作.?
发布于 2018-12-04 12:03:45
抱歉,几天前我想出了一个解决方案,下面是我的解决方案:
for i in "$@"; do
echo creating user: "$i"
sudo adduser $i
echo add user to sudo group
sudo usermod -aG sudo $i
echo creating ssh folder and authorized_keys
sudo -H -u $i bash -c 'mkdir -p /home/"$0"/.ssh' $i
sudo -H -u $i bash -c 'chmod 700 /home/"$0"/.ssh/' $i
sudo -H -u $i bash -c 'touch /home/"$0"/.ssh/authorized_keys' $i
sudo -H -u $i bash -c 'chmod 600 /home/"$0"/.ssh/authorized_keys' $i
done当然,这要求我在每台服务器上创建一个新脚本,但仍然比为5个用户手动运行所有这些命令要快得多。因此,我在每个服务器上所做的是:
touch create_users.shchmod +x create_users.shvi create_users.sh与“脚本代码”中的过去./create_users.sh john joe jill然后提示每个用户输入一个密码,然后为每个用户创建一个简单的密码,让他们尽快更改密码。这对我来说是有效的,而且比手动运行每个用户的adduser --> usermod --> mkdir etc.要快得多。所以现在我坚持这个。
可以随意发布您的解决方案(如果有的话),我希望看到其他方法,特别是因为我对脚本编写和使用ubuntu服务器非常陌生。
https://askubuntu.com/questions/1097420
复制相似问题