所以我在这种情况下,我们已经开始添加一堆新服务器,因为我们正在获得新客户端,因此,我们需要为我们获得的每个新客户端新服务器,然后需要在这些服务器上创建具有特权的用户和所有这些东西。所以我在每台新服务器上基本上需要做的是以下步骤:
sudo adduser John
sudo usermod -aG sudo John
sudo su John
cd /home/John
mkdir .ssh
chmod 700 .ssh/
touch .ssh/authorized_keys
chmod 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
就可以了,因为他们无论如何都需要更改密码。
甚至可以用脚本来做和/或不建议这样做。
编辑 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
的不工作......?
抱歉,我几天前想出了一个解决方案,这是我的解决方案:
当然,这需要我在每台服务器上创建一个新脚本,但仍然比为 5 个用户手动运行所有这些命令要快得多。所以我在每台服务器上做的是:
touch create_users.sh
chmod +x create_users.sh
vi create_users.sh
并在“脚本代码”中过去./create_users.sh john joe jill
然后我会提示每个用户输入密码,然后我只需为每个用户创建一个简单的密码并让他们尽快更改它。
adduser --> usermod --> mkdir etc.
这对我有用,比为每个用户手动运行要快得多。所以现在我坚持这个。随意发布您的解决方案,如果有的话,我希望看到其他方法,特别是因为我对脚本编写和使用 ubuntu 服务器非常陌生。