一篇文章入门Linux——搞定后端面试

Linux学习笔记

同样的MD格式,别的平台直接上传解析,CSDN每次还要对几十张图片修修改改,我快放弃这个平台了!

1. Linux简介

简介

Linux 内核最初只是由芬兰人林纳斯·托瓦兹(Linus Torvalds)在赫尔辛基大学上学时出于个人爱好而编写的。

Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 UNIX 的多用户、多任务、支持多线程和多 CPU 的操作系统。

Linux 能运行主要的 UNIX 工具软件、应用程序和网络协议。它支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

发行版

Linux 的发行版说简单点就是将 Linux 内核与应用软件做一个打包。

目前市面上较知名的发行版有:Ubuntu、RedHat、CentOS、Debian、Fedora、SuSE、OpenSUSE、Arch Linux、SolusOS 等。

Linux和Windows的对比

一篇文章入门Linux——搞定后端面试_第1张图片

2. Linux的目录结构

登录系统后,在终端输入:

ls /

你会看到以下图示:

mark

树状目录结构为:

有关目录的解释:

  • /bin:

    bin是Binary的缩写,/bin 放置的是在单人维护模式下还能够被操作的指令。在/bin底下的指令可以被root与一般账号所使用,主要有:cat, chmod, chown, date, mv, mkdir, cp, bash 等等常用的指令。

  • /boot:

    这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。

  • /dev:

    dev是Device(设备)的缩写, 该目录下存放的是Linux的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的。因为Linux中一切皆文件!

  • /etc:

    这个目录用来存放所有的系统管理所需要的配置文件和子目录。例如人员的账号密码文件、 各种服务的启始档等等。一般来说,这个目录下的各文件属性是可以让一般使用者查阅的, 但是只有 root 有权力修改。

  • /home:

    用户的主目录,在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的,比如在我的系统中只有cheerway这一个用户。

    • ~:代表目前这个用户的目录

mark

  • /lib:

    这个目录存放着系统最基本的动态链接共享库,其作用类似于Windows中的DLL文件。几乎所有的应用程序都要使用到这些共享库。

  • /lost+found:

    这个目录一般是空的,当系统非法关机以后,这里就存了一些文件。也就是说当文件系统发生错误时,这里就遗留了一些片段。

  • /media:

    linux 系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。

  • /mnt:

    系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在/mnt/上,然后进入该目录就可以查看光驱里的内容了

  • /opt:

    这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。不过有的人喜欢把软件放在usr/local。这个因人而异吧。

  • /proc:

    **这个目录本身是一个虚拟文件系统(virtual filesystem)!**他放置的数据都是在内存当中, 例如系统核心、进程信息(process)、周边装置的状态及网络状态等等。因为这个目录下的数据都是在内存当中, 所以本身不占任何硬盘空间啊!比较重要的文件例如:/proc/cpuinfo, /proc/dma, /proc/interrupts, /proc/ioports, /proc/net/等等。

    这个目录的内容不在硬盘上而是在内存里,我们也可以直接修改里面的某些文件,比如可以通过下面的命令来屏蔽主机的ping命令,使别人无法ping你的机器:

    echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
    

    进入该目录下,输入如下命令可以一窥cpuinfo文件的内容,但是具体内容我也看不懂/(ㄒoㄒ)/~~:

    cat cpuinfo
    

一篇文章入门Linux——搞定后端面试_第2张图片

  • /root:

    该目录为系统管理员,也称作超级权限者的用户主目录。

  • /sbin:

    s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序。放在/sbin 底下的为开机过程中所需要的,里面包括了开机、修复、还原系统所需要的指令。 至于某些服务器软件程序,一般则放置到/usr/sbin/当中。至于本机自行安装的软件所产生的系统执行文件(system binary),则放置到/usr/local/sbin/当中了。常见的指令包括:fdisk, fsck, ifconfig, mkfs 等等。

  • /selinux:

    这个目录是Redhat和CentOS所特有的目录,Selinux是一个安全机制,类似于Windows的防火墙,但是这套机制比较复杂,而这个目录就是用来存放Selinux相关的文件的。

  • /srv:

    该目录存放一些服务启动之后需要提取的数据。

  • /sys:

    这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs 。

    sysfs文件系统集成了下面3种文件系统的信息:针对进程信息的proc文件系统针对设备的devfs文件系统以及针对伪终端的devpts文件系统

    该文件系统是内核设备树的一个直观反映。

    当一个内核对象被创建的时候,对应的文件和目录也在内核对象子系统中被创建。

  • /tmp:
    这个目录是用来存放一些临时文件的。

  • /usr:
    这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于windows下的program files目录。

  • /usr/bin:
    系统用户使用的应用程序。

  • /usr/sbin:
    超级用户使用的比较高级的管理程序和系统守护程序。

  • /usr/src:
    内核源代码默认的放置目录。

  • /var:
    这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。

  • /run:
    是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。如果你的系统上有 /var/run 目录,应该让它指向 run。

