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

在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] 属组名 文件名

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

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

(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 文件或目录
  • 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
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 选项 用户名
  • 选项

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

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

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

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

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

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

  • 用户名

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

例如:

# useradd -d /home/hhh -m hhh

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

(2)删除账号

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

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

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

例如:

# userdel -r hhh

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

(3)修改账号

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

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

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

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

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

例如:

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

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

(4)用户口令的管理

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

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

passwd 选项 用户名

可使用的选项:

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

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

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

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

groupadd 选项 用户组

可以使用的选项有:

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

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

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

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

groupmod 选项 用户组

常用的选项有:

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

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

$ newgrp root

这条命令将当前用户切换到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 ...]
  • options : 可选,选项包括-h(帮助),-y(当安装过程提示选择全部为 “yes”),-q(不显示安装的过程)等等。
  • command : 要进行的操作。
  • package : 安装的包名
2、yum常用命令
  • 列出所有可更新的软件清单命令:yum check-update

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

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

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

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

  • 删除软件包命令:yum remove <package_name>

  • 查找软件包命令: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 <package_name>

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

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

  • 删除软件包命令:yum remove <package_name>

  • 查找软件包命令: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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值