Linux学习笔记之超详细基础linux命令

by:授客 QQ1033553122

---------------------------------接Part 5------------------------------

删除口令

例子:删除tom用户的口令

[root@localhost ~]# passwd -d tom

清除用户的密码 tom。

passwd: 操作成功

[root@localhost ~]# cat /etc/shadow

...

tom::15659:0:99999:7:::

...

说明:超级用户删除用户口令,删除用户口令后,用户不需要口令即可登录,查看/etc/shadow文件,用户口令字段为空,修改密码文件也是删除密码的一种方式

锁定和解锁用户帐号

例子:锁定tom用户账户

[root@localhost ~]# passwd -l tom

锁定用户 tom 的密码 。

passwd: 操作成功

注:超级用户也可直接编辑/etc/passwd文件。在指定的用户帐号所在行前面加上“#”或“*”符号,使其成为注释。即锁定该用户帐号。

反之去除注释符则解锁帐号。

例子:锁定tom用户账户

[root@localhost ~]# passwd -u tom

解锁用户 tom 的密码 。

passwd: 警告:未锁定的密码将是空的。

passwd: 不安全的操作(使用 -f 参数强制进行该操作)

显示用户帐号的状态

例子:查看tom用户帐号的当前状态

[root@localhost ~]# passwd -S tom

tom LK 2012-11-15 0 99999 7 -1 (密码已被锁定。)

[root@localhost ~]# passwd tom

更改用户 tom 的密码 。

新的 密码:

无效的密码: 它基于字典单词

无效的密码: 过于简单

重新输入新的 密码:

passwd: 所有的身份验证令牌已经成功更新。

[root@localhost ~]# passwd -S tom

tom PS 2012-11-15 0 99999 7 -1 (密码已设置,使用 SHA512 加密。)

注:字母S必须大写

超级用户可以查看用户帐号的状态,如果提示“Passwd locked”则表示此用户帐号被锁定,没密码的用户将被锁定。

usermod命令

方法:usermod
[选项]

用户名

功能:修改用户的属性,只有超级用户才能使用该命令

主要选项:

-c(comment)

全名

指定用户的全称

-d(directory)

主目录

指定用户的主目录

-e(expire)

有效期限
指定用户账号的有效期限

-f

缓冲天数

指定口令过期多少天后将关闭此账号

-g

组群ID|组群名

指定用户所属的主要组群

-G

组群ID|组群名

指定用户所属的附加组群

-s(Shell)

登陆Shell

指定用户登陆后启动的Shell类型

-u(user)

用户UID

指定用户的UID

-l

用户名

指定用户的新名称

例子:将tom用户名改为tommy

[root@localhost ~]# usermod
-l tommy tom

[root@localhost ~]# cat
/etc/passwd

...

tommy:x:501:501::/home/tom:/bin/bash

注:执行usermod命令将修改/etc/passwd文件中指定用户名的信息。

userdel命令

方法:userdel [-r]

用户名

说明:删除指定的用户账号,只有超级用户才可以使用该命令

主要选项:

-r

删除用户账号的同时将用户的主目录也一并删除,如果不指定则只删除用户

正在使用系统的用户不能被删除,必须先终止该用户所有的进程才能删除用户

例子:删除tommy用户账号及主目录

[root@localhost ~]# userdel
-r tommy

su命令

方法:su
[-] [用户名]

功能:切换用户身份,超级用户可以切换为任何普通用户,而且不要输入口令。普通用户转为其他用户时需要输入被转换用户的口令,使用exit返回到原来的用户身份

主要选项:

-

如果使用-选项,则用户切换为新用户的同时使用新用户的环境变量。当不指定用户名时,默认为从普通用户转为超级用户。

例子:普通用户laiyu切换为超级用户,并使用超级用户的环境变量

[laiyu@localhost ~]$
pwd

/home/laiyu

[laiyu@localhost ~]$ su
-

Password:

[root@localhost ~]#
pwd

/root

[root@localhost ~]#
exit

logout

[laiyu@localhost
~]$

说明:为保系统安全,当必要时才切换为超级用户,执行完后使用“exit”命令退回到普通用户身份。

例子:普通用户laiyu切换为jerry

[laiyu@localhost ~]$ su
jerry