在 Linux 系统中,有几个目录是比较重要的,平时需要注意不要误删除或者随意更改内部文件。

  • /etc: 上边也提到了,这个是系统中的配置文件,如果你更改了该目录下的某个文件可能会导致系统不能启动。

  • /bin, /sbin, /usr/bin, /usr/sbin: 这是系统预设的执行文件的放置目录,比如 ls 就是在/bin/ls 目录下的。

    值得提出的是,/bin, /usr/bin 是给系统用户使用的指令(除root外的通用户),而/sbin, /usr/sbin 则是给root使用的指令。

  • /var: 这是一个非常重要的目录,系统上跑了很多程序,那么每个程序都会有相应的日志产生,而这些日志就被记录到这个目录下,具体在/var/log 目录下,另外mail的预设放置也是在这里。

3. Linux文件基本属性

基本属性

Linux系统是一个典型的多用户系统,不同的用户有不同的地位,拥有不同的权限。为了保护系统的安全性,Linux系统对不同的用户访问同一文件的权限做了不同的规定。

可以使用ls -l或者ll命令查看一个文件的属性以及文件所属的用户和组,比如:

一篇文章入门Linux——搞定后端面试_第3张图片

实例中,boot文件的第一个属性用"d"表示。"d"在Linux中代表该文件是一个目录文件。

在Linux中第一个字符代表这个文件是目录、文件或链接文件等等。

  • 当为[ d ]则是目录
  • 当为[ - ]则是文件;
  • 若是[ l ]则表示为链接文档(link file);
  • 若是[ b ]则表示为装置文件里面的可供储存的接口设备(可随机存取装置);
  • 若是[ c ]则表示为装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)。

接下来的字符中,以三个为一组,且均为『rwx』 的三个参数的组合。其中,[ r ]代表可读(read)、[ w ]代表可写(write)、[ x ]代表可执行(execute)。 要注意的是,这三个权限的位置不会改变,如果没有权限,就会出现减号[ - ]而已。

每个文件的属性由左边第一部分的10个字符来确定(如下图):

一篇文章入门Linux——搞定后端面试_第4张图片

对于文件来说,它都有一个特定的所有者,也就是对该文件具有所有权的用户。

同时,在Linux系统中,用户是按组分类的,一个用户属于一个或多个组。

文件所有者以外的用户又可以分为文件所有者的同组用户和其他用户。

因此,Linux系统按文件所有者、文件所有者同组用户和其他用户来规定了不同的文件访问权限。

对于 root 用户来说,一般情况下,文件的权限对其不起作用。

