Linux命令使用

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

[[email protected] ~]# who | cut -d ‘ ‘ -f 1 | sort -u

admin

root

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

[[email protected] ~]# cat /etc/passwd | cut -d : -f 7 | uniq -c | sort -n | tail -1

25 /sbin/nologino

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

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

[[email protected] ~]# cat /tmp/maxusers.txt

ABRT:X:173:173::/ETC/ABRT:/SBIN/NOLOGIN

PULSE:X:497:495:PULSEAUDIO SYSTEM DAEMON:/VAR/RUN/PULSE:/SBIN/NOLOGIN

SASLAUTH:X:498:76:SASLAUTHD USER:/VAR/EMPTY/SASLAUTH:/SBIN/NOLOGIN

RTKIT:X:499:497:REALTIMEKIT:/PROC:/SBIN/NOLOGIN

ADMIN:X:500:500::/HOME/ADMIN:/BIN/BASH

USER1:X:501:502::/HOME/USER1:/BIN/BASH

USER2:X:502:503::/HOME/USER2:/BIN/BASH

CENTOS:X:503:504::/HOME/CENTOS:/BIN/BASH

ROOT123:X:504:505::/HOME/ROOT123:/BIN/BASH

NFSNOBODY:X:65534:65534:ANONYMOUS NFS USER:/VAR/LIB/NFS:/SBIN/NOLOGIN

4、取出当前主机的IP地址,提示:对ifconfig命令的结果进行切分。

[[email protected] ~]# ifconfig | grep "\(inet add\)" | head -1 | cut -d : -f 2 | tr -d Bcast

192.168.10.103

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

[[email protected] ~]# tree -L 1 /var | wc -l

24

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

[[email protected] ~]# cat /etc/group | sort -t : -k 3 -n | head -10 | cut -d : -f 1

root

bin

daemon

sys

adm

tty

disk

lp

mem

kmem

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

[[email protected] ~]# cat /etc/fstab /etc/issue > /tmp/etc.text

[[email protected] ~]# cat /tmp/etc.text

#

# /etc/fstab

# Created by anaconda on Fri Nov 25 05:32:50 2016

#

# Accessible filesystems, by reference, are maintained under ‘/dev/disk‘

# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info

#

/dev/mapper/VolGroup-lv_root /                       ext4    defaults        1 1

UUID=40cea874-31c8-404a-9463-32c09bad241c /boot                   ext4    defaults        1 2

/dev/mapper/VolGroup-lv_swap swap                    swap    defaults        0 0

tmpfs                   /dev/shm                tmpfs   defaults        0 0

devpts                  /dev/pts                devpts  gid=5,mode=620  0 0

sysfs                   /sys                    sysfs   defaults        0 0

proc                    /proc                   proc    defaults        0 0

CentOS release 6.8 (Final)

Kernel \r on an \m

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

用户创建:useradd

-u:UID,定义在/etc/login.defs

-g:GID指定用户所属基本组,可为组名,也可以为GID

-c:用户的注释信息

-d:已指定的路径为家目录。

-s:指定用户默认的shell程序,可用列表在/etc/shells中

-G:为用户指明附加组。

-r:创建系统用户。

组创建:groupadd

-g:指明GID号

用户属性修改:usermod

-u:新的uid

-g:新的基本组

-G:新的附加组,原来的附加组将会覆盖,若要保留原有,则同时要使用-a选项。

-s:新的shell

-c:新的注释信息

-d:新的家目录,原有家目录中的文件不会同时移动至新的家目录,若要移动,则同时使用-m选项

-l:login name:新的名字

-L:lock指定用户

-U:unlock指定用户

-e:YYYY-MM-DD指明用户账号的过期日期

-f:设定非活动的期限

组属性修改:groupmod

-n:新的名字

-g:新的GID

用户添加密码:passwd(修改指定用户的密码,仅root用户权限)

passwd:修改自己的密码

-l:锁定指定用户

-u:解锁指定用户

-n:mindays:指定最短的使用期限

-x:maxdays:最大使用期限

-i:非活动期限

--stdin:从标准输入接收用户密码。

echo "passwd" | passwd --stdin USERNAME

