Linux基础之正则表达式,用户、组管理命令介绍

通配符(Globbing)

通配符与元字符类似,通配符主要用于文件名的匹配,而元字符则主要用在字符串的匹配上;
下面介绍几种常用的通配符:

* 表示匹配任意位数的任意字符
? 表示匹配一位任意字符
^ 表示取反,不包含的意思
[] 表示此区间内的任意一个字符
{} 表示一种集合
\ 转义字符,使具有特殊意义的字符失去原有意义
| 表示‘或',匹配一组可选的字符

元字符

元字符是用来描述字符的特殊字符。
常用的元字符及意义如下:

*      重复前面的字符0次或者多次
.      匹配任意字符一次
\+     匹配前面的字符1次或者多次
\?     匹配前面的字符0次或者1次
\{m\}    匹配其前面的字符m次
\{m,n\}   匹配前面的字符至少m次,至多n次
^      匹配字符在行首
$      匹配字符在行尾
^$     匹配空白行。空格、0不算
\<     匹配字符在词首
\>     匹配字符在词尾
\<string\> 精准匹配string
\(xy\)   xy表示一个分组
\1     模式从左侧起,第一个左括号以及与之匹配的右括号之间的模式所匹配的字符

除了以上的常用的元字符,还有一些特殊的元字符:

[:alpha:]  所有大小写字母
[:upper:]  所有大写字母
[:lower:]  所有小写字母
[:alnum:]  所有字母及数字
[:punct:]  所有标点符号
[:blank:]  空白键和TAB键
[:space:]  任意空白的字元,空格、tab、CR等
[:digit:]  任意数字,0-9
[:print:]  任何可以被打印出来的字符

grep

grep, egrep, fgrep - print lines matching a pattern
【SYNOPSIS】
  grep [OPTIONS] PATTERN [FILE...]
  grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
【OPTIONS】
  --color=auto  对匹配到的内容进行高亮显示处理
  -i,--ignore-case
     Ignore case distinctions in both the PATTERN and the input
     files. (-i is specified by POSIX.)忽略字符大小写匹配
  -v,--invert-match
     Invert the sense of matching, to select non-matching lines.
     (-v is specified by POSIX.)显示没有匹配到的行
  -o,--only-matching
     Print only the matched (non-empty) parts of a matching line,
     with each such part on a separate output line.只显示匹配到的部分
  -q,--quiet,--silent静默模式,不列举任何内容
  -w,--word-regexp  单词完整匹配所在的行
  -d, --directories=ACTION how to handle directories; ACTION is 'read', 'recurse', or 'skip',目录表示方式:只读、递归、跳过
  -r,-r, --recursive      like --directories=recurse
  -c,--count print only a count of matching lines per FILE匹配到的文件有多少行
  -B,--before-context=NUM print NUM lines of leading context列出匹配到的前NUM行
  -A,--after-context=NUM  print NUM lines of trailing context列出匹配到的后NUM行
  -C,--context=NUM   print NUM lines of output context列出匹配到的前后几行

cut

Print selected parts of lines from each FILE to standard output列举每行被选中的部分到标准输出,也就是提取行中的某个字段
【SYNOPSIS】
cut OPTION... [FILE]...
【OPTION】
  -b,--bytes=LIST   select only these bytes按字节分隔
  -c,--characters=LIST  select only these characters按字符分隔
  -d,--delimiter=DELIM  use DELIM instead of TAB for field delimiter  用TAB替换指定的分隔符来分区域
  -f,--field=LIST   分区域后,根据区域位数来列出数据
  -n with -b: don't split multibyte characters不分隔多字节字符
【FOR EXAMPLE】
  [root@localhost ~]# cat /etc/passwd|cut -d: -f1
  root
  bin
  daemon
  adm
  lp
  提取/etc/passwd文件的第一个字段内容,也就是用户名
  [root@localhost ~]# cat /tmp/ah2.txt |cut -nb 1,2,3
  平凡的
  [root@localhost ~]# cat /tmp/ah2.txt |cut -nb 1不分割字节
  平
  [root@localhost ~]# cat /tmp/ah2.txt |cut -b 1汉字属于多字节字符

  [root@localhost ~]# cat /tmp/ah2.txt |cut -c 1
  平