更改文件属性

  1. chgrp:更改文件属组

    语法:

    chgrp [-R] 属性组 文件名
    

    参数选项:

    • -R:递归更改文件属组,就是在更改某个目录文件的属组时,如果加上-R的参数,那么该目录下的所有文件的属组都会更改。
  2. chown:更改文件属主,也可以同时更改其属组

    语法:

    chown [-R] 属主名 文件名
    chown [-R] 属主名:属组名 文件名
    

    **举例:**进入 /root 目录(~)将install.log的拥有者改为bin这个账号:

    [root@www ~] cd ~
    [root@www ~]# chown bin install.log
    [root@www ~]# ls -l
    -rw-r--r--  1 bin  users 68495 Jun 25 08:53 install.log
    

    将install.log的拥有者与群组改回为root:

    [root@www ~]# chown root:root install.log
    [root@www ~]# ls -l
    -rw-r--r--  1 root root 68495 Jun 25 08:53 install.log
    
  3. chmod:更改文件9个属性

    Linux文件属性有两种设置方法,一种是数字,一种是符号。

    Linux文件的基本权限就有九个,分别是owner/group/others三种身份各有自己的read/write/execute权限。

    先复习一下刚刚上面提到的数据:文件的权限字符为:『-rwxrwxrwx』, 这九个权限是三个三个一组的!其中,我们可以使用数字来代表各个权限,各权限的分数对照表如下:

    • r:4
    • w:2
    • x:1

    每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的,例如当权限为: [-rwxrwx—] 分数则是:

    • owner = rwx = 4+2+1 = 7
    • group = rwx = 4+2+1 = 7
    • others= — = 0+0+0 = 0

    所以等一下我们设定权限的变更时,该文件的权限数字就是770啦!变更权限的指令chmod的语法是这样的:

    chmod [-R] xyz 文件名或目录
    

    选项与参数:

    • xyz:分别代表三个数字,为rwx属性值的相加
    • -R:进行递归(recursive)的持续变更,亦即连同次目录下的所有文件都会变更

    举例来说,如果要将一个文件的权限更改为 -rwxr-xr-- 的话,那么权限的分数就是:

    [4+2+1] [4+0+1] [4+0+0] = 754。

    符号类型改变文件权限

    还有一个改变权限的方法,从之前的介绍中我们可以发现,基本上就九个权限分别是:

    • (1)user
    • (2)group
    • (3)others

    那么我们就可以使用 u, g, o 来代表三种身份的权限!

    此外, a 则代表 all,即全部的身份。读写的权限可以写成 r, w, x,也就是可以使用下表的方式来看:

    chmod u + 加入 r 文件名/目录
    g - 除去 w
    o = 设定 x
    a

    如果我们需要将文件权限设置为 -rwxr-xr– ,可以使用 chmod u=rwx,g=rx,o=r 文件名 来设定:

    #  touch test1    // 创建 test1 文件
    # ls -al test1    // 查看 test1 默认权限
    -rw-r--r-- 1 root root 0 Nov 15 10:32 test1
    # chmod u=rwx,g=rx,o=r  test1    // 修改 test1 权限
    # ls -al test1
    -rwxr-xr-- 1 root root 0 Nov 15 10:32 test1
    

    而如果是要将权限去掉而不改变其他已存在的权限呢?例如要拿掉全部人的可执行权限,则:

    #  chmod  a-x test1
    # ls -al test1
    -rw-r--r-- 1 root root 0 Nov 15 10:32 test1
    

4. Linux文件与目录管理

Linux的目录结构为树状结构,最顶级的目录为根目录 /。

其他目录通过挂载可以将它们添加到树中,通过解除挂载可以移除它们。

在开始本教程前我们需要先知道什么是绝对路径与相对路径。

  • 绝对路径:
    路径的写法,由根目录 / 写起,例如: /usr/share/doc 这个目录。
  • 相对路径:
    路径的写法,不是由 / 写起,例如由 /usr/share/doc 要到 /usr/share/man 底下时,可以写成: cd …/man 这就是相对路径的写法啦!

处理文件的常用指令

  • ls: 列出目录及文件名
  • cd:切换目录
  • pwd:显示目前的目录
  • mkdir:创建一个新的目录
  • rmdir:删除一个空的目录
  • cp: 复制文件或目录
  • rm: 移除文件或目录
  • mv: 移动文件与目录,或修改文件与目录的名称

可以使用 man [命令] 来查看各个命令的使用文档,如 :man cp。

ls:列出目录

语法:

[root@www ~]# ls [-aAdfFhilnrRSt] 目录名称
[root@www ~]# ls [--color={never,auto,always}] 目录名称
[root@www ~]# ls [--full-time] 目录名称

选项与参数:

  • -a :全部的文件,连同隐藏文件( 开头为 . 的文件) 一起列出来(常用)
  • -d :仅列出目录本身,而不是列出目录内的文件数据(常用)
  • -l :长数据串列出,包含文件的属性与权限等等数据;(常用)

