• Linux学习笔记


    Linux学习报告

    安利一波(资源指路) ==》

    《Linux速查备忘手册》:下载链接: https://pan.baidu.com/s/1Xub98JU3rBIoYiUgn8AOgg 提取码:x6we

    一、linux介绍

    Linux,全称GNU/Linux,是一种免费使用和自由传播的类UNIX操作系统,其内核由[林纳斯·本纳第克特·托瓦兹于1991年10月5日首次发布,它主要受到Minix和Unix思想的启发,是一个基于POSIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的Unix工具软件、应用程序和网络协议。它支持32位和64位硬件。

    Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。Linux有上百种不同的发行版,如基于社区开发的debian、archlinux,和基于商业开发的Red Hat Enterprise Linux、SUSE、Oracle Linux等。

    二、Linux安装

    安装部署教程详见:https://blog.csdn.net/qq_44619675/article/details/125717240

    三、系统目录结构

    1、树状目录结构

    在Linux和Unix操作系统中,所有的文件目录都被组织为一个以根节点开始的倒置的树状结构。

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JR6hh3GK-1661498385876)(D:\培训笔记\学习报告\linux学习报告\1.png)]

    文件系统的最顶层是由根目录开始的,系统使用 / 来表示根目录。在根目录之下的既可以是目录,也可以是文件,而每一个目录中又可以包含子目录文件。如此反复就可以构成一个庞大的文件系统。

    在Linux文件系统中有两个特殊的目录,一个用户所在的工作目录,也叫当前目录,可以使用一个点 . 来表示;另一个是当前目录的上一级目录,也叫父目录,可以使用两个点 … 来表示。即:

    ① ./ : 代表当前的目录,也可以使用 ./ 来表示。

    ② … : 代表上一层目录,也可以 …/ 来代表。

    如果一个目录或文件名以一个点 . 开始,表示这个目录或文件是一个隐藏目录或文件(如:.bashrc)。即以默认方式查找时,不显示该目录或文件。

    2、目录结构的解释

    (1)/bin : bin 是 Binaries (二进制文件) 的缩写, 这个目录存放着最经常使用的命令。

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

    (3)/dev : dev 是 Device(设备) 的缩写, 该目录下存放的是 Linux 的外部设备,在 Linux 中访问设备的方式和访问文件的方式是相同的。

    (4)/etc : etc 是 Etcetera(等等) 的缩写,这个目录用来存放所有的系统管理所需要的配置文件和子目录。

    注:/etc 是系统中的配置文件,如果你更改了该目录下的某个文件可能会导致系统不能启动,所以改动时要慎重。

    (5)/home : 用户的主目录,在 Linux 中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。

    (6)/lib : lib 是 Library(库) 的缩写这个目录里存放着系统最基本的动态连接共享库,其作用类似于 Windows 里的 DLL 文件。几乎所有的应用程序都需要用到这些共享库。

    (7)/lost+found : 这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。

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

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

    (10)/opt : opt 是 optional(可选) 的缩写,这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。

    (11)/proc

    proc 是 Processes(进程) 的缩写,/proc 是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。

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

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

    (12)/root : 该目录为系统管理员,也称作超级权限者的用户主目录。

    (13)/sbin : s 就是 Super User 的意思,是 Superuser Binaries (超级用户的二进制文件) 的缩写,这里存放的是系统管理员使用的系统管理程序。

    (14)/selinux : 这个目录是 Redhat/CentOS 所特有的目录,Selinux 是一个安全机制,类似于 windows 的防火墙,但是这套机制比较复杂,这个目录就是存放selinux相关的文件的。

    (15)/srv : 该目录存放一些服务启动之后需要提取的数据。

    (16)/sys

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

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

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

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

    (17)/tmp : tmp 是 temporary(临时) 的缩写这个目录是用来存放一些临时文件的。

    (18)/usr : usr 是 unix shared resources(共享资源) 的缩写,这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于 windows 下的 program files 目录。

    (19)/usr/bin : 系统用户使用的应用程序。

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

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

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

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

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

    小结:

    系统启动必须:/boot 、 /etc 、/lib 、/sys

    指令集合: /bin 、/sbin

    外部文件管理: /dev 、/media 、/mnt

    临时文件:/run 、/lost+found 、/tmp

    账户: /root 、/home 、/usr 、/usr/bin 、/usr/sbin 、/usr/src

    运行过程中要用:/var 、/proc

    扩展用:/opt 、/srv

    四、文件和目录管理

    1、文件的基本属性

    Linux 系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。

    为了保护系统的安全性,Linux 系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。

    在 Linux 中我们通常使用以下两个命令来修改文件或目录的所属用户与权限:

    • chown (change owner) : 修改所属用户和组。
    • chmod (change mode) : 修改用户的权限。

    在linux操作系统中,我们可以使用ll或者ls -l 命令来显示一个文件的属性以及文件所属的用户和组,如:

    [root@localhost bin]ls -l
    
    • 1

    在linux中的第一个字符代表的是这个文件是目录、文件或者链接文件等等,即:

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

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

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WCw7zQl5-1661498385877)(D:\培训笔记\学习报告\linux学习报告\2.png)]

    user permissions : 属主

    group permissions : 属组

    other(everyone) permissions : 其他用户

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

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BO4qcLbY-1661498385878)(D:\培训笔记\学习报告\linux学习报告\3.png)]

    从左至右用 0-9 这些数字来表示。

    • 第 0 位确定文件类型
    • 第 1-3 位确定属主(该文件的所有者)拥有该文件的权限
    • 第4-6位确定属组(所有者的同组用户)拥有该文件的权限
    • 第7-9位确定其他用户拥有该文件的权限

    第 1、4、7 位表示读权限,如果用 r 字符表示,则有读权限,如果用 - 字符表示,则没有读权限;

    第 2、5、8 位表示写权限,如果用 w 字符表示,则有写权限,如果用 - 字符表示没有写权限;

    第 3、6、9 位表示可执行权限,如果用 x 字符表示,则有执行权限,如果用 - 字符表示,则没有执行权限。

    2、更改文件属性

    (1)chgrp : 更改未见属组

    chgrp [-R] 属组名 文件名
    
    • 1

    (2)chown : 更改文件属主,也可以同时更改文件属组

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

    (3)chmod : 更改文件9个属性

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

    Linux 文件的基本权限有9个,分别是 owner/group/others(拥有者/组/其他) 三种身份各有自己的 read/write/execute 权限。

    ① 数字方式更改权限

    用数字代表各权限,则各权限的分数对照表为:

    权限二进制值八进制值描述
    0000没有任何权限
    r–1004只有读取权限
    -w-0102只有写入权限
    –x0011只有执行权限
    rw-1106有读取和写入权限
    r-x1015有读取和执行权限
    -wx0113有写入和执行权限
    rwx1118有读取、写入和执行权限

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

    • owner = rwx = 4 + 2 + 1 = 7
    • group = r-x = 4 + 0 +1 = 5
    • others = — = 0 + 0 + 0 = 0

    所以通过数字方式更改权限时,该文件的权限数字就是750,变更权限的指令语法为:

    chmod [-R] xyz 文件或目录
    
    • 1
    • xyz : 表示的就是上面提到的权限数字750

    ② 符号方式更改权限

    user : 用户

    group : 组

    others : 其他用户

    那么我们就可以使用ugo 来代表三种身份的权限。

    此外,a 代表all,即全部的身份。

    那么通过符号方式更改权限的语法组成为:

    指令身份操作权限授权目标
    chmodu
    g
    o
    a
    +(加入)
    -(除去)
    =(设定)
    r
    w
    x
    文件或目录

    例如:

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

    # touch test1   //创建test1文件
    # ls -al test1    //查看test1的默认权限
    -rw-r--r-- 1 root root 0 Nov 15 12:12 test1
    # chmod u=rwx,g=r-x,o=r test1  //修改test1权限
    # ls -al test1
    -rwxr-xr-- 1 root root 0 Nov 15 12:15 test1
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    3、文件与目录管理
    (1)处理目录常用命令
    • ls(英文全拼:list files): 列出目录及文件名
    • cd(英文全拼:change directory):切换目录
    • pwd(英文全拼:print work directory):显示目前的目录
    • mkdir(英文全拼:make directory):创建一个新的目录
    • rmdir(英文全拼:remove directory):删除一个空的目录
    • cp(英文全拼:copy file): 复制文件或目录
    • rm(英文全拼:remove): 删除文件或目录
    • mv(英文全拼:move file): 移动文件与目录,或修改文件与目录的名称
    (2)Linux文件内容查看常用命令
    • cat 由第一行开始显示文件内容
    • tac 从最后一行开始显示,可以看出 tac 是 cat 的倒着写!
    • nl 显示的时候,顺道输出行号!
    • more 一页一页的显示文件内容
    • less 与 more 类似,但是比 more 更好的是,他可以往前翻页!
    • head 只看头几行
    • tail 只看尾巴几行

    五、用户和用户组管理

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

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

    • 每个用户账号都拥有一个唯一的用户名和各自的口令。

    • 用户在登录时键入正确的用户名和口令后,就能够进入系统和自己的主目录。

    实现用户账号的管理,要完成的工作主要有如下几个方面:

    • 用户账号的添加、删除与修改。
    • 用户口令的管理。
    • 用户组的管理。
    1、Linux系统用户账号的管理

    用户账号的管理工作主要涉及到用户账号的添加、修改和删除。

    添加用户账号就是在系统中创建一个新账号,然后为新账号分配用户号、用户组、主目录和登录Shell等资源。刚添加的账号是被锁定的,无法使用。

    (1)添加新的用户账号使用useradd命令

    其语法如下:

    useradd 选项 用户名
    
    • 1
    • 选项

      • -c comment 指定一段注释性描述。

      • -d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。

      • -g 用户组 指定用户所属的用户组。

      • -G 用户组,用户组 指定用户所属的附加组。

      • -s Shell文件 指定用户的登录Shell。

      • -u 用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。

    • 用户名

      指定新账号的登录名例如:

    例如:

    # useradd -d /home/hhh -m hhh
    
    • 1

    此命令创建了一个用户hhh,其中-d和-m选项用来为登录名hhh产生一个主目录 /home/hhh(/home为默认的用户主目录所在的父目录)。

    (2)删除账号

    如果一个用户的账号不再使用,可以从系统中删除。删除用户账号就是要将/etc/passwd等系统文件中的该用户从用户记录删除,必要时还删除用户的主目录。

    删除一个已有的用户账号使用userdel命令,其格式如下:

    userdel 选项 用户名
    
    • 1
    • 常用的选项是 -r ,它的作用是吧用户的主目录一起删除。

    例如:

    # userdel -r hhh
    
    • 1

    此命令删除用户hhhh在系统文件中(主要是/etc/passwd,/etc/shadow, /etc/grop等)的记录,同时删除用户的主目录。

    (3)修改账号

    修改用户账号就是根据实际情况更改用户的有关属性,如用户号、主目录、用户组、登录Shell等。

    修改已有用户的信息使用usermod命令,其格式如下:

    usermod 选项 用户名
    
    • 1
    • 常用的选项包括-c, -d, -m, -g, -G, -s, -u以及-o等,这些选项的意义与useradd命令中的选项一样,可以为用户指定新的资源值。

    • 另外,有些系统可以使用选项:-l 新用户名

      这个选项指定一个新的账号,即将原来的用户名改为新的用户名。

    例如:

    # usermod -s /bin/ksh -d /home/z -g developer hhh
    
    • 1

    此命令将用户hhh的登录Shell修改为ksh,主目录改为/home/z,用户组改为developer

    (4)用户口令的管理

    用户管理的一项重要内容是用户口令的管理。用户账号刚创建时没有口令,但是被系统锁定,无法使用,必须为其指定口令后才可以使用,即使是指定空口令。

    指定和修改用户口令的Shell命令是passwd。超级用户可以为自己和其他用户指定口令,普通用户只能用它修改自己的口令。命令的格式为:

    passwd 选项 用户名
    
    • 1

    可使用的选项:

    • -l 锁定口令,即禁用账号。
    • -u 口令解锁。
    • -d 使账号无口令。
    • -f 强迫用户下次登录时修改口令。

    注:如果默认用户名,则修改当前用户的口令。

    2、Linux系统用户组的管理
    (1)增加一个新的用户组

    使用groupadd 命令,其格式如下:

    groupadd 选项 用户组
    
    • 1

    可以使用的选项有:

    • -g GID 指定新用户租的组标识号(GID)
    • -o 一般与-g选项同时使用,表示新用户组的GID可以与系统已有用户组的GID相同。
    (2) 删除一个已有用户组

    使用groupdel 命令,其格式如下:

    groupdel  用户组
    
    • 1
    (3)修改用户组的属性

    使用groupmod 命令,其格式如下:

    groupmod 选项 用户组
    
    • 1

    常用的选项有:

    • -g GID 为用户组指定新的组标识号。
    • -o 与-g选项同时使用,用户组的新GID可以与系统已有用户组的GID相同。
    • -n新用户组 将用户组的名字改为新名字
    (4)如果一个用户同时属于多个用户组,那么用户可以在用户组之间切换,以便具有其他用户组的权限。

    用户可以在登录后,使用命令newgrp 切换到其他用户组,这个命令的参数就是目的用户组。例如:

    $ newgrp root
    
    • 1

    这条命令将当前用户切换到root用户组,前提条件是root用户组确实是该用户的主组或附加组。类似于用户账号的管理,用户组的管理也可以通过集成的系统管理工具来完成。

    六、磁盘管理

    稍后学习补充

    七、Linux vi/vim

    1、vim 是什么

    Vim 是从 vi 发展出来的一个文本编辑器。代码补全、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。

    简单的来说, vi 是老式的字处理器,不过功能已经很齐全了,但是还是有可以进步的地方。 vim 则可以说是程序开发者的一项很好用的工具。

    vim的官方网站:https://www.vim.org/

    vim 键盘图:

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MsDvKNbT-1661498385880)(D:\培训笔记\学习报告\linux学习报告\4.png)]

    2、vi/vim 使用

    基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode),输入模式(Insert mode)和底线命令模式(Last line mode)。

    (1)命令模式

    用户刚刚启动vi/vim,便进入到了命令模式,此状态下敲击键盘动作会被Vim识别为命令,而非输入字符。比如我们此时按下i,并不会输入一个字符,i被当作了一个命令。

    以下是常用的几个命令:

    • i 切换到输入模式,以输入字符。
    • x 删除当前光标所在处的字符。
    • : 切换到底线命令模式,以在最底一行输入命令。

    若想要编辑文本:启动Vim,进入了命令模式,按下i,切换到输入模式。

    命令模式只有一些最基本的命令,因此仍要依靠底线命令模式输入更多命令。

    (2)输入模式

    在命令模式下按下i就进入了输入模式。

    在输入模式中,可以使用以下按键:

    • 字符按键以及Shift组合,输入字符
    • ENTER,回车键,换行
    • BACK SPACE,退格键,删除光标前一个字符
    • DEL,删除键,删除光标后一个字符
    • 方向键,在文本中移动光标
    • HOME/END,移动光标到行首/行尾
    • Page Up/Page Down,上/下翻页
    • Insert,切换光标为输入/替换模式,光标将变成竖线/下划线
    • ESC,退出输入模式,切换到命令模式
    (3)底线命令模式

    在命令模式下按下:(英文冒号)就进入了底线命令模式。

    底线命令模式可以输入单个或多个字符的命令,可用的命令非常多。

    在底线命令模式中,基本的命令有(已经省略了冒号):

    • q 退出程序

    • w 保存文件

    • 按ESC键可随时退出底线命令模式。

    3、vi/vim 按键说明

    后面慢慢学习补充

    八、linux yum

    yum(Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器。

    基于 RPM 包管理,能够从指定的服务器自动下载 RPM 包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次次下载、安装。

    yum 提供了查找、安装、删除某一个、一组甚至全部软件包的命令,而且命令简洁而又好记。

    1、yum语法
    yum [options] [command] [package ...]
    
    • 1
    • options : 可选,选项包括-h(帮助),-y(当安装过程提示选择全部为 “yes”),-q(不显示安装的过程)等等。
    • command : 要进行的操作。
    • package : 安装的包名
    2、yum常用命令
    • 列出所有可更新的软件清单命令:yum check-update

    • 更新所有软件命令:yum update

    • 仅安装指定的软件命令:yum install

    • 仅更新指定的软件命令:yum update

    • 列出所有可安裝的软件清单命令:yum list

    • 删除软件包命令:yum remove

    • 查找软件包命令:yum search

    • 清除缓存命令:

      • yum clean packages: 清除缓存目录下的软件包
      • yum clean headers: 清除缓存目录下的 headers
      • yum clean oldheaders: 清除缓存目录下旧的 headers
      • yum clean, yum clean all (= yum clean packages; yum clean oldheaders) :清除缓存目录下的软件包及旧的 headers

    (帮助),-y(当安装过程提示选择全部为 “yes”),-q(不显示安装的过程)等等。

    • command : 要进行的操作。
    • package : 安装的包名
    2、yum常用命令
    • 列出所有可更新的软件清单命令:yum check-update

    • 更新所有软件命令:yum update

    • 仅安装指定的软件命令:yum install

    • 仅更新指定的软件命令:yum update

    • 列出所有可安裝的软件清单命令:yum list

    • 删除软件包命令:yum remove

    • 查找软件包命令:yum search

    • 清除缓存命令:

      • yum clean packages: 清除缓存目录下的软件包
      • yum clean headers: 清除缓存目录下的 headers
      • yum clean oldheaders: 清除缓存目录下旧的 headers
      • yum clean, yum clean all (= yum clean packages; yum clean oldheaders) :清除缓存目录下的软件包及旧的 headers
  • 相关阅读:
    TripleDES golang/python/ts 实现方式
    vue交互
    【办公类-04-04】华为助手导出照片视频分类(根据图片、视频的文件名日期导入“年-月-日”文件夹中,并转移到“年-月”文件中整理、转移到“年”文件夹中整理)
    Python基础List列表定义与函数
    Gradle系列【1】概述、安装、创建工程、目录介绍
    每日一题——自动补全——1972
    Element Plus el-form表单自定义插槽如何使用
    C++ Primer学习笔记-----第十八章:用于大型程序的工具
    【SQL】MySQL中的索引,索引优化
    化繁为简,聊一聊复制状态机系统架构抽象
  • 原文地址:https://blog.csdn.net/qq_44619675/article/details/126544162