无法使用 usermod 将组附加到用户组
Posted
技术标签:
【中文标题】无法使用 usermod 将组附加到用户组【英文标题】:Unable to append group to user gropus with usermod 【发布时间】:2021-03-26 21:30:45 【问题描述】:我创建了名为 support 的组来管理对一些应该以 sudo 运行的脚本的访问。所以我创建了组并验证,如果组存在于 /etc/group:
# groupadd support
# cat /etc/group | grep support
support:x:1002:
然后,我想给 user1 添加组:
# usermod –a –G support user1; echo $?
Usage: usermod [options] LOGIN
...
<usermod help page>
...
2
命令返回代码2,没有出现错误信息。我想,问题可能出在组 support 所以我尝试将 user1 添加到组 sudo (仅用于测试)并且问题仍然存在。我做错了什么还是我错过了什么?无法弄清楚问题可能出在哪里。谢谢
操作系统:Kubuntu 20.04 LTS(5.4.0-58-generic)
BASH:GNU bash,版本 5.0.17(1)-release (x86_64-pc-linux-gnu)
【问题讨论】:
你试过 sudo useradd ... 是的。我以 root 身份登录,这就是为什么在我的命令前面有#
而不是 $
。
【参考方案1】:
您的“-”字符不正确。也许您从某个地方复制并粘贴了它,或者您使用的是非标准键盘。 看看你的命令 hex-dump:
echo 'usermod –a –G support user1' | hd
00000000 75 73 65 72 6d 6f 64 20 e2 80 93 61 20 e2 80 93 |usermod ...a ...|
00000010 47 20 73 75 70 70 6f 72 74 20 75 73 65 72 31 0a |G support user1.|
00000020
但正确的是:
echo 'usermod -a -G support user1' | hd
00000000 75 73 65 72 6d 6f 64 20 2d 61 20 2d 47 20 73 75 |usermod -a -G su|
00000010 70 70 6f 72 74 20 75 73 65 72 31 0a |pport user1.|
0000001c
注意第二个十六进制中的 -
字符并将其与您的比较
【讨论】:
天啊,没注意到。我刚刚从我之前写的文档中复制了一些命令,这发生了。谢谢!以上是关于无法使用 usermod 将组附加到用户组的主要内容,如果未能解决你的问题,请参考以下文章