一篇文章入门Linux——搞定后端面试_第5张图片

cd:切换目录

cd是Change Directory的缩写,这是用来变换工作目录的命令。

语法:

cd [相对路径或绝对路径]

pwd :显示目前所在的目录

pwd 是 Print Working Directory 的缩写,也就是显示目前所在目录的命令。

语法:

pwd [-P]

选项与参数:

  • -P :显示出确实的路径,而非使用连结 (link) 路径。

实例:单纯显示出目前的工作目录:

mark

上图就直接显示了目录本身,下面是一个带参数的实例:

[root@www ~]# cd /var/mail   <==注意,/var/mail是一个连结档
[root@www mail]# pwd
/var/mail         <==列出目前的工作目录
[root@www mail]# pwd -P
/var/spool/mail   <==怎么回事?有没有加 -P 差很多~
[root@www mail]# ls -ld /var/mail
lrwxrwxrwx 1 root root 10 Sep  4 17:54 /var/mail -> spool/mail
# 看到这里应该知道为啥了吧?因为 /var/mail 是连结档,连结到 /var/spool/mail 
# 所以,加上 pwd -P 的选项后,会不以连结档的数据显示,而是显示正确的完整路径啊!

mkdir:创建目录

语法:

mkdir [-mp] 目录名称

选项与参数:

  • -m :配置文件的权限喔!直接配置,不需要看默认权限 (umask) 的脸色~
  • -p :帮助你直接将所需要的目录(包含上一级目录)递归创建起来!

实例:

mark

加了 -p 的选项,可以自行帮你创建多层目录

也可以在创建目录的时候指定权限,创建权限为 rwx–x--x 的目录:

一篇文章入门Linux——搞定后端面试_第6张图片

rmdir:删除空的目录

语法:

rmdir [-p] 目录名称

选项与参数:

  • **-p :**连同上一级『空的』目录也一起删除

不过要注意的是,这个 rmdir 仅能删除空的目录,你可以使用 rm 命令来删除非空目录。

cp:复制文件或者目录

语法:

cp [-adfilprsu] 来源档(source) 目标档(destination)
cp [options] source1 source2 source3 .... directory

选项与参数:

  • **-a:**相当於 -pdr 的意思,至於 pdr 请参考下列说明;(常用)
  • **-d:**若来源档为连结档的属性(link file),则复制连结档属性而非文件本身;
  • **-f:**为强制(force)的意思,若目标文件已经存在且无法开启,则移除后再尝试一次;
  • **-i:**若目标档(destination)已经存在时,在覆盖时会先询问动作的进行(常用)
  • **-l:**进行硬式连结(hard link)的连结档创建,而非复制文件本身;
  • **-p:**连同文件的属性一起复制过去,而非使用默认属性(备份常用);
  • **-r:**递归持续复制,用於目录的复制行为;(常用)
  • **-s:**复制成为符号连结档 (symbolic link),亦即『捷径』文件;
  • **-u:**若 destination 比 source 旧才升级 destination !

值得一提的是,在修改任何重要的文件之前利用cp进行备份是非常必要的

rm:删除文件或者目录

终于迎来了删库跑路用的命令!

语法:

rm [-fir] 文件或者目录

选项与参数:

  • -f :就是 force 的意思,忽略不存在的文件,不会出现警告信息;
  • -i :互动模式,在删除前会询问使用者是否动作
  • -r :递归删除啊!最常用在目录的删除了!这是非常危险的选项!!!

如果你想强制递归删除某个东西,比如你公司的数据库文件,可以使用:

rm -rf 数据库文件夹

做完这一步操作,恭喜你可以跳槽加薪了!

mv:移动文件与目录或者修改名称

语法:

mv [-fiu] source destination
mv [options] source1 source2 source3 .... directory

选项与参数:

  • -f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;
  • -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
  • -u :若目标文件已经存在,且 source 比较新,才会升级 (update)

Linux文件内容查看

Linux系统中使用以下命令来查看文件的内容:

  • cat 由第一行开始显示文件内容
  • tac 从最后一行开始显示,可以看出 tac 是 cat 的倒着写!
  • nl 显示的时候,顺道输出行号!
  • more 一页一页的显示文件内容
  • less 与 more 类似,但是比 more 更好的是,他可以往前翻页!
  • head 只看头几行
  • tail 只看尾巴几行

