欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

ubuntu创建用户+文件读写权限+新用户添加到组

程序员文章站 2021-11-26 20:03:49
...

一、 ubuntu 增加一个用户 并赋予权限

ubuntu 增加一个用户 并赋予权限

1. 添加一个用户

#添加一个test的用户
 sudo adduser test 
 
#修改密码 回车后出现一下提示 输入密码即可
 sudo passwd test
#Changing password for user test.

#在这里输入新密码
New UNIX password:  

#再次输入新密码   
Retype new UNIX password:  
#passwd: all authentication tokens updated successfully.

2.ssh远程时,出现只有$的情况

$ cd    
$ ls
  • 原因

查看/etc/passwd文件后发现,新建的用户未指定shell。我们只需将其指定为/bin/bash即可。

  • 解决方法:

切换至root用户
使用usermod命令修改shell类型

sudo usermod -s /bin/bash tommy

3. 新用户下没有人root 权限 即执行不了sudo 命令

  • 切换到root用户下,即创建新用户的用户下

  • 添加sudo文件的写权限,命令是:

sudo chmod u+w /etc/sudoers
  • 编辑sudoers文件
vi /etc/sudoers

找到这行 root ALL=(ALL) ALL,在他下面添加xxx ALL=(ALL) ALL (这里的xxx是你的用户名 如test)

ps:这里说下你可以sudoers添加下面四行中任意一条

youuser            ALL=(ALL)                ALL
%youuser           ALL=(ALL)                ALL
youuser            ALL=(ALL)                NOPASSWD: ALL
%youuser           ALL=(ALL)                NOPASSWD: ALL

第一行:允许用户youuser执行sudo命令(需要输入密码).
第二行:允许用户组youuser里面的用户执行sudo命令(需要输入密码).
第三行:允许用户youuser执行sudo命令,并且在执行的时候不输入密码.
第四行:允许用户组youuser里面的用户执行sudo命令,并且在执行的时候不输入密码.

4.撤销sudoers文件写权限,命令:

sudo chmod u-w /etc/sudoers

这样普通用户就可以使用sudo了

二、文件读写权限

Ubuntu 文件文件夹查看权限和设置权限
ubuntu下查看权限的命令为:

ls -l filename

ls -ld folder

ubuntu下设置权限的命令为:

一共有10位数

其中: 最前面那个 - 代表的是类型

中间那三个 rw- 代表的是所有者(user)

然后那三个 rw- 代表的是组群(group)

最后那三个 r-- 代表的是其他人(other)

然后我再解释一下后面那9位数:

r 表示文件可以被读(read)

w 表示文件可以被写(write)

x 表示文件可以被执行(如果它是程序的话)

  • 表示相应的权限还没有被授予

现在该说说修改文件权限了

在终端输入:

chmod o+w xxx.xxx

表示给其他人授予写xxx.xxx这个文件的权限

chmod go-rw xxx.xxx

表示删除xxx.xxx中组群和其他人的读和写的权限

其中:

u 代表所有者(user)

g 代表所有者所在的组群(group)

o 代表其他人,但不是u和g (other)

a 代表全部的人,也就是包括u,g和o

r 表示文件可以被读(read)

w 表示文件可以被写(write)

x 表示文件可以被执行(如果它是程序的话)

其中:rwx也可以用数字来代替

r ------------4

w -----------2

x ------------1

  • ------------0

行动:

  • 表示添加权限
  • 表示删除权限

= 表示使之成为唯一的权限

当大家都明白了上面的东西之后,那么我们常见的以下的一些权限就很容易都明白了:

-rw------- (600) 只有所有者才有读和写的权限

-rw-r–r-- (644) 只有所有者才有读和写的权限,组群和其他人只有读的权限

-rwx------ (700) 只有所有者才有读,写,执行的权限

-rwxr-xr-x (755) 只有所有者才有读,写,执行的权限,组群和其他人只有读和执行的权限

-rwx–x--x (711) 只有所有者才有读,写,执行的权限,组群和其他人只有执行的权限

-rw-rw-rw- (666) 每个人都有读写的权限

-rwxrwxrwx (777) 每个人都有读写和执行的权限

sudo chmod 600 ××× (只有所有者有读和写的权限)

sudo chmod 644 ××× (所有者有读和写的权限,组用户只有读的权限)

sudo chmod 700 ××× (只有所有者有读和写以及执行的权限)

sudo chmod 666 ××× (每个人都有读和写的权限)

sudo chmod 777 ××× (每个人都有读和写以及执行的权限)

若分配给某个文件所有权限,则利用下面的命令:

sudo chmod -R 777 文件或文件夹的名字(其中sudo是管理员权限)

三、把新建的用户test加入 admin组中

输入以下命令以查看当前用户属于哪个组:

groups

输入以下命令以检查特定用户属于哪个组:

groups [username]

usermod 示例 – 将一个已有用户增加到一个已有用户组中
将一个已有用户 centos 增加到一个已有用户组 apache 中,使此用户组成为该用户的附加用户组,可以使用带 -a 参数的 usermod 指令。-a 代表 append, 也就是将用户添加到新用户组中而不必离开原有的其他用户组。不过需要与 -G 选项配合使用:

usermod -a -G apache centos

会显示出:正在将用户“test”加入到“admin”组中

参考文章:

ubuntu 增加一个用户 并赋予权限
Ubuntu 文件文件夹查看权限和设置权限