组密码:gpasswd

-a:将user添加至指定的组中

-d:删除用户user的以当前为组名的附加组

-A:设置管理权限的用户列表

删除用户:userdel

-r:删除用户的家目录

删除组:groupdel

groupdel GROUP

临时切换基本组:newgrp

如果用户本不属于此组,则需要密码

修改用户的属性:chage

-d LAST_DAY

-E, --expiredate EXPIRE_DATE

-I, --inactive INACTIVE

-m, --mindays MIN_DAYS

-M, --maxdays MAX_DAYS

-W, --warndays WARN_DAYS

查看用户的相关的ID信息:ID

-u:UID

-g:GID

-G:Group

-n:Name

切换用户或以其他用户身份执行:su

su UserName:非登录式切换

su - Username:登录式切换。会读取目标用户的配置文件,完全切换。

note:root 至其他用户无需密码,非root用户切换时需要密码。

换个身份执行命令:su - Username -c `COMMAND`

修改一些具体的信息:chfn

修改新的shell:chsh

显示用户的详细信息:finger

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

[[email protected] ~]# groupadd distro -g 2016

[[email protected] ~]# cat /etc/group | tail -1

distro:x:2016:

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

[[email protected] ~]# useradd mandriva -u 1005 -g distro

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

[[email protected] ~]# useradd mageia -u 1100 -d /home/linux

[[email protected] ~]# cat /etc/passwd | tail -1

mageia:x:1100:1100::/home/linux:/bin/bash

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

[[email protected] ~]# passwd mageia

Changing password for user mageia.

New password:

BAD PASSWORD: it is based on a dictionary word

BAD PASSWORD: is too simple

Retype new password:

passwd: all authentication tokens updated successfully.

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

[[email protected] ~]# userdel mandriva

[[email protected] ~]# ls /home/

admin  centos  linux  mandriva  root123  user1  user2

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

[[email protected] ~]# groupadd peguin

[[email protected] ~]# useradd slackware -u 2002 -g distro -G peguin

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

[[email protected] ~]# usermod slackware -s /bin/tcsh

[[email protected] ~]# cat /etc/passwd | tail -1

slackware:x:2002:2016::/home/slackware:/bin/tcsh

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

usermod  slackware -aG admins

[[email protected] ~]# id slackware

uid=2002(slackware) gid=2016(distro) groups=2016(distro),2018(admins)

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

[[email protected] ~]# passwd -n 3 -x 180 -w 3 slackware

[[email protected] ~]# cat /etc/shadow | tail -1

slackware:!!:17155:3:180:3:::

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

[[email protected] ~]# useradd openstack -u 3003 -g clouds -G peguin,nova

[[email protected] ~]# id openstack

uid=3003(openstack) gid=2020(clouds) groups=2020(clouds),2017(peguin),2019(nova)

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

[[email protected] ~]# useradd mysql -s /sbin/nologin

[[email protected] ~]# cat /etc/passwd | tail -1

mysql:x:3004:3004::/home/mysql:/sbin/nologin

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

[[email protected] ~]# echo "11qqwww" | passwd --stdin openstack

Changing password for user openstack.

passwd: all authentication tokens updated successfully.

9、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。

[[email protected] ~]# cp -r /etc/skel /home/tuser1 && chmod -R go= /home/tuser1

10、显示/proc/meminfo文件中以大写或小写S开头的行;用两种方式

[[email protected] ~]# grep -i "^s" /proc/meminfo

[[email protected] ~]# grep  "^[sS]" /proc/meminfo

SwapCached:            0 kB

SwapTotal:       2064380 kB

SwapFree:        2064380 kB

Shmem:              3844 kB

Slab:             139288 kB

SReclaimable:      94680 kB

SUnreclaim:        44608 kB

11、显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户;

[[email protected] ~]# grep -v ".*\(/sbin/nologin\)$" /etc/passwd

root:x:0:0:root:/root:/bin/bash

sync:x:5:0:sync:/sbin:/bin/sync

shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown

halt:x:7:0:halt:/sbin:/sbin/halt

admin:x:500:500::/home/admin:/bin/bash