cat:由第一行开始显示文件内容

语法:

cat [-AbEnTv]

选项与参数:

  • -A :相当於 -vET 的整合选项,可列出一些特殊字符而不是空白而已;
  • -b :列出行号,仅针对非空白行做行号显示,空白行不标行号!
  • -E :将结尾的断行字节 $ 显示出来;
  • -n :列印出行号,连同空白行也会有行号,与 -b 的选项不同;
  • -T :将 [tab] 按键以 ^I 显示出来;
  • -v :列出一些看不出来的特殊字符

实例:

一篇文章入门Linux——搞定后端面试_第7张图片

tac:从最后一行开始查看

如果你仔细看的话,会发现tac其实是cat反过来,他们表达的意思也是相反的

示例:

一篇文章入门Linux——搞定后端面试_第8张图片

确实是倒过来了,很迷惑这个命令的作用是什么?

nl:显示行号

语法:

nl [-bnw] 文件

选项与参数:

  • -b :指定行号指定的方式,主要有两种:
    -b a :表示不论是否为空行,也同样列出行号(类似 cat -n);
    -b t :如果有空行,空的那一行不要列出行号(默认值);
  • -n :列出行号表示的方法,主要有三种:
    -n ln :行号在荧幕的最左方显示;
    -n rn :行号在自己栏位的最右方显示,且不加 0 ;
    -n rz :行号在自己栏位的最右方显示,且加 0 ;
  • -w :行号栏位的占用的位数。

示例:
一篇文章入门Linux——搞定后端面试_第9张图片

more:一页一页翻动

示例:

一篇文章入门Linux——搞定后端面试_第10张图片

在 more 这个程序的运行过程中,你有几个按键可以按的:

  • 空白键 (space):代表向下翻一页;
  • Enter :代表向下翻『一行』;
  • /字串 :代表在这个显示的内容当中,向下搜寻『字串』这个关键字;
  • :f :立刻显示出档名以及目前显示的行数;
  • q :代表立刻离开 more ,不再显示该文件内容。
  • b 或 [ctrl]-b :代表往回翻页,不过这动作只对文件有用,对管线无用。

高级用法:

more +3 test.log  #从第三行开始显示
more -4 test.log  #每屏显示四行内容
more +/java test.log  #从第一个java关键字处前两行开始显示

less:一页一页翻动

less 工具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能极其强大。less 的用法比起 more 更加的有弹性。在 less 里头可以拥有更多的搜索功能,不止可以向下搜,也可以向上搜。

less运行时可以输入的命令有:

  • 空白键 :向下翻动一页;
  • [pagedown]:向下翻动一页;
  • [pageup] :向上翻动一页;
  • /字串 :向下搜寻『字串』的功能;
  • ?字串 :向上搜寻『字串』的功能;
  • n :重复前一个搜寻 (与 / 或 ? 有关!)
  • N :反向的重复前一个搜寻 (与 / 或 ? 有关!)
  • q :离开 less 这个程序;

head:取出文件内容的开头部分

语法:

head [-n number] 文件名

示例:

mark

选项与参数:

  • -n :后面接数字,代表显示几行的意思

默认显示前十行

tail:取出文件末尾的内容

tail [-n number] 文件名

示例:

mark

选项与参数:

  • -n :后面接数字,代表显示几行的意思
  • -f :表示持续侦测后面所接的档名,要等到按下[ctrl]-c才会结束tail的侦测

>指令和>>指令

> 输出重定向:会将原来的文件内容覆盖

>> 追加,不会覆盖原来的内容,而是追加在文件尾部

示例:

一篇文章入门Linux——搞定后端面试_第11张图片

再次使用ls -l > a.txt ,这次不加-a参数:

一篇文章入门Linux——搞定后端面试_第12张图片

再次输入ls -al >> a.txt

一篇文章入门Linux——搞定后端面试_第13张图片

示例:将文件1的内容覆盖到文件2

cat 文件1 > 文件2

echo指令

语法:

echo [options] 输出的内容

示例:使用echo指令输出环境变量

