ubuntu用户知识
Linux 是个多用户多任务的分时操作系统,所有想要调用系统资源的用户都必须先向系统管理员申请一个账号,然后通过这个账号进入系统。用户的账号一方面能帮助系统管理员对使用系统的用户进行跟踪,控制他们对系统资源的访问;另一方面也能帮助用户组织文件,为用户提供安全性保护。每个账号都拥有一个唯一的用户名和用户密码。用户在登录时键入正确的用户名和密码后,才能进入系统和自己的主目录。
1.用户与用户组间的联系:
一对一
:一个用户可以存在于一个用户组中,也可以是组中的唯一成员。
一对多
:一个用户可以存在于多个用户组中,那么此用户具有多个组的共同权限。
多对一
:多个用户可以存在于一个用户组中,这些用户具有和组相同的权限。
多对多
:多个用户可以存在于多个用户组中,其实就是上面三个对应关系的扩展。
tina@tina-G3-3590 ~ cat /etc/passwd
root:x:0:0:root:/root:/bin/zsh
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
sync:x:4:65534:sync:/bin:/bin/sync
......
tina:x:1000:1000:tina,,,:/home/tina:/usr/bin/zsh
nvidia-persistenced:x:121:129:NVIDIA Persistence Daemon,,,:/:/sbin/nologin
文件中每行记录用冒号 :
分隔为 7 个字段,从左到右具体含义是:
用户名:密码占位符(x 表示用户需要密码登录):用户标识号(
UID
):
组标识号(GID
):注释性描述:主目录:登录的shell
2.useradd 创建用户
useradd [-d home] [-s shell] [-c comment] [-m [-k template]] [-f inactive] [-e expire ] [-p passwd] [-r] name
3.主要参数
-c:加上备注文字,备注文字保存在passwd的备注栏中。
-d:指定用户登入时的启始目录。
-D:变更预设值。
-e:指定账号的有效期限,缺省表示永久有效。
-f:指定在密码过期后多少天即关闭该账号。
-g:指定用户所属的群组。
-G:指定用户所属的附加群组。
-m:自动建立用户的登入目录。
-M:不要自动建立用户的登入目录。
-n:取消建立以用户名称为名的群组。
-r:建立系统账号。
-s:指定用户登入后所使用的shell。
-u:指定用户ID号。
useradd -h
命令可查看帮助信息
选项 | 说明 |
---|---|
-c | 指定一段注释性描述 |
-d | 指定用户主目录 |
-md | 如果指定的用户主目录不存在,则用此选项来创建目录并指定为主目录 |
-g | 指定用户所属的主用户组 |
-G | 指定用户所属的附加用户组 |
-s | 指定用户的登录 shell |
-u | 指定用户的用户号,若有 -o 选项,则可以重复使用其它用户的标识号 |
mcdx@ubuntu:~$ sudo useradd -md /home/haha -s /bin/bash -G mcdx haha
mcdx@ubuntu:~$ ls /home/ # 查看用户主目录
haha mcdx
mcdx@ubuntu:~$ tail -3 /etc/passwd # 查看用户信息
mongodb:x:122:65534::/home/mongodb:/bin/false
redis:x:123:131::/var/lib/redis:/bin/false
haha:x:1001:1001::/home/haha:/bin/bash
mcdx@ubuntu:~$ groups haha # 查看用户属于哪些组
haha : haha mcdx # 用户 : 主组 附加组
mcdx@ubuntu:~$ id haha # 也是查看用户信息
uid=1001(haha) gid=1001(haha) 组=1001(haha),1000(mcdx)
3、usermod
修改用户信息
常用的选项跟 useradd
差不多,参见 usermod -h
4、userdel
删除用户
-r
选项顺便删除主目录
sudo userdel haha
ubuntu环境变量知识
/etc/profile —— 此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行.并从/etc/profile.d目录的配置文件中搜集shell的设置;
/etc/environment —— 在登录时操作系统使用的第二个文件,系统在读取你自己的profile前,设置环境文件的环境变量;
/etc/bashrc —— 为每一个运行bash shell的用户执行此文件.当bash shell被打开时,该文件被读取;
~/.profile —— 每个用户都可使用该文件输入专用于自己使用的shell信息,当用户登录时,该文件仅仅执行一次!默认情况下,它设置一些环境变量,执行用户的.bashrc文件;
方法一:直接修改/etc/enviroment文件,这种方法的作用域是全局的,永久性的。
打开/etc/environment文件,其内容如下:PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games"
在环境变量PATH中添加你要添加的路径即可。
方法二:修改/etc/profile文件,这种方法的作用域是全局的,永久性的。
这个文件不是保存环境变量信息的文件,在登录时,系统只是根据它的内容对环境变量进行设置。
export PATH=
P
A
T
H
:
[
y
o
u
r
p
a
t
h
1
]
:
[
y
o
u
r
p
a
t
h
2
]
:
[
.
.
.
]
e
x
p
o
r
t
P
A
T
H
=
[
y
o
u
r
p
a
t
h
1
]
:
[
y
o
u
r
p
a
t
h
2
]
:
[
.
.
.
]
:
PATH:[your path1]:[your path2]:[...] export PATH=[your path1]:[your path2]:[...]:
PATH:[yourpath1]:[yourpath2]:[...]exportPATH=[yourpath1]:[yourpath2]:[...]:PATH
其中,各个PATH之间用冒号分隔,$PATH指代添加your path前的环境变量。我感觉这是计算机中一个特有的定义方式,就像 i = i + 1一样。
方法三:修改/etc/bashrc或者~/.bashrc文件
这两个文件同样不是为了保存环境变量,只是在使用bash shell时进行设置而已,所以设置方法和二中一样:
[plain] view plain copy
export PATH=
P
A
T
H
:
[
y
o
u
r
p
a
t
h
1
]
:
[
y
o
u
r
p
a
t
h
2
]
:
[
.
.
.
]
e
x
p
o
r
t
P
A
T
H
=
[
y
o
u
r
p
a
t
h
1
]
:
[
y
o
u
r
p
a
t
h
2
]
:
[
.
.
.
]
:
PATH:[your path1]:[your path2]:[...] export PATH=[your path1]:[your path2]:[...]:
PATH:[yourpath1]:[yourpath2]:[...]exportPATH=[yourpath1]:[yourpath2]:[...]:PATH
对于/etc/bashrc文件,修改的作用于所以用户,但对于~/.bashrc文件,修改的仅仅作用于当前用户。这种修改的作用也是永久性的。
方法四:修改~/.profile文件
这种方法和修改/etc/profile本质上是一样的,这种之不过是仅仅修改了当前用户自己的配置文件。所以作用仅限于当前用户,但同样也是永久性的。
方法五:在Terminal中使用shell命令
export PATH=
P
A
T
H
:
[
y
o
u
r
p
a
t
h
1
]
:
[
y
o
u
r
p
a
t
h
2
]
:
[
.
.
.
]
e
x
p
o
r
t
P
A
T
H
=
[
y
o
u
r
p
a
t
h
1
]
:
[
y
o
u
r
p
a
t
h
2
]
:
[
.
.
.
]
:
PATH:[your path1]:[your path2]:[...] export PATH=[your path1]:[your path2]:[...]:
PATH:[yourpath1]:[yourpath2]:[...]exportPATH=[yourpath1]:[yourpath2]:[...]:PATH
这种方法是暂时的关闭终端这个设置也就失效了,而且作用仅仅限于当前终端,其他终端中这个设置不会启作用。
在设置成功后,可以使用命令查看设置的环境变量。
env //打印所有的环境变量
echo $PATH //打印PATH环境变量
这时我们就可以在PATH变量后看到相关的修改了。在以上前四种方法中,修改后不会设置立即生效(大家思考一下原因),需要重启或者重新登录(哪个需要重启,哪个需要重新登录?),当然使用source命令也可以。使用方法为:
source [file name] //不要忘记路径,或者执行时要在文件路径下