user1:x:501:502::/home/user1:/bin/bash

user2:x:502:503::/home/user2:/bin/bash

centos:x:503:504::/home/centos:/bin/bash

root123:x:504:505::/home/root123:/bin/bash

mageia:x:1100:1100::/home/linux:/bin/bash

slackware:x:2002:2016::/home/slackware:/bin/tcsh

openstack:x:3003:2020::/home/openstack:/bin/bash

12、显示/etc/passwd文件中其默认shell为/bin/bash的用户;

[[email protected] ~]# grep  ".*\(/bin/bash\)$" /etc/passwd

root:x:0:0:root:/root:/bin/bash

admin:x:500:500::/home/admin:/bin/bash

user1:x:501:502::/home/user1:/bin/bash

user2:x:502:503::/home/user2:/bin/bash

centos:x:503:504::/home/centos:/bin/bash

root123:x:504:505::/home/root123:/bin/bash

mageia:x:1100:1100::/home/linux:/bin/bash

openstack:x:3003:2020::/home/openstack:/bin/bash

13、找出/etc/passwd文件中的一位数或两位数;

[[email protected] ~]# grep -o "\<[0-9]\{2,3\}\>" /etc/passwd

12

10

14

11

12

100

13

30

14

50

99

99

14、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;

[[email protected] ~]# grep "^#[[:space:]]\+[^[:space:]]" /etc/rc.d/rc.sysinit

# /etc/rc.d/rc.sysinit - run once at boot time

# Taken in part from Miquel van Smoorenburg‘s bcheckrc.

# Check SELinux status

# Print a text banner.

# Only read this once.

# Initialize hardware

# Set default affinity

15、打出netstat -tan命令执行结果中以‘LISTEN’,后或跟空白字符结尾的行;

[[email protected] ~]# netstat -tan | grep ".*LISTEN[[:space:]]\+$"

tcp        0      0 0.0.0.0:111                 0.0.0.0:*                   LISTEN

tcp        0      0 0.0.0.0:39476               0.0.0.0:*                   LISTEN

tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN

tcp        0      0 127.0.0.1:631               0.0.0.0:*                   LISTEN

tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN

tcp        0      0 :::111                      :::*                        LISTEN

tcp        0      0 :::53232                    :::*                        LISTEN

16、添加用户bash, testbash, basher, nologin (此一个用户的shell为/sbin/nologin),而后找出当前系统上其用户名和默认shell相同的用户的信息;

[[email protected] ~]# grep "^\([[:alnum:]]\+\).*\1$" /etc/passwd

sync:x:5:0:sync:/sbin:/bin/sync

shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown

halt:x:7:0:halt:/sbin:/sbin/halt

nobody:x:99:99:Nobody:/:/sbin/nologin

ntp:x:38:38::/etc/ntp:/sbin/nologin

nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin

bash:x:3005:3005::/home/bash:/bin/bash

basher:x:3007:3007::/home/basher:/bin/bash

nologin:x:3008:3008::/home/nologin:/sbin/nologin

时间: 2024-08-24 17:47:46

Linux命令使用的相关文章

linux命令格式,获取帮助及其目录结构简要理解

我们都知道,一台计算机要是没通电,和一堆废铁没什么区别.那么,通电开机进入系统后,会进入交互界面,等待用户操作,人与计算机交互界面有两种: GUI:图形用户接口.如我们平时使用的Windows  ,linux的X window,有KDE和GOME. CLI:命令行接口,使用的SHELL类型有bash ,csh,tcshell,zshell等. 例如:[[email protected] ~]# commandbin root:当前登录的用户名. dxlcentOS:当前主机的主机名.@是一个分隔

linux 命令 及学习进度综合整理

linux  命令  及学习进度综合整理 pwd 查看当前所在位置 cd  跳转到什么什么目录 ls  显示所有文件和目录 ls -l  显示目录详细信息 cd ..  返回上一级 vi  lnany.txt  创建一个文件 vi  .lnany.txt    创建一个隐藏文件 vim 是 vi 的升级版 功能更多 出现 -bash: vim: command not found 的解决办法 i. 那么如何安裝 vim 呢?输入rpm -qa|grep vim 命令, 如果 vim 已经正确安裝