Password:

[jerry@localhost laiyu]$
pwd

/home/laiyu

说明:没使用“-”选项,所以当前工作目录仍然为/home/laiyu没变化。

id命令

方法:id
[用户名]

功能:查看用户的UID,GID和用户所属组群的信息。如果不指定用户,则显示当前用户的相关信息

例子:查看用户jerry的用户信息

[jerry@localhost laiyu]$
id

uid=502(jerry)
gid=503(helen) groups=503(helen)
context=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023

[jerry@localhost laiyu]$
exit

exit

[laiyu@localhost ~]$ id
jerry

uid=502(jerry)
gid=503(helen) groups=503(helen)

管理组群的Shell命令

groupadd命令

格式:groupadd
[选项]

组群名

功能:新建组群,只有超级用户才能使用此命令

主要选项:-g
组群ID
指定组群的GID

例:新建一名为helen的组群

[root@localhost ~]#
groupadd helen

[root@localhost ~]# cat
/etc/group

...

helen:x:503:

[root@localhost ~]# cat
/etc/gshadow

...

helen:!::

说明:如果不指定群组ID,其GID由系统指定,groupadd的执行结果将在/etc/group和/etc/gshdow文件中增加一行记录,“!”表示组群没设置口令

groupmod命令

方法:groupmod
[选项]

组群名

功能:修改指定组群的属性,只有超级用户才能使用此命令

主要选项:

-g

组群id

指定组群的GID

-n

组群名

指定组群的新名字

例子:改变组群helen名为jerry

[root@localhost laiyu]#
groupmod -n jerry helen

[root@localhost laiyu]#
id

uid=0(root)
gid=0(root)
组=0(root)

环境=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023

[root@localhost laiyu]# id
jerry

uid=502(jerry)
gid=503(jerry)
组=503(jerry)

groupdel命令

方法:groupdel

组群名

功能:删除指定的组群。只有超级用户才能使用此命令,在删除指定组群之前必须保证该组群不是任何用户的主要主群,否则要先删除那些以此组群为主

要组群的用户才能删除这个组群

[root@localhost laiyu]#
groupdel jerry

groupdel: cannot remove the
primary group of user 'jerry'

[root@localhost laiyu]#
userdel -r jerry

[root@localhost laiyu]#
groupdel jerry

groupdel: group 'jerry'
does not exist

批量新建多个用户帐号

例:假设为新入学的08级学生添加为RHEL
Server 5计算机的新用户,每个学生帐号的用户名为“s”+学号的组合。他们都属于一个组群08students。

第一:创建共用组群08students

[root@localhost ~]#
groupadd -g 600 08students

为方便后续步骤,指定组群的GID为600

第二:编辑用户信息文件。

新建student.txt文件,严格按/etc/passwd文件的格式输入每个用户的用户名,UID,口令“x”,全名,主目录,登录Shell等等信息

s080101:x:601:600::/home/s080101:/bin/bash

s080102:x:602:600::/home/s080101:/bin/bash

s080103:x:603:600::/home/s080101:/bin/bash

s080104:x:604:600::/home/s080101:/bin/bash

s080105:x:605:600::/home/s080101:/bin/bash

s080106:x:606:600::/home/s080101:/bin/bash

s080107:x:607:600::/home/s080101:/bin/bash

...

第三:创建用户口令文件

新建password.txt文件,根据上述帐号信息,严格按照/etc/shadow文件的格式输入用户信息。

s080101:knei9e

s080102:kdn7i3n

s080103:kdnd3df

s080104:kdn89n3

s080105:88997dn

s080106:kdnnkdkd8

s080107:kdkdkd7

...

第四:利用newusers命令批量创建用户帐号

[root@localhost ~]#
newusers < students.txt

如果没出先任何错误信息,那么查看/etc/passwd文件将发现sutdents.txt文件的内容出现在/etc/passwd文件中。系统还在/home目录下为每一个用户创建

主目录。

第五:利用命令pwunconv暂时取消shadow加密

[root@localhost ~]#
pwunconv

注:为了用户口令文件中指定的口令可用,必先取消原有shadow加密。超级用户利用pwunconv命令将/etc/shadow文件中加密口令解密后保存

