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

相关推荐

  • 计算机基础知识及基本命令(20170214)

    计算机基础知识 操作系统相关 linux分区介绍 安装linux linux基本命令    一、计算机基础知识       计算机(computer):计算机(Computer):俗称电脑,是一种能接收和存储信息,并按照存储在其内部的程序对海量数据进行自动、高速地处理,然后把处理结果输出的现代化智能电子设备 …

    Linux干货 2017-02-14
  • iptables:iptables工具详解

    之前的博客聊了关于iptables防火墙工作原理的相关介绍, 本片将详细介绍iptables的使用。 一、 iptables 查看链表,创建链表,类命令     1. iptables [-t table] -N chain : 创建一条自定义规则的链      #&n…

    Linux干货 2015-08-06
  • linux-用户和组的基本管理

    用户和组

    2018-03-20
  • 17 正则表达式及作业

    17 正则表达式及作业     因为正则表达式类型较多且比较重要,因此单独拿出一篇进行陈述。 正则表达式是各种文本处理工具的基础,也是shell编程必须牢牢掌握的知识,其重要性不言而喻。 一、杂项知识整理 1、一个[:space:]包括一个tab。 2、区分好文件名通配(globing)和文件内容通配(正则表达式)。 …

    Linux干货 2016-08-05
  • bash特性

    2018-03-11

    2018-03-11
  • redis简介

    redis是一种非关系性数据库,单进程工作模型,通常用来做KV存储,同memcached一样,所有数据加载至内存工作因此工作效率非常快,但他会将内存中的数据同步至磁盘当中,使得数据不会像memcached的一样,断电后丢失数据。 自身支持多种数据结构(此处列出常用数据结构) string:单一的kv存储 hash:支持hash计算后的存储 list:列表存储…

    2017-03-17