首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在新服务器上创建用户的脚本

在新服务器上创建用户的脚本
EN

Ask Ubuntu用户
提问于 2018-11-30 13:54:09
回答 1查看 1.9K关注 0票数 1

在这种情况下,我们已经开始添加一批新的服务器,因为我们正在获得新的客户端,因此,我们需要为我们获得的每一个新客户端提供新的服务器,然后我们需要在这些服务器上创建具有特权和其他所有内容的用户。因此,我基本上需要在每台新服务器上执行以下步骤:

  1. sudo adduser John
  2. sudo usermod -aG sudo John
  3. sudo su John
  4. cd /home/John
  5. mkdir .ssh
  6. chmod 700 .ssh/
  7. touch .ssh/authorized_keys
  8. chmod 600 .ssh/authorized_keys

当您必须在每个服务器上创建4-5个用户时,这是非常乏味的。我现在正在做的是创建一个脚本,它使用一个简单的命令为我执行所有这些步骤

./create_users.sh John Jim Jill Peter

因此,到目前为止,我得到的是:

代码语言:javascript
复制
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的步骤--它似乎不起作用--我得到了以下错误:

代码语言:javascript
复制
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不能工作.?

EN

回答 1

Ask Ubuntu用户

回答已采纳

发布于 2018-12-04 12:03:45

抱歉,几天前我想出了一个解决方案,下面是我的解决方案:

代码语言:javascript
复制
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个用户手动运行所有这些命令要快得多。因此,我在每个服务器上所做的是:

  1. touch create_users.sh
  2. chmod +x create_users.sh
  3. vi create_users.sh与“脚本代码”中的过去
  4. 最后,我运行./create_users.sh john joe jill

然后提示每个用户输入一个密码,然后为每个用户创建一个简单的密码,让他们尽快更改密码。这对我来说是有效的,而且比手动运行每个用户的adduser --> usermod --> mkdir etc.要快得多。所以现在我坚持这个。

可以随意发布您的解决方案(如果有的话),我希望看到其他方法,特别是因为我对脚本编写和使用ubuntu服务器非常陌生。

票数 1
EN
页面原文内容由Ask Ubuntu提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://askubuntu.com/questions/1097420

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档