echo $PATH

mark

history指令

查看已经执行过的历史命令,也可以执行历史命令

语法:

history n

n表示要显示的个数

示例:最近使用的全部指令

一篇文章入门Linux——搞定后端面试_第14张图片

示例:最近使用的五条指令

mark

示例:执行标号为17的指令

mark

find指令

find指令将从指定目录向下递归地遍历其各个子目录,将满足条件地文件或者目录显示在终端。

语法:

find 搜索范围 [选项]

选项说明:

选项 功能
-name<查询方式> 按照指定的文件名查找模式查找文件
-user<用户名> 查找属于指定用户名的所有文件
-size<文件大小> 按照指定的文件大小查找文件

示例:根据文件名查找文件

mark

根据拥有者查找文件

mark

查找整个Linux系统中大于20M的文件(+n 大于,-n小于,n等于)

一篇文章入门Linux——搞定后端面试_第15张图片

查找所有的.txt文件

一篇文章入门Linux——搞定后端面试_第16张图片

locate指令

locate 可以快速定位文件路径。locate指令利用事先建立好的系统中所有文件名称及其路径的locate数据库实现快速定位给定的文件。

locate无需遍历整个文件系统,所以速度非常快,为了保证查询结果的精确性,管理员必须定期更新locate数据库

语法:

locate 文件名

由于locate指令基于数据库进行查询,所以第一次运行前,必需使用updatedb指令创建数据库

示例:使用locate快速定位a.txt文件所在的目录

一篇文章入门Linux——搞定后端面试_第17张图片

5. Linux用户与用户组管理

Linux 用户管理

Linux 系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。

用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。

Linux 用户管理相关命令:

  • useradd 选项 用户名:添加用户账号
  • userdel 选项 用户名:删除用户帐号
  • usermod 选项 用户名:修改帐号
  • passwd 用户名:更改或创建用户的密码
  • passwd -S 用户名 :显示用户账号密码信息
  • passwd -d 用户名: 清除用户密码

useradd 命令用于 Linux 中创建的新的系统用户。useradd可用来建立用户帐号。帐号建好之后,再用passwd设定帐号的密码.而可用userdel删除帐号。使用useradd指令所建立的帐号,实际上是保存在 /etc/passwd文本文件中。

passwd命令用于设置用户的认证信息,包括用户密码、密码过期时间等。系统管理者则能用它管理系统用户的密码。只有管理者可以指定用户名称,一般用户只能变更自己的密码。

Linux 系统用户组的管理

每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同 Linux 系统对用户组的规定有所不同,如 Linux 下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。

用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。

Linux 系统用户组的管理相关命令:

  • groupadd 选项 用户组 :增加一个新的用户组
  • groupdel 用户组:要删除一个已有的用户组
  • groupmod 选项 用户组 : 修改用户组的属性

6. 压缩与解压缩命令

打包并压缩文件

Linux 中的打包文件一般是以.tar 结尾的,压缩的命令一般是以.gz 结尾的。而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般.tar.gz。 命令:tar -zcvf 打包压缩后的文件名 要打包压缩的文件 ,其中:

  • z:调用 gzip 压缩命令进行压缩
  • c:打包文件
  • v:显示运行过程
  • f:指定文件名

比如:假如 test 目录下有三个文件分别是:aaa.txt bbb.txt ccc.txt,如果我们要打包 test 目录并指定压缩后的压缩包名称为 test.tar.gz 可以使用命令:tar -zcvf test.tar.gz aaa.txt bbb.txt ccc.txttar -zcvf test.tar.gz /test/

解压压缩包

命令:tar [-xvf] 压缩文件

其中:x:代表解压

示例:

  • 将 /test 下的 test.tar.gz 解压到当前目录下可以使用命令:tar -xvf test.tar.gz
  • 将 /test 下的 test.tar.gz 解压到根目录/usr 下:tar -xvf test.tar.gz -C /usr(- C 代表指定解压的位置)

7. grep指令和管道符号 |

grep:过滤查找

管道符号:| 表示将前一个命令的处理结果输出传递后后面的命令处理

语法:

grep [选项] 查找内容 源文件

