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

相关推荐

  • 8-5作业

    4、取本机ip地址 ifconfig | grep -o "1[0-9]\+\.[0-9]\+\.[0-9]\+\.[1-2][0-5][0-4]" 5、取各分区利用率的数值 df | grep "/dev/sda"|tr -s ' ' |cut -d" " -f5 |tr -d…

    Linux干货 2016-08-10
  • lvs-dr模型

    dr 模型 1、 directory ,node1 ,node2 三台主机都是一块网块, 并且网卡都为桥接,且node1,nod2,不需要指定网关 在director主机中执行   #ip addr add 192.168.1.20/32 dev ens33 # ipvsadm -A -t 192.168.1.20:80 -s rr # ipvsa…

    Linux干货 2017-08-26
  • 文本查看类命令

    文本查看相关的命令:1.  cat – 串连文件,并以标准输出显示语法:cat [OPTION]… [FILE]… 常用选项 选项 | 含义—— | ——-n | 在显示文件内容时打印行号示例:~]# cat -n /etc/rc.d/init.d/functions显示/e…

    2017-09-07
  • 5.20 TOMCAT

    需要安装JDK JAVA Development Kit //JAVA 2 SE 的接口    TOMCAT 的安装: yum 安装 #yum install -y java-1.8.0-openjdk-devel 如下界面出现的话就是安装OK 注意:安装完成后,要配置JAVA_HOME环境变量,指向java的安装路径; OpenJDK: JAVA_HOME…

    2017-07-09
  • Linux基础解析;echo;man;centos;runlevel;PS1;screen;shell 倒三角;date -d等命令—-fazion blog at22.July

    Linux基础解析 fazionlan blog in 178Linux.July 20nd. 内核、版本信息 # uname -a                 &n…

    Linux干货 2016-07-29
  • yum与rpm包

    yum与rpm包 包命名和工具 包:分类和拆包 Application-VERSION-ARCH.rpm:主包 Application-devel-VERSION-ARCH.rpm 开发子包 Application-utils-VERSION-ARHC.rpm 其它子包 Application-libs-VERSION-ARHC.rpm 其它子包 包之间:可…

    Linux干货 2017-05-08