9个使用时必须时刻警惕的Linux命令

Linux shell/terminal命令非常强大,即使一个简单的命令就可能导致文件夹.文件或者路径文件夹等被删除.为了避免这样的事情发生,我们应该时刻注意PHP代码&命令,今天为大家带来9个必须时刻警惕的Linux命令&代码. Linux shell/terminal 命令非常强大,即使一个简单的命令就可能导致文件夹.文件或者路径文件夹等被删除. 在一些情况下,Linux 甚至不会询问你而直接执行命令,导致你丢失各种数据信息. 一般来说在 Web 上推荐新的 Linux 用户执行这些命

Linux命令之scp

Linux命令之scp 功能说明 scp 是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且 scp传输是加密的.可能会稍微影响一下速度.当你服务器硬盘变为只读 read only system时,用scp可以帮你把文件移出来.另 外,scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了.虽然 rsync比scp会快一点,但当小文件众多的情况 下,rsync会导致硬盘I/O非常高

linux命令--top命令&free命令

top命令是用来查看系统性能的工具,能够实时显示各个进程的状况,包括进程ID.内存占用率.CPU占用率等. top - 23:12:04 up 79 days,  8:14,  1 user,  load average: 0.00, 0.01, 0.05 Tasks: 573 total,   2 running, 571 sleeping,   0 stopped,   0 zombie Cpu(s):  0.2%us,  0.4%sy,  0.0%ni, 99.5%id,  0.0%wa,

linux命令学习笔记

操作文件和目录: copy: $ cp file1 file2 $ cp -r dir1 dir2 move: $ mv file .. $ mv file dir/ rename: $ mv file1 file2 $ mv dir1 dir2 # dir2如果存在,则为移动操作 remove: $ rm file $ rm -r dir 创建文件: $ touch a.txt $ >a.txt 创建目录: $ mkdir dir 查看文件: #一般 $ cat file #查看文件类型: $

cv:显示Linux命令运行进度

cv: 显示 cp.mv 等命令的进度 2014-07-14 By toy Posted in Apps Edit on GitHub 在 Linux 系统中 , 大多数命令从来都是信奉 “ 沉默是金 ” 的准则 , 所以当我们利用 cp 复制文件的时候并不能看到所谓的进度条 . 如果你在意这一点 , 那么不妨来用用 cv. cv 是 Coreutils Viewer, 它能够显示传输数据的进度 , 包括百分比 . 大小 . 以及速率等信息 .cv 支持 coreutils 中的基本命令 , 比

三个网站让你成为Linux命令行高手

[转载自http://www.linuxeden.com/html/news/20091119/69183.html] Linux的命令行是通向Linux高级应用的必经之路,Linux系统管理员.开发者都是学习对象.Susan Linton向我们推荐了三个学习Linux命令行的网站,现在介绍给大家: 1. LinuxCommand LinuxCommand是一个学习Linux命令行最好的网站之一.网站分为:学习Shell.写Shell脚本.脚本库.超级MAN页面. 2. O'Reilly的Lin

linux 命令解析2

基本命令  uname -a -s hostname显示主机名若是要永久生效,则编辑以下文件  #vim /etc/sysconfig/network    ssh远程登录#ssh 10.1.1.54 (是以root用户登录的)  #ssh [email protected](是以tom身份登录)  #ssh -Y 10.1.1.54(可以启动图形界面的远程登陆) scp远程拷贝  #scp 10.1.1.54:/etc/passwd /tmp/test(将目的地址10.1.1.54上的/etc

Windows下使用linux命令

我参阅了这份文章: 让windows cmd也用上linux命令 原文时间有点久了,Cygwin也更新了... 所以我的做法简单了很多... 到Cygwin官网下载安装包:https://cygwin.com/install.html 一路安装下去... 假如安装路径是:C:\cygwin64 那么就在环境变量Path后面加上C:\cygwin64\bin 好了,完成了,没别的了 觉得太简单了?那我补充下,Cygwin官网下载下来的不能叫安装包,叫引导程序比较合适.英文好的可以看该页面的Q&A,