选项说明:

  • -n:显示匹配行及行号
  • -i:忽略字母大小写

示例:在b.txt文件中,查找yes所在行并显示行号

一篇文章入门Linux——搞定后端面试_第18张图片

8. 磁盘情况查询命令

查询磁盘整体使用情况

语法:

df -lh

一篇文章入门Linux——搞定后端面试_第19张图片

查看指定目录的磁盘占用情况

语法:

du -h /目录

选项说明:

  • -s:指定目录占用的大小汇总
  • -h:带计量单位
  • -a:含文件
  • –max-depth=1 子目录深度
  • -c:列出明细的同时,增加汇总值

示例:查看/opt 目录的占用情况,深度为1

mark

一些实用指令

  1. 统计/home文件夹下文件的个数

mark

  1. 统计/home文件夹下文件夹的个数

mark

  1. 统计/home文件夹下的文件个数(或者文件夹个数),包含子文件夹里的

mark

  1. 以树状显示目录结构

    使用之前需要yum install tree才能使用tree命令!

wc命令用于计算字数。利用wc指令我们可以计算文件的Byte数、字数、或是列数,若不指定文件名称、或是所给予的文件名为"-",则wc指令会从标准输入设备读取数据。

语法:wc [-clw][--help][--version][文件...]

参数说明:

  • -c或–bytes或–chars 只显示Bytes数。
  • -l或–lines 只显示行数。
  • -w或–words 只显示字数。
  • –help 在线帮助。
  • –version 显示版本信息。

在默认的情况下,wc将计算指定文件的行数、字数,以及字节数。使用的命令为:

wc filename

结果是:3 92 598 testfile # testfile文件的行数为3、单词数92、字节数598

9. 进程管理

进程的基本介绍

一篇文章入门Linux——搞定后端面试_第20张图片

显示系统执行的进程

查看进程使用的命令是:ps,一般来说使用的参数是ps -aux

  • -a:显示所有的进程信息
  • -u:以用户的格式显示进程信息
  • -x:显示后台进程运行的参数

示例:

一篇文章入门Linux——搞定后端面试_第21张图片

参数详细说明:

一篇文章入门Linux——搞定后端面试_第22张图片

示例:以全格式显示当前所有的进程,查看进程的父进程

一篇文章入门Linux——搞定后端面试_第23张图片

参数详细说明:

一篇文章入门Linux——搞定后端面试_第24张图片

终止进程kill和killall

语法:

kill [选项] 进程号 (通过进程号杀死进程)
killall 进程名称 (通过名称杀死进程,也支持通配符,这在系统因负载过大而变慢时很有用)

选项说明:

  • -9:强迫进程立即停止

查看进程树pstree

语法:

pstree [选项]

选项说明:

  • -p:显示进程的PID
  • -u:显示进程的所属用户

一篇文章入门Linux——搞定后端面试_第25张图片

动态监控进程

介绍

top与ps命令很相似。他们都是用来显示正在执行的进程。top与ps最大的不同之处在于top在执行一段时间内可以更新正在运行的进程

top指令

语法:

top [选项]

选项说明:

  • -d 秒数:指定top指令每隔几秒更新,默认是3秒
  • -i:使top不显示任何闲置或者僵尸jinc
  • -p:通过指定监控进程的ID来监控特定的进程状态

交互操作说明:

  • P:以CPU使用率排序,默认就是此项
  • M:以内存的使用率排序
  • N:以PID排序
  • q:退出指令

示例:输入top命令

一篇文章入门Linux——搞定后端面试_第26张图片

然后再输入”u“,再输入用户名,即可监控指定用户名的进程
一篇文章入门Linux——搞定后端面试_第27张图片
输入”k“,在输入要结束的进程ID,即可杀死进程

示例:指定10秒更新一次

top -d 10

查看网络情况netstat(重要!!!)

语法:

netstat [-anp] 

选项说明:

  • -an:按一定的顺序排列
  • -p:显示哪个进程在调用

示例:查看所有的网络连接

一篇文章入门Linux——搞定后端面试_第28张图片

示例:查看所有的tcp连接

一篇文章入门Linux——搞定后端面试_第29张图片

你可能感兴趣的:(Linux,linux,java,服务器)