在/etc/passwd文件。并删除/etc/shadow文件。

第六:利用chpasswd命令为用户设置口令

[root@localhost ~]#
chpasswd < password.txt

执行成功后,查看/etc/passwd文件,会看到password.txt中的口令均出现在/etc/passwd文件中相应的口令字段。

第7:利用pwconv命令恢复加密

[root@localhost ~]#
pwconv

注:以批量新建的用户名登录时会发现命令提示符不太一样,如下所示,,如果需要使用默认的命令提示符号,可复制独立创建的用户如(tom)的用户主目

录中的设置文件.bash_profile和.bahsrc到对应目录下。如:cp
/home/tom/.bash_profile /home/s080101

[root@localhost ~]# su
s080101

bash-4.1$

Linux 学习笔记之超详细基础linux命令 Part 6的更多相关文章

  1. Linux 学习笔记之超详细基础linux命令(the end)

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 14---------------- ...

  2. Linux 学习笔记之超详细基础linux命令 Part 14

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 13---------------- ...

  3. Linux 学习笔记之超详细基础linux命令 Part 13

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 12---------------- ...

  4. Linux 学习笔记之超详细基础linux命令 Part 12

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 11---------------- ...

  5. Linux 学习笔记之超详细基础linux命令 Part 11

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 10---------------- ...

  6. Linux 学习笔记之超详细基础linux命令 Part 10

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 9----------------- ...

  7. Linux 学习笔记之超详细基础linux命令 Part 9

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 8----------------- ...

  8. Linux 学习笔记之超详细基础linux命令 Part 8

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 7----------------- ...

  9. Linux 学习笔记之超详细基础linux命令 Part 7

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 6----------------- ...

随机推荐

  1. ElasticSearch核心知识总结(二)

    如何超出扩容极限,以及如何提升容错性 primary&replica自动负载均衡,6个shared,3个primary,3个replica,随着机器扩容,会被均衡分配到多台机器上 6个shar ...

  2. HoloLens开发手记-开发概述Development overview

    开发HoloLens全息应用将使用UWP平台(Universal Windows Platform),所有的HoloLens应用都是Win10通用应用,所有UWP通用应用都可以在HoloLens上运行 ...

  3. iOS-实现后台长时间运行

    前言 一般APP在按下Home键被挂起后,这时APP的 backgroundTimeRemaining 也就是后台运行时间大约只有3分钟,如果在退出APP后,过十几二十二分钟或者更长时间再回到APP, ...

  4. app操作的一些命令

    这里的操作都是在windows下,在android SDK安装好之后就可以连接实体手机或者模拟器操作 1.查看连接的手机或者模拟器 adb devices 结果如下: 2.查看某个app的包名和act ...

  5. 课程四(Convolutional Neural Networks),第一周(Foundations of Convolutional Neural Networks) —— 1.Practice questions:The basics of ConvNets

    [解释] 100*(300*300*3)+ 100=27000100 [解释] (5*5*3+1)*100=7600 [中文翻译] 您有一个输入是 63x63x16, 并 将他与32个滤波器卷积, 每 ...

  6. 从零开始学 Web 之 JavaScript 高级(一)原型,贪吃蛇案例

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...

  7. HDFS-Architecture剖析

    1.概述 从HDFS的应用层面来看,我们可以非常容易的使用其API来操作HDFS,实现目录的创建.删除,文件的上传下载.删除.追加(Hadoop2.x版本以后开始支持)等功能.然而仅仅局限与代码层面是 ...

  8. Docker的基本组成

    Docker主要有以下几部分组成:Docker Client 客户端Docker daemon 守护进程Docker Image 镜像Docker Container 容器Docker Registr ...

  9. elasticsearch数据过期删除处理

    一.概述 使用elasticsearch收集日志进行处理,时间久了,很老的数据就没用了或者用途不是很大,这个时候就要对过期数据进行清理.这里介绍两种方式清理这种过期的数据. 1.curator 关于版 ...

  10. linux图形化客户端

    很多服务器都用linux 但这些linux都是没有图形化界面的, 一般也不建议在服务器上装图形化界面 我们都知道,维护linux,大部分都是使用命令 那么,为什么不能开发一个应用程序, 把图形化操作转 ...