sort

sort lines of text files文本文件的行排序
【SYNOPSIS】
 sort [OPTION]... [FILE]...
 sort [OPTION]... --files0-from=F
【OPTION】
  -b,--ignore-leading-blanks
  -f,--ignore-case
    fold lower case to upper case characters 忽略大小写
  -i,--ignore-nonprinting
    consider only printable characters忽略空白
  -M,--month-sort
    按照三位数月份排序
  -h,--human-numeric-sort   compare human readable numbers
    使用人类可读的单位排序
  -g,--genaral-numeric-sort
    使用通用数值排序,支持科学计数
  -t,--field-separator=SEP
    use SEP instead of non-blank to blank transition
    指定分列的分隔符
  -k,--key=KEYDEF
    sort via a key;KEYDEF gives location and type
    指定列排序,
  -n,--numeric-sort
    compare according to string numerical value
    根据字符串中的数值排序
  -r,--reverse
    反序排列
  -c,--check check from srot input;don't sort
    排序检查,但不排序
  -o,--output=FILE  write result to FILE instead of standard output
    将结果保存至文件中而不输出
  -u,--unique   with -c,check for strict ordering; without -c,output only the first of an equal run
    与-c组合,执行严格的顺序检查;不与-c组合,仅输出第一个结果,剔除相邻重复的行,重复且相邻的无法剔除。

uniq

report or omit repeated lines记录或剔除重复行
【SYNOPSIS】
uniq [OPTION]... [INPUT [OUTPUT]]
【OPTION】
  -c,--count prefix lines by the number of occurrences行计数(重复行列一行,前面有重复次数)
  -d,--repeated  only print duplicate lines, one for each group只打印有重复的行
  -D,--all-repeated[=METHOD]
  -f,--skip-fields=N
    跳过前N个字段
  -s,--skip-chars=N
    跳过前几个字符
  -i,--ignore-case  忽略大小写
  -u,--unique   only print unique lines仅打印不重复的行
  -z,--zero-terminated  end lines with 0 bytes,not newline
  -w,--check-chars=N compare no more than N characters in lines
    第N个字符之后不做匹配

练习

1、列出当前系统上所有已经登录的用户的用户名,同一用户登录多次,只显示一次即可

who |cut -d' ' -f 1|uniq

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

cat /etc/passwd|grep "^`last -1|cut -d' ' -f1|head -1`"

3、去除当前系统上被用户当作其默认的shell的最多的那个shell

cat /etc/passwd|cut -d: -f7|sort -u|sort -rn|head -1

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

cat /etc/passwd|sort -t':' -k3 -n|tail|tr [a-z] [A-Z] 2&>1 /tmp/maxusers.txt

5、取出当前主机的IP地址,

ifconfig eno16777736| grep  "\<inet\>"|cut -d' ' -f 10

6、列出/etc/下所有以.conf结尾的文件的文件名,并将其名字转换成大写后保存至/tmp/etc.conf文件中

ls /etc|grep -o ".*\.conf$"|tr [a-z] [A-Z] >> /tmp/etc.conf

7、显示/var目录下一级子目录或者文件的总个数

linux里没有直接的命令来展示一个目录下的文件个数,可以通过管道将两个命令组合
查看目录下所有文件个数命令如下:
ls |wc -l
 1、ls 是查看文件夹内所有文件的命令
 2、wc -l 是统计文件行数的命令
 3、以上两个命令叠加,相当于统计文件夹下文件总数

#!/bin/sh
find /tmp/homework -maxdepth 1 -type d | while read dir; do
count=$(find "$dir" -type f | wc -l)
echo "$dir : $count"
done

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

cat /etc/group|sort -t':' -k 3 -n|head |cut -d':' -f1

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

