Linux用户管理相关

Q1列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。

[root@radio_freshman ~]# who
root     tty1         2016-11-11 16:35
root     pts/0        2016-11-11 16:36 (192.168.1.100)
radio    pts/1        2016-11-11 18:06 (192.168.1.100)
openstack pts/2        2016-11-11 18:06 (192.168.1.100)
mageia   pts/3        2016-11-11 18:07 (192.168.1.100)
[root@radio_freshman ~]# who | cut -d' ' -f1 | uniq
root
radio
openstack
mageia

Q2取出最后登录到当前系统的用户的相关信息。

[root@radio_freshman ~]# who
root     tty1         2016-11-11 16:35
root     pts/0        2016-11-11 16:36 (192.168.1.100)
radio    pts/1        2016-11-11 18:06 (192.168.1.100)
openstack pts/2        2016-11-11 18:06 (192.168.1.100)
mageia   pts/3        2016-11-11 18:07 (192.168.1.100)
[root@radio_freshman ~]# who | tail -1
mageia   pts/3        2016-11-11 18:07 (192.168.1.100)

Q3取出当前系统上被用户当作其默认shell的最多的那个shell。

~]# cat /etc/passwd | cut -d':' -f7 | sort | uniq -c | head -n 1 | sed 's/^.*in\///g'
bash

Q4将/etc/passwd中的第三个字段数值最大的后10个用户的信息全部改为大写后保存至/tmp/maxusers.txt文件中。

~]# cat /etc/passwd | sort -n -t ':' -k 3 | tail -10 | tr 'a-z' 'A-Z' > /tmp/maxusers.txt

Q5取出当前主机的IP地址。

方法一:
~]#ip addr show eno16777736 | grep 'inet\>' | sed 's/^.*inet[[:space:]]//g' | sed 's/\/.*$//g'
192.168.1.111
方法二:
~]# ip addr show eno16777736 | grep 'inet\>' | awk 'NR==1 {print $2}' | sed 's/\/.*$//g'
192.168.1.111
方法三:
~]# ip addr show eno16777736 | grep 'inet\>' | awk 'NR==1 {print $2}' | cut -c 1-13
192.168.1.111

Q6列出/etc目录下所有以.conf结尾的文件的文件名,并将其名字转换为大写后保存至/tmp/etc.conf文件中。

]# ls /etc/*.conf | cut -d'/' -f3 | tr 'a-z' 'A-Z' > /tmp/etc.conf

Q7显示/var目录下一级子目录或文件的总个数。

~]# ls /var/ | wc -l

Q8取出/etc/group文件中第三个字段数值最小的10个组的名字。

[root@radio_freshman var]# cat /etc/group | sort -n -t ':' -k 3 | head -n 10 | cut -d':' -f1
root
bin
daemon
sys
adm
tty
disk
lp
mem
kmem

Q9将/etc/fstab和/etc/issue文件的内容合并为同一个内容后保存至/tmp/etc.test文件中。

~]# cp /etc/fstab /tmp/etc.test
~]# cat /etc/issue >> /tmp/etc.test

Q10请总结描述用户和管理类命令的使用方法并完成一下练习:

(1)创建组distro,其GID为2016;

[root@radio_freshman ~]# groupadd -g 2016 distro
[root@radio_freshman ~]# grep distro /etc/group 
distro:x:2016:

(2)创建用户mandriva,其ID号为1005;基本组为distro;

[root@radio_freshman ~]# useradd -u 1005 -g distro mandriva
[root@radio_freshman ~]# grep mandriva /etc/passwd
mandriva:x:1005:2016::/home/mandriva:/bin/bash

(3)创建用户mageia,其ID号为1100,家目录为/home/linux;

[root@radio_freshman ~]# useradd -u 1100 -d /home/linux mageia
[root@radio_freshman ~]# grep mageia /etc/passwd
mageia:x:1100:1100::/home/linux:/bin/bash

(4)给用户mageia添加密码,密码为mageedu;

[root@radio_freshman ~]# passwd mageia
更改用户 mageia 的密码 。
新的 密码:
重新输入新的 密码:
passwd:所有的身份验证令牌已经成功更新。

(5)删除mandriva,保留其家目录;

[root@radio_freshman ~]# userdel mandriva
[root@radio_freshman ~]# ls /home/mandriva/
[root@radio_freshman ~]# ls /home/
linux  mandriva  radio  user3

(6)创建用户slackware,其ID号为2002,基本组为distro,付加组peguin;

[root@radio_freshman ~]# useradd -u 2002 -g distro -G peguin slackware
[root@radio_freshman ~]# grep slackware /etc/passwd /etc/group;grep distro /etc/group
/etc/passwd:slackware:x:2002:2016::/home/slackware:/bin/bash
/etc/group:peguin:x:2017:slackware
distro:x:2016:

(7)修改slackware的默认shell为/bin/tcsh;

[root@radio_freshman ~]# usermod -s /bin/tcsh slackware
[root@radio_freshman ~]# grep slackware /etc/passwd
slackware:x:2002:2016::/home/slackware:/bin/tcsh

(8)为用户slackware新增附加组admins;

[root@radio_freshman ~]# groupadd admins
[root@radio_freshman ~]# grep slackware /etc/group
peguin:x:2017:slackware
[root@radio_freshman ~]# usermod -aG admins slackware
[root@radio_freshman ~]# grep slackware /etc/group
peguin:x:2017:slackware
admins:x:2018:slackware

(9)为slackware添加密码,且要求密码最短使用期限为3天,最长为180天,警告为3天;

[root@radio_freshman ~]# passwd -n 3 -x 180 -w 3 slackware
调整用户密码老化数据slackware。
passwd: 操作成功
[root@radio_freshman ~]# grep slackware /etc/shadow
slackware:!!:17116:3:180:3:::

(10)添加用户openstack,其ID号为3003,基本组为clouds,附加组为peguin和nova;

[root@radio_freshman ~]# groupadd clouds
[root@radio_freshman ~]# groupadd  nova
[root@radio_freshman ~]# grep -E "clouds|nova" /etc/group
clouds:x:2019:
nova:x:2020:
[root@radio_freshman ~]# useradd -u 3003 -g clouds -G peguin,nova openstack
[root@radio_freshman ~]# grep openstack /etc/passwd /etc/group
/etc/passwd:openstack:x:3003:2019::/home/openstack:/bin/bash
/etc/group:peguin:x:2017:slackware,openstack
/etc/group:nova:x:2020:openstack

(11)添加系统用户为mysql,要求其shell为/sbin/nologin;

[root@radio_freshman ~]# useradd -s /sbin/nologin mysql
[root@radio_freshman ~]# grep mysql /etc/passwd
mysql:x:3004:3004::/home/mysql:/sbin/nologin

(12)使用echo命令,非交互式为openstack添加密码。

[root@radio_freshman ~]# echo "mageedu1" | passwd --stdin openstack
更改用户 openstack 的密码 。
passwd:所有的身份验证令牌已经成功更新

原创文章,作者:N24_VC,如若转载,请注明出处:http://www.178linux.com/59047

(0)
N24_VCN24_VC
上一篇 2016-11-13
下一篇 2016-11-13

相关推荐

  • Linux软件包管理(YUM)及编译安装

    YUM 一、yum安装使用: 1、Yum:rpm的前端程序,用来解决软件包相关依赖性,可以在多个库之间定位软件包,up2date的替代工具 2、yum repository:yum repo,存储了众多rpm包,以及包的相关的元数据文件(放置于特定目录repodata下) 3、yum客户端配置文件: /etc/yum.conf:为所有仓库提供公共配置 /et…

    Linux干货 2016-08-26
  • httpd2.4 应用

    练习:  (1)基于主机名实现三个虚拟主机     (2) 每虚拟主机使用独立的访问日志和错误日志 (3) 第三个虚拟主机的/admin要进行用户访问认证  (4) 在第二个虚拟主机上提供/status; (5) 在第三个虚拟主机提供路径别名/bbs,访问其它文件系统路径; (6) 尝试使用混合类型…

    Linux干货 2016-10-09
  • 权限管理

    权限管理包括普通权限、特殊权限、默认权限、ACL权限。 这些权限都是针对u(owner)、g(group)、o(other)三类定义的。 设置权限时文件和目录不同(此处把文件和目录分开,一般说文件就包含目录(linux思想:一切皆文件))如下图所示, 分别用两个用户分别创建了一个目录一个文件,可以看到同是目录的liutest和test的权限不同,它俩同为目录…

    Linux干货 2017-07-30
  • 了解Nginx

    Nginx Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。由俄罗斯的程序设计师Igor Sysoev所开发,其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝…

    Linux干货 2016-11-07
  • 第一周记录

    列出Linux的发行版,描述不同发行版之间的联系与区别。    发行版多达100多种,其中主要的有Debian旗下的Ubuntu、knopix,Slackware旗下的S.u.S.E,RedHat公司旗下的RedHat、CentOS、Fedora。其中各个版本之间的区别:包管理器的区别;但其内核都是Linux内核。 ifconfig: 查…

    Linux干货 2016-08-15
  • hello! 我的博客第一站

    大家好!  这是我进博客的第一天,一个刚进来的新司机。在这里我就不秀我的车技了,只希望各位老司机开车不要太快,我晕车      —— 生命不息,奋斗不止

    Linux干货 2017-07-11