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 权限。
① 数字方式更改权限
用数字代表各权限,则各权限的分数对照表为:
权限 | 二进制值 | 八进制值 | 描述 |
---|---|---|---|
— | 000 | 0 | 没有任何权限 |
r– | 100 | 4 | 只有读取权限 |
-w- | 010 | 2 | 只有写入权限 |
–x | 001 | 1 | 只有执行权限 |
rw- | 110 | 6 | 有读取和写入权限 |
r-x | 101 | 5 | 有读取和执行权限 |
-wx | 011 | 3 | 有写入和执行权限 |
rwx | 111 | 8 | 有读取、写入和执行权限 |
每种身份(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 : 其他用户
那么我们就可以使用u,g,o 来代表三种身份的权限。
此外,a 代表all,即全部的身份。
那么通过符号方式更改权限的语法组成为:
指令 | 身份 | 操作 | 权限 | 授权目标 |
---|---|---|---|---|
chmod | u 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