cat /etc/fstab /etc/issue >>/tmp/etc.test

Linux基础知识—用户、组管理

Linux为了提高其安全性,通过创建用户及用户组并赋相应的权限来限制各用户访问不同的文件。下面我们来学习下用户及用户组的相关管理命令先来看看几个文件:

/etc/passwd

[root@localhost ~]# cat /etc/passwd|head -3
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin

其文件内容格式是由‘:'分隔开的字符串,其内容包括如下: USERNAME:X:UID:GID:DESCRIPTION:HOME:SHELL

/etc/shadow

[root@localhost ~]# cat /etc/shadow|head -3
root:$6$1RSlswAIVbmtwWM5$WLZxHXzkL7.PvHb2ghYqbGvj3Cz4AB5sGRr33TwCX1cwSqV.syv0q1eqcF3NGUJeNNspAOt5C1rWfdsgBllB1.::0:99999:7:::
bin:*:16659:0:99999:7:::
daemon:*:16659:0:99999:7:::

其内容格式类似于/etc/passwd格式,只是内容不同:

USERNAME:ENCRYPTED PASSWD:DATE OF LAST CHANGE:MINIMUM PASSWD AGE: MAXIMUM PASSWD AGE:PASSWD WARNING:PASSWORD INACTIVITY:EXPIRATION

这个简单的解释下:

USERNAME:也就是用户名
ENCRYPTED PASSWD:加密的密码
DATE OF LAST CHANGE:最后修改密码的日期(天数,是以1970-1-1起算的天数)
MINIMUM PASSWD:最短可修改密码日期(天数,相对第三栏的最后修改日期)
MAXIMUM PASSWD:最长可修改密码日期
PASSWD WARNING:密码过期前的警告天数(相对第四栏的日期之前的天数)
PASSWD INACTIVITY:密码的闲置日期(密码过期之后还有一定的天数可以使用)
EXPIRATION:备注

UID

人与计算机交互,人可识别字符和数字等,但是计算机只能识别0、1这样的二进制代码,所以,UID就是分配给USERNAME相对应的计算机可识别的ID号码;UID可分为以下几类:

0:系统管理员,root的UID
1-999:系统用户,这些用户是系统后台的服务类程序的用户所用;用户也可以指定用户为系统用户
1000-2^32-1:普通用户

GID

在程序设计过程中,我们会将一部分用户之间的资料共享,而不愿让资料为外人看到,所以就有了用户组的概念,用户之间通过GID来确定用户组的范围

下面我们来介绍下设置以上及相关信息的命令:

useradd

create a new user or update default new user information
【SYNOPSIS】
  useradd [options] LOGIN
  useradd -D
  useradd -D [options]
【OPTIONS】
  -D useradd命令的部分默认参数,可修改
  -c,--comment    添加用户的描述信息,finger USERNAME查看更直观
  -d,--home-dir    指定用户的家目录,必须为绝对路径
  -e,--expiredate   用户账号失效日期,格式默认:YYYY-MM-DD
  -f,--inactive    指定用户密码是否失效(-1:永不失效,过期会强制修改密码;0:立刻失效)
  -g,--gid      用户主属组,该属组必须可用
  -G,--groups     用户附加属组,该属组可设置多个
  -M         强制不建立家目录
  -m         强制建立家目录
  -r,create system user  创建系统用户
  -o,--non-unique   允许创建一个已存在的UID的用户(重复的UID)
  -s,--shell     指定该用户的shell环境
  -u,--uid      指定用户的uid值

passwd

update user's authentication tokens
【SYNOPSIS】
  passwd [-k] [-l] [-u [-f]] [-d] [-e] [-n mindays] [-x maxdays] [-w warndays] [-i inactivedays] [-S]
  [--stdin] [username]
【OPTIONS】
  --stdin   结合管道符将标准输入直接赋值给用户密码
  -l,--lock  锁定指定用户
  -u,--unlock   解锁指定用户
  -d,--delete   快速删除用户密码
  -e,--expire   使用户密码失效
  -n,--minimum  密码的最短修改天数
  -x,--maximum  密码的最长修改天数
  -w,--waring   密码过期前的通知天数
  -i,--inactive  密码过期后的闲置天数
  -S,--status   用户的密码状态

groupadd

create a new group
【SYNOPSIS】
  groupadd [options] group
【OPTION】
  -g,--gid    创建一个指定gid的group
  -K,--key    修改/etc/login.defs的值,具体可参照此文件的内容
  -o,--non-unique   创建一个已有的gid的组
  -p,--password  创建组密码,现在基本用不到
  -r,--system-group  创建一个系统组

newgrp

log in to a new group
【SYNOPSIS】
  newgrp [-] [group]
这个命令只是在用户的主属组更换的时候有用,例如USERNAME有主属组group1,附属组group2,group3;现在切换用户的主属组为group3则使用此命令

总结描述用户和组管理类命令的使用方法并完成练习

创建组distro,其GID为2016;
[root@localhost ~]# groupadd -g 2016 distro
[root@localhost ~]# tail -1 /etc/group
distro:x:2016:

创建用户mandriva,其ID为1005;基本组位distro;
[root@localhost ~]# useradd -g distro -u 1005 mandriva
[root@localhost ~]# tail -1 /etc/passwd
mandriva:x:1005:2016::/home/mandriva:/bin/bash

创建用户mageia,其ID位1100;家目录为/home/linux;
[root@localhost ~]# useradd -u 1100 -d /home/linux mageia
[root@localhost ~]# tail -1 /etc/passwd
mageia:x:1100:1100::/home/linux:/bin/bash

给用户mageia添加密码,密码为mageedu;
[root@localhost ~]# passwd mageia
Changing password for user mageia.
New password:
Retype new password:
passwd: all authentication tokens updated successfully.

删除用户mandriva但保留其家目录;
[root@localhost ~]# tail -3 /etc/passwd
mariadb:x:1000:1000::/home/mariadb:/sbin/nologin
hadoop:x:1001:1001::/home/hadoop:/bin/bash
mageia:x:1100:1100::/home/linux:/bin/bash
[root@localhost ~]# ls /home/
hadoop linux mandriva

创建用户slackware,其ID为2002,基本组为distro,附属组为peguin;
[root@localhost ~]# groupadd peguin
[root@localhost ~]# useradd -u 2002 -g distro -Gpeguin slackware
[root@localhost ~]# tail -2 /etc/passwd
mageia:x:1100:1100::/home/linux:/bin/bash
slackware:x:2002:2016::/home/slackware:/bin/bash
[root@localhost ~]# tail -2 /etc/group
mageia:x:1100:
peguin:x:2017:slackware

修改slackware的默认shell为/bin/tcsh;
[root@localhost ~]# usermod -s /bin/tcsh slackware
[root@localhost ~]# tail -2 /etc/passwd
mageia:x:1100:1100::/home/linux:/bin/bash
slackware:x:2002:2016::/home/slackware:/bin/tcsh  

为用户slackware新增附属组admins;
[root@localhost ~]# usermod -aG admins slackware
[root@localhost ~]# tail -4 /etc/group
distro:x:2016:
mageia:x:1100:
peguin:x:2017:slackware
admins:x:2018:slackware

为slackware添加密码,且要求密码最短使用期限为3天,最长为180天,警告为3天;
[root@localhost ~]#passwd -n 3 -x 180 -w 3 slackware
[root@localhost ~]# tail -1 /etc/shadow
slackware:!!:16658:3:180:3:::
[root@localhost ~]#echo 'Slackware'|passwd --stdin slackware

添加用户openstack,其ID号为3003,基本组为clouds,附加组为peguin和nova;
[root@localhost ~]# groupadd clouds
[root@localhost ~]# groupadd nova
[root@localhost ~]# useradd openstack -u 3003 -g clouds -G peguin,nova
[root@localhost ~]# tail -1 /etc/passwd
openstack:x:3003:2019::/home/openstack:/bin/bash

添加系统用户mysql,要求其shell为/sbin/nologin;
[root@localhost ~]# useradd -r mysql -s /sbin/nologin
[root@localhost ~]# tail -1 /etc/passwd
mysql:x:996:994::/home/mysql:/sbin/nologin

使用echo命令,非交互为openstack添加密码
[root@localhost ~]# echo 'Openstack'|passwd --stdin openstack
Changing password for user openstack.
passwd: all authentication tokens updated successfully.

以上就是Linux基础之正则表达式,用户、组管理命令介绍,如果您有什么建议可以留言

(0)

相关推荐

  • 详解Linux命令中的正则表达式

    命令中的正则表达式 如果要在命令输出或文本中筛选内容时使用模糊查找,就需要使用正则表达式.正则表达式是一套由多个元字符组成的模糊查找模式,使用正则表达式可以快速查找和定位文本中指定的内容. 1.单字符匹配符.  正则表达式主要由一些元字符和匹配模式组成 单字符匹配符可以匹配任意单个字符,这个字符的功能和文件名匹配符中的?功能相同 使用正则表达式查找文本,首先需要使用元字符组成一个查找模式 (1)使用查找模式时,通常将其放入两个斜杠//中,然后再放入命令,例如要在一个文本中查找匹配模式/.i...

  • 详解基于Linux下正则表达式(基本正则和扩展正则命令使用实例)

    前言 正则表达式应用广泛,在绝大多数的编程语言都可以完美应用,在Linux中,也有着极大的用处. 使用正则表达式,可以有效的筛选出需要的文本,然后结合相应的支持的工具或语言,完成任务需求. 在本篇博客中,我们使用grep/egrep来完成对正则表达式的调用,其实也可以使用sed等工具,但是sed的使用极大的需要正则表达式,为了在后面sed篇的书写,就只能这样排序了,有需要的朋友可以把这两篇一起来看. 正则表达式的类型 正则表达式可以使用正则表达式引擎实现,正则表达式引擎是解释正则表达式模式并使用

  • Linux基础之正则表达式,用户、组管理命令介绍

    通配符(Globbing) 通配符与元字符类似,通配符主要用于文件名的匹配,而元字符则主要用在字符串的匹配上: 下面介绍几种常用的通配符: * 表示匹配任意位数的任意字符 ? 表示匹配一位任意字符 ^ 表示取反,不包含的意思 [] 表示此区间内的任意一个字符 {} 表示一种集合 \ 转义字符,使具有特殊意义的字符失去原有意义 | 表示'或',匹配一组可选的字符 元字符 元字符是用来描述字符的特殊字符. 常用的元字符及意义如下: * 重复前面的字符0次或者多次 . 匹配任意字符一次 \+ 匹配前面

  • Linux下sshd服务及服务管理命令详解

    sshd SSH为Secure Shell的缩写,是应用层的安全协议.SSH是目前较可靠,专为远程登陆会话和其他网络服务提供安全性的协议.利用SSH协议可以有效防止远程管理过程中的信息泄露问题. openssh-server 功能:让远程主机可以通过网络访问sshd服务,开始一个安全shell 客户端连接方式 ssh 远程主机用户@远程主机ip 先rm -rf /root/.ssh/清掉之前的配置 ssh 远程主机用户@远程主机ip -X 调用远程主机图形工具 ssh 远程主机用户@远程主机ip

  • Linux 下dmidecode查看内存条数的命令介绍

    在linux下有很多命令,可以查看机器的硬件信息. 这里介绍一个查看内存的条数等信息的方法. 相看硬件信息,仅适合ubuntu系列发行版: lshw Linux 下查看内存条数: dmidecode |grep -A16 "Memory Device$" 有关dmidecode命令的详细用法,请参考这篇文章:linux查看主板内存槽与内存信息的命令dmidecode. 以上就是小编为大家带来的Linux 下dmidecode查看内存条数的命令介绍全部内容了,希望大家多多支持我们~

  • linux 查找过滤及用户和组管理命令的一些实例

    1.列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可. ~]# who | cut -d' ' -f1 | sort | uniq 2.列出最后登录到当前系统的用户的相关信息. ~]# last | head -1 3.列出当前系统上被用户当作其默认shell的最多的那个shell. ~]# cut -d: -f7 /etc/passwd | uniq -c | sort -n | tail -1 4.将/etc/passwd中的第三个字段数值最大的后10个用

  • Linux文件权限与群组修改命令详解

    在Linux中,一切皆为文件(目录也是文件),每个文件对用户具有可读(read).可写(write).可执行(execute)权限.目录的执行操作表示是否有权限进入该目录,文件的可执行表示是否可以运行该文件.文件都会从属于一个用户和一个用户组,每个文件针对文件的拥有者.所属组以及其他用户组具有特定的权限. 如上图,除去第一个表示文件类型的字符外,后面的字符均以三个为一组,是『rwx』 的三个参数的组合.[ r ]代表可读(read).[ w ]代表可写(write).[ x ]代表可执行(exe

  • Linux系统用户管理命令小结

    用户和组管理 1.用户/组基本概念 Users and groups: . Every process (running program) on the system runs as a particular user. . Every file is owned by a particular user. . Access to files and directories are restricted by user. . The user associated with a running

  • Linux用户和用户组管理方法介绍

    目录 一.用户账号的管理 1.添加新的用户账号使用useradd命令,其语法如下: 2.删除帐号 3.修改帐号 4.用户口令的管理 二.用户组的管理 1.增加一个新的用户组使用groupadd命令.其格式如下: 2.如果要删除一个已有的用户组,使用groupdel命令,其格式如下: 3.修改用户组的属性使用groupmod命令.其语法如下: 4.如果一个用户同时属于多个用户组,那么用户可以在用户组之间切换,以便具有其他用户组的权限. 三.与用户账号有关的系统文件 1./etc/passwd文件,

  • linux用户和组管理常见命令总结

    本文总结了linux用户和组管理常见命令.分享给大家供大家参考,具体如下: 1.用户隶属于用户组的. 2.用户与用户组配置文件 1)用户组配置文件 /etc/group 第一列:用户组的组名 第二列:组密码(真正的密码存储在了gshadow中) 第三列:用户组组ID,用户组唯一标识         组ID为0的是超级用户组         组ID为1-499是系统用户组         组ID大于500是用户自定义组 第四列:组成员 2)用户组密码配置文件 /etc/gshadow 第一列:用户

  • linux用户与文件基础命令介绍(1)

    linux系统是一个多用户多任务的分时操作系统,但系统并不能识别人,它通过账号来区别每个用户.每个linux系统在安装的过程中都要为root账号设置密码,这个root即为系统的第一个账号.每一个用这个账号登录系统的用户都是超级管理员,他们对此系统有绝对的控制权.通过向系统管理员进行申请,还可以为系统创建普通账号.每个用普通账号登录系统的用户,对系统都只有部分控制权. 我们知道计算机中的数据是以二进制0.1的形式存储在硬件之上的.在linux中,为了管理的方便,系统将这些数据组织成目录和文件,并以

  • Linux帮助和用户管理命令

    上篇文章我们介绍了Linux文件搜索命令,其中find是用的最多的也是功能最强大的文件或目录搜索命令,和另一个搜索命令locate的区别是,find命令是全盘搜索,刚创建的文件也能搜索的到,而locate是在文件资料库中进行搜索,对比find命令搜索速度快很多,但是新创建的文件如果没有收录到文件资料库中,使用locate命令是搜索不到的,再就是/tmp目录是不收录到文件资料库的,也就是说使用locate命令搜索不到在/tmp目录下的文件.然后我们介绍搜索命令所在的目录以及别名信息which,搜索

随机推荐