目录
引用
本汇总主要针对《老韩的一周学会Linux》课程整理,在其课程的内容上进行了额外的补充,以供将来学习复习使用。
虚拟机篇1 网络连接的三种方式
1、桥接模式:虚拟系统可以和外部系统通讯,但是容易造成IP冲突(在一个局域网)
2、NAT模式:也称网络地址转换模式。虚拟系统可以和外部系统通讯,不造成IP冲突。 在主机内部会生成另外一个内部网段的IP,主机和生成的IP(用于自己和虚拟机)可以进行互通。且内网可以和外部局域网连接(通过主机的真实ip),但是外部的局域网不能与虚拟机进行直接连接。(工程下选他即可)
3、主机模式:独立系统,不与外部产生连接
虚拟机篇2 虚拟机克隆
当已经安装了一台linux操作系统,仍想要多个时,无需重新下载。
方式一:直接拷贝一份安装好的虚拟机文件。
直接复制一份已经做好的虚拟机,并且把它复制到不同的区盘即可。并用VM“文件”下打开即可。
方式二:使用vmware的克隆操作
克隆时,先关闭已经开启的虚拟机,在虚拟机上右键进行克隆。
虚拟机篇3 虚拟机快照
如果使用虚拟机的时候,想要回到原先的某一个状态,可能有些误操作造成系统异常,需要回到原先某个正常的运行状态,vmware提供了一个快照管理.
【操作】只需进入vmware右键虚拟机名称选择快照拍摄和快照管理器即可,因为是会占用空间的,因此在需要的时候再去拍照
虚拟机篇4 vmtools下的共享文件夹
共享文件夹的意思是主机和虚拟机共享一个文件夹,主机拷贝过去,虚拟机就可以直接使用了。
右键虚拟机名称,点击设置,在选项处就有共享文件夹了!
【虚拟机如何找到】在文件夹里面找到/mnt/hgfs,里面就会存放着刚刚设置的共享的文件夹
0 快捷键
------终端--------
Ctrl+Alt+T
打开终端
Ctrl+Shift+Q
关闭终端
Ctrl + Shift + [+]
放大终端(注意这个+不是小键盘上的)
Ctrl + [-]
缩小终端(注意这个-不是小键盘上的)
Alt+ Tab
切换不同的程序窗口
Alt + F4
强制关闭当前窗口
------命令行任务---------
上键
查看历史命令
Ctrl+l
清屏,类似clear命令
Ctrl + c
强制终止当前命令
Ctrl + z
暂停在终端运行的任务
Ctrl + Shift + c
复制
Ctrl + Shift + v
粘贴
------光标移动---------
Ctrl + a
使光标快速到行首
Ctrl + e
光标快速移到行尾
1 目录结构—Linux世界里,一切皆文件
首先,对于指令要明白的是:在 linux 下,隐藏文件是以 .开头 , 选项可以组合使用 比如 ls -al
, 比如 ls -al /root
linux 的文件系统是采用级层式的树状目录结构,在此结构中的最上层是根目录“/”,然后在此目录下再创建其他的目录。
以下为具体的目录结构(不用背,可查询):
(1)/bin [常用] (/usr/bin 、 /usr/local/bin),是 Binary 的缩写, 这个目录存放着最经常使用的命令。该目录中存储的都是一些二进制文件,文件都是可以被运行的。
(2)/sbin (/usr/sbin 、 /usr/local/sbin),全称super binary,该目录也是存储一些可以被执行的二进制文件,但是必须得有super权限的用户才能执行。
(3)/home [常用],存放普通用户的主目录,在 Linux 中每个用户都有一个自己的目录,一般该目录名是以用户的账号命名。
(4)/root [常用],该目录为系统管理员,也称作超级权限者的用户主目录
(5)/lib ,系统开机所需要最基本的动态连接共享库,其作用类似于 Windows 里的 DLL 文件。几乎所有的应用程序都需要用到这些共享库。
(6)/lost+found 这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件(日常是隐藏的)
(7)/etc [常用],所有的系统管理所需要的配置文件和子目录, 比如安装 mysql 数据库 my.conf
(8)/usr [常用],这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似与 windows 下的 program files 目录。
(9)/boot [常用] 存放的是启动 Linux 时使用的一些核心文件,包括一些连接文件以及镜像文件
(10)/proc [不能动] 这个目录是一个虚拟的目录,它是系统内存的映射,访问这个目录来获取系统信息
(11)/srv [不能动] service 缩写,该目录存放一些服务启动之后需要提取的数据
(12)/sys [不能动]这是 linux2.6 内核的一个很大的变化。该目录下安装了 2.6 内核中新出现的一个文件系统 sysfs =》【别动】
(13)/tmp 这个目录是用来存放一些临时文件的
(14)/dev,该目录中主要存放的是外接设备,例如盘、其他的光盘等。在其中的外接设备是不能直接被使用的,需要挂载(类似window下的分配盘符)。
(15)/media [常用], linux 系统会自动识别一些设备,例如 U 盘、光驱等等,当识别后,linux 会把识别的设备挂载到这个目录下
(16)/mnt [常用],系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将外部的存储挂载在/mnt/上,然后进入该目录就可以查看里的内容了。 d:/myshare
(17) /opt ,这是给主机额外安装软件所存放的目录。如安装 ORACLE 数据库就可放到该目录下。默认为空
(18)/usr/local [常用]这是另一个给主机额外安装软件所安装的目录。一般是通过编译源码方式安装的程序。
(19)/var [常用],这个目录中存放着在不断扩充着的东西,习惯将经常被修改的目录放在这个目录下。包括各种日志文件。
2 Vim编辑器的使用
编辑器的三种模式
1、正常模式
以vim 打开一个档案就直接进入一般模式了(这是默认的模式)。在这个模式中, 你可以使用『上下左右』按键来移动光标,你可以使用『删除字符』或『删除整行』来处理档案内容, 也可以使用『复制、粘贴』来处理你的文件数据。
2、插入模式
按下 i, I, o, O, a, A, r, R 等任何一个字母之后才会进入编辑模式, 一般来说按 i 即可.
3、命令行模式
输入 esc (到正常模式)再输入":",在这个模式当中, 可以提供你相关指令,完成读取、存盘、替换、离开 vim 、显示行号等的动作则是在此模式中达成的!
快捷键
【关于复制】 光标移动到你要选中的文字前或后,然后按一下v键
再移动光标,若是要复制就按一下y键,若是要剪切就按一上d键
然后,再把光标移动到你想要粘贴的地方,按一下p键。
复制、删除、查找、显示行号、快速定位某行
- 拷贝当前行 yy , 拷贝当前行向下的 5 行 5yy,并粘贴(输入 p)。【正常模式】
- 删除当前行 dd , 删除当前行向下的 5 行 5dd【正常模式】
- 在文件中查找某个单词 [命令行下 /关键字 , 回车 查找 , 输入 n 就是查找下一个]【命令行模式】
- 移动光标,到某个字符的后面,按下x,是删除单个字符【插入模式】
- 设置文件的行号,取消文件的行号.[命令行下 : set nu 和 :set nonu]【命令行模式】
- 编辑 /etc/profile 文件,在一般模式下, 使用快捷键到该文档的最末行[G]和最首行[gg]
- 在一个文件中输入 “hello” ,在一般模式下, 然后又撤销这个动作 u
- 一般模式下,快速移动到某行直接使用
: 行数
。
3 开机、重启和用户登录注销
关机&重启指令
- shutdown –h now 立该进行关机
- shudown -h 1 1 分钟后关机
- shutdown –r now 现在重新启动计算机
- halt 关机,作用和上面一样.(上面的-h中的h就是这个)
- reboot 现在重新启动计算机
- sync 把内存的数据同步到磁盘.
PS:不管是重启系统还是关闭系统,首先要运行 sync 命令,把内存中的数据写到磁盘中,
目前的 shutdown/reboot/halt 等命令均已经在关机前进行了 sync , 老韩提醒: 小心驶得万年船。
指定运行级别
【服务的运行级别】Linux 系统有 7 种运行级别(runlevel):常用的是级别 3 和 5
运行级别 0:系统停机状态,系统默认运行级别不能设为 0,否则不能正常启动
运行级别 1:单用户工作状态,root 权限,用于系统维护,禁止远程登陆
运行级别 2:多用户状态(没有 NFS),不支持网络
运行级别 3:完全的多用户状态(有 NFS),无界面,登陆后进入控制台命令行模式
运行级别 4:系统未使用,保留
运行级别 5:X11 控制台,登陆后进入图形 GUI 模式
运行级别 6:系统正常关闭并重启,默认运行级别不能设为 6,否则不能正常启动
开机流程如下图所示
【指令】init [0/1/2/3/4/5/6]
通过init即可完成不同运行等级的切换。
若想永久改变开机的运行等级,详见第15中的服务管理部分指令。
Ubuntu的root用户
安装 ubuntu 成功后,都是普通用户权限,并没有最高 root 权限,如果需要使用 root 权限的时候,通常都会在命令前面加上 sudo。所以,一般直接使用su命令来直接切换到root用户。但若一开始没给其设置密码,是无法进入的,需要用以下方式去设置:
【如何给root用户设置密码并使用】
- 输入 sudo passwd 命令,设定 root 用户密码。
- 设定 root 密码成功后,输入 su 命令,并输入刚才设定的 root 密码,就可以切换成 root 了。提示符$代表一般用户以及提示符#代表 root 用户
- 上述操作后,就可以使用root用户了。使用完毕后,输入 exit 命令,退出 root 并返回一般用户。
4 用户管理
Linux 系统是一个多用户多任务的操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
添加用户
指令:useradd 用户名
PS:当创建用户成功后,会自动的创建和用户同名的家目录。另外,若想在创建用户时指定组,则以下指令useradd –g 用户组 用户名
指定/修改密码
指令:passwd 用户名
PS:显示当前用户所在的目录的指令——pwd
删除用户
指令:uesrdel 用户名
【应用】删除用户以及用户主目录, 比如 tom, userdel -r tom
(慎用!一般保留的)
查询用户信息
指令:id 用户名
切换用户
指令:su 切换用户名
当需要返回到原来用户时,使用 exit/logout
指令
查看当前登录用户
指令:whoami
5 组管理
【Linux组介绍】在 linux 中的每个用户必须属于一个组,不能独立于组外。在 linux 中每个文件有所有者、所在组、其它组的概念。
a、用户所在组的创建、删除与修改
【定义】类似于角色,系统可以对有共性/权限的多个用户进行统一的管理
创建指令 : groupadd 组名
PS:在创建用户是,默认分到跟它用户名相同的一个组里。但可以指定将该用户添加到哪个组中,同样的用 root 的管理权限可以改变某个用户所在的组。
创建用户时指定组,则以下指令useradd –g 用户组 用户名
。
删除指令(基本语法): groupdel 组名
修改指令:usermod –g 用户组 用户名
用户和组相关文件
1、/etc/passwd 文件
用户(user)的配置文件,记录用户的各种信息
每行的含义:用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录 Shell
2、/etc/shadow文件
口令的配置文件
每行的含义:登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志
3、/etc/group 文件
组(group)的配置文件,记录 Linux 包含的组的信息
每行含义:组名:口令:组标识号:组内用户列表
b、文件/目录的所有者
【定义】一般为文件的创建者,谁创建了该文件,就自然的成为该文件的所有者(可修改)。
查看文件所有者的指令:ll
指令即可:
修改文件所有者的指令:chown 用户名 文件名
c、文件/目录的所在组
【定义】当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组(默认)。
查看文件所在组的指令:依旧是ll
指令:
修改文件所在组的指令:chgrp 组名 文件名
d、其它组
【定义】除文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组。
6权限管理
权限的基本介绍
执行指令ll
后,显示的内容如下:
其中0-9位便是有关权限的说明位:
1、第 0 位确定文件类型(d
, -
, l
, c
, b
)
其中:l
是链接,相当于 windows 的快捷方式;-
代表这是一个普通文件; d
是目录,相当于 windows 的文件夹;c
是字符设备文件,鼠标,键盘;b
是块设备,比如硬盘;
2、第 1-3 位确定所有者(该文件的所有者)拥有该文件的权限—User
3、第 4-6 位确定所属组(同用户组的)拥有该文件的权限—Group
4、第 7-9 位确定其他用户拥有该文件的权限—Other
rwx 权限详解
【rwx作用到文件】
r
代表可读(read): 可以读取,查看。
w
代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件。
x
代表可执行(execute):可以被执行。
【rwx作用到目录】
r
代表可读(read): 可以读取,ls 查看目录内容( 仅读⽬录内容!!)
w
代表可写(write): 可以修改, 对目录内创建+删除+重命名目录
x
代表可执行(execute):可以进入该目录(不仅仅可以进入该目录,还可以读写目录里面权限够的文件和子目录)
【案例】-rwxrw-r-- 1 root root 1213 Feb 2 09:39 abc
1、10 个字符确定不同用户能对文件干什么
第一个字符代表文件类型: - l d c b
,本题的-
代表这个是一个普通文件。
其余字符每 3 个一组(rwx) 读® 写(w) 执行(x)
第一组 rwx
: 文件拥有者的权限是读、写和执行
第二组 rw-
: 与文件拥有者同一组的用户的权限是读、写但不能执行
第三组 r--
: 不与文件拥有者同组的其他用户的权限是读不能写和执行
2、1
的位置根据其类型是不同的含义:文件(硬连接数,就是1)和目录(一级目录的个数,实际应该减2,因为这里面包含了.
和..
)有不同含义。这里因为是文件所以就是1。
3、第一个和第二个root
分别是文件拥有者以及其所在组
4、1213
表示的是文件大小(字节),如果是文件夹,显示 4096 字节
5、Feb 2 09:39
是最后修改日期。
6、abc
文件名
修改文件或者目录的权限
通过chmod xxx(变更权限方式) 文件/目录名
指令
第一种方式:+ 、-、= 变更权限
u:所有者 g:所有组 o:其他人 a:所有人(u、g、o 的总和)
chmod u=rwx,g=rx,o=x 文件/目录名
给该文件/目录的所有者读、写、执行的权限,给所在组读、执行权限,给其它组读执行权限。=
就是赋予。
chmod o+w 文件/目录名
给该文件/目录的其它用户赋予写的权限+
就是添加。
chmod a-x 文件/目录名
给该文件/目录的所有人的执行权限都去掉-
就是减去。
第二种方式:通过数字变更权限
r=4 w=2 x=1 rwx=4+2+1=7
所以下面的是7代表rwx,其实就是rwx的111(其实就是⼆进制设置)。
因此,chmod 751 文件/目录名
其实就相当于指令chmod u=rwx,g=rx,o=x 文件目录名
。
修改文件或者目录的所有者及所在组
修改文件或者目录的所有者:chown newowner 文件/目录
修改文件或者目录的所在组:chgrp newgroup 文件/目录
改变所有者和所在组:
指令:chown newowner:newgroup 文件/目录
【选项】-R
如果是目录 则使其下所有子文件或目录递归生效。
5和6的综合例题
jack, jerry: 警察police
xh, xq: 土匪bandit
- 创建组
groupadd police ; groupadd bandit;
- 创建用户
useradd -g police jack ; useradd -g police jerry
useradd -g bandit xh; useradd -g bandit xq
- jack 创建一个文件,自己可以读 r 写 w,本组人可以读,其它组没人任何权限
首先 jack 登录 ;vim jack.txt ; chmod 640 jack.txt
- jack 修改该文件,让其它组人可以读, 本组人可以读写
chmod o=r,g=r jack.txt
- xh 投靠 警察,看看是否可以读写.
usermod -g police xh
- 测试,看看 xh 是否可以读写,xq 是否可以【小结论】就是如果要对目录内的文件进行操作,需要要有对该目录的相应权限
7 帮助指令
获得帮助信息(查看指令的详细选项)
基本语法:man [命令或配置文件]
(功能描述:获得帮助信息)
案例:查看 ls 命令的帮助信息 man ls
退出手册时,直接q
即可。
获得 shell 内置命令的帮助信息
基本语法:help 命令
8 文件目录类
显示当前工作目录的绝对路径
指令:pwd
(Print current working directory)
查看目录求文件的内容信息
指令:ls [选项] [目录或是文件]
(List directory contents)
绝对目录中
ls ./ #【表示当前目录下】
ls ../ #【上一级目录下】
【常用选项】
-a
:显示当前目录所有的文件和目录,包括隐藏的。
-l
:以列表的方式显示信息
【Tips】在 linux 下,隐藏文件是以 .
开头 , 选项可以组合使用 比如 ls -al
, 比如 ls -al /root
【常用形式】ll
其实该指令直接详细查看目录或文件的信息(等同于ls -al
)
切换到指定目录(包括进入文件夹,返回文件夹)
指令:cd [参数]
(change directory)
【案例】
cd ~
或者 cd
:回到自己的家目录。
cd..
:回到当前目录的上一级目录(返回操作)
使用绝对路径切换到 root 目录 cd /root
使用相对路径到/root 目录, 比如在 /home/tom , cd ../../root
创建目录
指令:mkdir [选项] 要创建的目录
常用选项 -p
:创建多级目录
【案例】创建多级目录 /home/animal/tiger mkdir -p /home/animal/tiger
删除空白目录
指令:rmdir [选项] 要删除的空目录
PS:如果需要删除非空目录,需要使用 rm -rf
要删除的目录(r指的是recurrent递归,f是force)
创建空文件
指令:touch 文件名称
拷贝文件到指定目录
指令:cp [选项] source dest
常用选项:-r
:递归复制整个文件夹
【案例】递归复制整个文件夹,举例, 比如将 /home/bbb 整个目录, 拷贝到 /opt
cp -r /home/bbb /op
删除文件或目录
指令:rm [选项] 要删除的文件或目录
常用选项:
-r
:递归删除整个文件夹
-f
: 强制删除不提示
【案例】递归删除整个文件夹 /home/bbb
rm -rf /home/bbb [删除整个文件夹,不提示]
移动文件与目录或重命名
指令:mv oldNameFile newNameFile (功能描述:重命名)
mv /temp/movefile /targetFolder (功能描述:移动文件)
【案例】:将 /home/pig.txt 文件 移动到 /root 目录下并改名为cat.txt
mv /home/pig.txt /root/cat.txt
显示文件内容(只读打开)
指令:cat [选项] 要查看的文件
常用选项:-n
:显示行号
PS:cat
只能浏览文件,而不能修改文件,为了浏览方便,一般会带上 管道命令 | more
more指令(文本过滤器,方便读)
more 指令是一个基于 VI 编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容。
指令:more 要查看的文件
分屏查看文件内容(动态加载)
less 指令用来分屏查看文件内容,它的功能与 more 指令类似,但是比 more 指令更加强大,支持各种显示终端。less指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要加载内容。
指令:less 要查看的文件
输出内容到控制台
指令:echo [选项] [输出内容]
【案例】使用 echo 指令输出环境变量, 比如输出 $PATH $HOSTNAME, echo $HOSTNAME
显示文件的开头部分内容
默认查看前十行:
head 文件 (功能描述:查看文件头 10 行内容)
head -n 5 文件 (功能描述:查看文件头 5 行内容,5 可以是任意行数)
显示出文件中尾部的内容(包括实时追踪文件更新)
tail 文件 (功能描述:查看文件尾 10 行内容)
tail -n 5 文件 (功能描述:查看文件尾 5 行内容,5 可以是任意行数)
tail -f 文件 (功能描述:实时追踪该文档的所有更新)
在实时追踪中,可以使用crlt + c
退出监控。
> 输出重定向指令 和 >> 追加指令
ll >文件 (功能描述:列表的内容写入文件 中(覆盖写))//若文档没有,则会创建
ll >>文件 (功能描述:列表的内容追加到文件的末尾)
cat 文件 1 > 文件 2 (功能描述:将文件 1 的内容覆盖到文件 2)
echo "内容">> 文件 (追加)
软链接(符号链接)
其实类似于 windows 里的快捷方式,主要存放了链接其他文件的路径。
指令:ln -s [原文件或目录] [软链接名] (功能描述:给原文件创建一个软链接)
【案例】: 在/home 目录下创建一个软连接 myroot,连接到 /root 目录
ln -s /root /home/myroot
删除软连接 myroot
rm /home/myroot
PS:但是我们使用 pwd 指令查看目录时,仍然看到的是软链接所在目录。
查看已经执行过历史命令
指令:history
【案例】显示所有的历史命令
history
显示最近使用过的 10 个指令
history 10
执行历史编号为 5 的指令
!5
9 时间日期类
显示当前日期
指令:
date (功能描述:显示当前时间)
date +%Y(功能描述:显示当前年份)
date +%m(功能描述:显示当前月份)
date +%d (功能描述:显示当前是哪一天)
date "+%Y-%m-%d %H:%M:%S"(功能描述:显示年月日时分秒)//这个指令中,除了+号必须有用于定位,其他的只是输出的一个符号罢了,也就是显示出来更好看而已
设置日期
date -s 字符串时间
【案例】设置系统当前时间 , 比如设置成 2020-11-03 20:02:10
date -s “2020-11-03 20:02:10”
显示日历
指令:cal//显示当前日历
显示 2020 年日历 : cal 2020
10 搜索查找类
find指令
find 指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件或者目录显示在终端。
指令:find [搜索范围] [选项]
【案例】按文件名:根据名称查找/home 目录下的 hello.txt 文件
find /home -name hello.txt
查找整个 linux 系统下大于 200M 的文件 (+n 大于 -n 小于 n 等于, 单位有 k,M,G)
find / -size +200M
locate指令
相比上面的find指令,locate 指令可以快速定位文件路径。因为 locate 指令利用事先建立的系统中所有文件名称及路径的 locate 数据库实现快速定位给定的文件。Locate 指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更新 locate 数据库
locate 搜索文件
PS:由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用 updatedb
指令创建 locate 数据库。
查看指令在哪个目录下
指令:which 要查询的指令名
grep指令和管道符号 |
grep
过滤查找 , 管道符|
,表示将前一个命令的处理结果输出传递给后面的命令处理。
指令grep [选项] 查找内容 源文件
11 压缩和解压类
gzip/gunzip 指令—*.gz文件
gzip 文件 (功能描述:压缩文件,只能将文件压缩为*.gz 文件)
gunzip 文件.gz (功能描述:解压缩文件命令)
zip/unzip 指令—*.zip文件
zip [选项] XXX.zip 将要压缩的内容(功能描述:压缩文件和目录的命令)
unzip [选项] XXX.zip (功能描述:解压缩文件)
【选项】
zip中的-r
:递归打包整个目录里面的文件和子文件夹
unzip中的-d<目录>
:指定解压后文件的存放目录
【案例】
将 myhome.zip 解压到 /opt/tmp 目录下
unzip -d /opt/tmp /home/myhome.zip
tar指令—*.tar.gz文件
一条指令既能压缩也能解压,全靠选项!
tar [选项] XXX.tar.gz 打包的内容
【案例】压缩多个文件,将 /home/pig.txt 和 /home/cat.txt 压缩成 pc.tar.gz
tar -zcvf pc.tar.gz /home/pig.txt /home/cat.txt
因为-f
是指定名,因此它必须在后面且紧跟的应是文件名
将myhome.tar.gz 解压到 /opt/tmp2目录下
tar -zxvf /home/myhome.tar.gz -C /opt/tmp2
//-C
后面加要解压到的位置
12 定时任务调度
【定义】任务调度:是指系统在某个时间执行的特定的命令或程序。
【分类】1.系统工作:有些重要的工作必须周而复始地执行。如病毒扫描等。
2.个别用户工作:个别用户可能希望执行某些程序,比如对 mysql 数据库的备份。
crond 任务调度
指令:crontab [选项]
常用指令:
编辑crontab定时任务crontab -e
(注意打开后crond后,多条定时任务换行后写上即可)
查询crontab定时任务crontab -l
删除当前用户所有的crontab任务crontab -r
(毕竟删⼀条,进⼊-e,直接把那⾏删掉即可)
【编辑时的格式要求】一条任务如:*/1 * * * * ls –l /etc/ > /tmp/to.txt
该指令译为:每小时的每分钟执行 ls –l /etc/ > /tmp/to.txt
命令
【特殊符号的含义】
【每位的含义】
注意!星期几和几号最好不要同时出现,因为他们定义的都是天,很容易让管理员混乱。
at 定时任务
【定义】at 命令是一次性定时计划任务(只执行一次),at 的守护进程 atd 会以后台模式运行,检查作业队列来运行。而默认情况下,atd 守护进程每 60 秒检查作业队列,有作业时,会检查作业运行时间,如果时间与当前时间匹配,则运行此作业!
在使用 at 命令的时候,一定要保证 atd 进程的启动 , 可以使用相关指令来查看ps -ef | grep atd //可以检测 atd 是否在运行
注意,应有/usr/sbin/atd此类字样才算是正在运行!
【指令】at [选项] [时间]
,随后两次Ctrl + D
结束 at 命令的输入(两次是因为:第一次相当于换行符,第二次相当于退出编辑模式)–结合下文案例理解
atq
命令来查看系统中没有执行的工作任务
atrm 编号
命令来删除已经设置的任务(每次at完或者atq都可以看到其编号–job后的数字)
【选项】
【指定时间的方法】
(1)接受在当天的 hh:mm(小时:分钟)式的时间指定。假如该时间已过去,那么就放在第二天执行。 例如:04:00
(2)使用 midnight(深夜),noon(中午),teatime(饮茶时间,一般是下午 4 点)等比较模糊的词语来指定时间。
(3) 采用 12 小时计时制,即在时间后面加上 AM(上午)或 PM(下午)来说明是上午还是下午。 例如:12pm
(4)指定命令执行的具体日期,指定格式为 month day(月 日)或 mm/dd/yy(月/日/年)或 dd.mm.yy(日.月.年),指定的日期必须跟在指定时间的后面。 例如:04:00 2021-03-1
(5) 使用相对计时法。指定格式为:now + count time-units ,now 就是当前时间,time-units 是时间单位,这里能够是 minutes(分钟)、hours(小时)、days(天)、weeks(星期)。count 是时间的数量,几天,几小时。 例如:now + 5 minutes
(6) 直接使用 today(今天)、tomorrow(明天)来指定完成命令的时间。
【案例】2 天后的下午 5 点执行 /bin/ls /home
2 分钟后,输出时间到指定文件内 比如 /root/date200.log
13Linux 磁盘分区、挂载
【挂载的定义】Linux 采用了一种叫“载入”的处理方法,它的整个文件系统中包含了一整套的文件和目录,且将一个分区和一个目录联系起来。这时要载入的一个分区将使它的存储空间在一个目录下获得。
【磁盘说明】Linux 硬盘分 IDE 硬盘和 SCSI 硬盘,目前基本上是 SCSI 硬盘
【 IDE 硬盘】以驱动器标识符为“hdx~”为例:
其中“hd”表明分区所在设备的类型,这里是指 IDE 硬盘了。
“x”为盘号(a 为基本盘,b 为基本从属盘,c 为辅助主盘,d 为辅助从属盘)
“~”代表分区,前四个分区用数字 1 到 4 表示,它们是主分区或扩展分区,从 5 开始就是逻辑分区。
【SCSI 硬盘】以驱动器标识符为“sdx~”为例:
SCSI 硬盘是用“sd”来表示分区所在设备的类型的,其余则和 IDE 硬盘的表示方法一样。
【案例】hda3
表示为第一个 IDE 硬盘上的第三个主分区或扩展分区,hdb2
表示为第二个 IDE 硬盘上的第二个主分区或扩展分区。
查看所有设备挂载情况
指令:lsblk 或者 lsblk -f
其中:MOUNTPOINT便是磁盘分区的挂载目录情况了
如何挂载一块新硬盘
将新硬盘挂载到/dev/sdb
为例:
1、虚拟机添加硬盘。【略】
2、使用分区命令fdisk [目录]
fdisk /dev/sdb
开始对/sdb 分区:
【快捷键】
m 显示命令列表
p 显示磁盘分区 同 fdisk –l
n 新增分区
d 删除分区
w 写入并退出
【详细步骤】 开始分区后输入 n
,新增分区,然后选择 p
,分区类型为主分区。两次回车
默认剩余全部空间。最后输入w
写入分区并退出,若不保存退出输入 q
。
3、格式化磁盘(至此完成分区,但未完成挂载)
指令:mkfs -t ext4 /dev/sdb1//其中 ext4 是分区类型
该步会产生一个唯一的UUID
4、将新硬盘与目录联系起来(挂载)
挂载命令mount 设备名称 挂载目录
因此执行mount /dev/sdb1 /newdisk
,但此时仅仅用命令行挂载,重启后会失效。
5、永久挂载: 通过修改/etc/fstab
实现挂载!添加完成后,执行 mount –a
即刻生效!
查询系统整体磁盘使用情况
指令:df -h
查询指定目录的磁盘占用情况
指令:du [选项]//默认查询当前目录
【选项】
【案例】查询 /opt 目录的磁盘占用情况,深度为 1
du -hac --max-depth=1 /opt
统计/可视化文件夹下的各种个数
1、统计/opt 文件夹下文件的个数
ll /opt | grep "^-"| wc-l
(其中^-
是指前面rwx内容中的普通文件指示,而wc-l
为只统计数量)
2、统计/opt 文件夹下目录的个数
ll /opt | grep "^d"| wc-l
3、统计/opt 文件夹下文件的个数,包括子文件夹里的(即需要递归)
ll -R /opt | grep "^-"| wc-l
4、以树状显示目录结构
tree 目录
14网络配置
查看 windows 环境的网络配置
指令:ipconfig
查看linux 环境的网络配置
指令:ifconfig
测试主机之间网络连通性
指令:ping 目的主机
IP配置
【自动获得ip】登陆后,通过界面的来设置自动获取 ip,特点:linux 启动后会自动获取 IP,缺点是每次自动获取的 ip 地址可能不一样,因此做服务器不合适。
【指定ip】直接修改配置文件来指定 IP,并可以连接到外网
通过编辑 vim /etc/sysconfig/network-scripts/ifcfg-ens33//这个ens33可能不一样,具体看ifconfig的显示
【案例】要求:将 ip 地址配置的静态的,比如: ip 地址为 192.168.200.130
1、首先对文件内的内容说明:
DEVICE=eth0 #接口名(设备,网卡)
HWADDR=00:0C:2x:6x:0x:xx #MAC 地址
TYPE=Ethernet#网络类型(通常是 Ethemet)
UUID=926a57ba-92c6-4231-bacb-f27e5e6a9f44 #随机 id
#系统启动的时候网络接口是否有效(yes/no)
ONBOOT=yes
#IP 的配置方法[none|static|bootp|dhcp](引导时不使用协议|静态分配 IP|BOOTP 协议|DHCP 协议)
2、用下面的方法进行修改
BOOTPROTO=static
#IP 地址
IPADDR=192.168.200.130
#网关
GATEWAY=192.168.200.2
#域名解析器
DNS1=192.168.200.2
3、重启网络服务或者重启系统生效
service network restart 、reboot
设置主机名
查看主机名的指令:hostname
修改文件在 /etc/hostname
指定,修改后,重启生效。
设置 hosts 映射
【定义】Hosts是一个文本文件,用来记录 IP 和 Hostname(主机名)的映射关系
【windows】在 C:\Windows\System32\drivers\etc\hosts
文件指定即可
例如:在文件内加入192.168.200.130 hspedu100
【Linux】在 /etc/hosts
文件指定
例如:在文件内加入192.168.200.1 ThinkPad-PC
主机名解析过程分析(Hosts、DNS)–三个保险
【DNS定义】DNS,就是 Domain Name System 的缩写,翻译过来就是域名系统
是互联网上作为域名和 IP 地址相互映射的一个分布式数据库。
以用户在浏览器输入了 www.baidu.com为例:
1、浏览器先检查浏览器缓存中有没有该域名解析 IP 地址,有就先调用这个 IP 完成解析;如果没有,就检查 DNS 解析器缓存,如果有直接返回 IP 完成解析。这两个缓存,可以理解为本地解析器缓存。
2、一般来说,当电脑第一次成功访问某一网站后,在一定时间内,浏览器或操作系统会缓存他的 IP 地址(DNS 解析记录)
3、如果本地解析器缓存没有找到对应映射,检查系统中 hosts 文件中有没有配置对应的域名 IP 映射,如果有,则完成解析并返回。(而域名劫持便是修改hosts文件成自己的钓鱼网站)。
4、如果本地 DNS 解析器缓存 和 hosts 文件 中均没有找到对应的 IP,则到域名服务 DNS 进行解析域。
监控网络状态(netstat)
指令:netstat [选项]
【选项】
-a
所有的socket
-n
直接使用IP地址,而不通过域名服务器
-p
显示哪个进程在调用(显示正在使用socket的程序的名称)
-l
显示正在监听的进程
-t
显示使用tcp的进程
-u
显示使用udp的进程
【案例】请查看服务名为 sshd 的服务的信息。
netstat -anp | grep sshd
,其中establish即已建立连接。
15进程管理
在 LINUX 中,每个执行的程序都称为一个进程。每一个进程都分配一个 ID 号(pid,进程号)。
显示系统执行的进程
指令:ps [选项]
【选项】
ps -ef
是以全格式显示当前所有的进程
-e 显示所有进程。-f 全格式
【指令执行后的参数说明】
//以下为ps -aux
的参数(如果想要更详细,可以使用-ajx
其含有父进程,组进程号等)
USER:进程执行的用户名称
PID:进程号
%CPU:进程占用 CPU 的百分比
%MEM:进程占用物理内存的百分比
VSZ:进程占用的虚拟内存大小(单位:KB)
RSS:进程占用的物理内存大小(单位:KB)
TT:终端名称,缩写
STAT:进程状态,其中 S-睡眠,s-表示该进程是会话的先导进程,N-表示进程拥有比普通优先级更低的优先级,R正在运行,D-短期等待,Z-僵死进程(应定期清除),T-被跟踪或者被停止等等
STARTED:进程的启动时间
TIME:CPU 时间,即进程使用 CPU 的总时间
COMMAND:启动进程所用的命令和参数,如果过长会被截断显示
//以下是ps -ef
的参数
UID:用户 ID
PID:进程 ID
PPID:父进程 ID
C:CPU 用于计算执行优先级的因子。数值越大,表明进程是 CPU 密集型运算,执行优先级会降低;数值越小,表明进程是 I/O 密集型运算,执行优先级会提高
STIME:进程启动的时间
TTY:完整的终端名称
TIME:CPU 时间
CMD:启动进程所用的命令和参数
终止进程
若是某个进程执行一半需要停止时,或是已消了很大的系统资源时,此时可以考虑停止该进程。
【指令】
kill [选项] 进程号(功能描述:通过进程号杀死/终止进程)
killall 进程名称 (功能描述:通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用)
注意这个指令会让子进程也会一起被杀掉!
【常用选项】-9
:表示强迫进程立即停止。
服务管理
【定义】服务(service) 本质就是进程,但是是运行在后台的,通常都会监听某个端口,等待其它程序的请求,比如(mysqld , sshd防火墙等),因此我们又称为守护进程,是 Linux 中非常重要的知识点。
【管理指令】systemctl [start | stop | restart | status] 服务名
systemctl 指令管理的服务在 /usr/lib/systemd/system
查看
【设置服务的自启动状态】
systemctl list-unit-files [ | grep 服务名]
(查看服务开机启动状态, grep 可以进行过滤)
systemctl enable 服务名
(设置服务开机启动)
systemctl disable 服务名
(关闭服务开机启动)
systemctl is-enabled 服务名
(查询某个服务是否是自启动的)
【设置开机的运行等级】
systemctl get-default
获得目前的开机运行等级
systemctl set-default multi-user.target
设置开机的运行等级为3
systemctl set-default graphical.target
设置开机的运行等级为5
动态监控进程
指令top [选项]
【选项】
【top执行后的交互按键】
16 APT 软件管理
安装ubuntu软件
apt 是 Advanced Packaging Tool 的简称,是一款安装包管理工具。在 Ubuntu 下,我们可以使用 apt 命令进行软件包的安装、删除、清理等,类似于 Windows 中的软件管理工具。
【指令】下面的package是指包名/软件名:
sudo apt-get update
更新源
sudo apt install package
安装包
sudo apt remove package
删除包
apt show package
获取软件信息
sudo apt-cache search package
搜索软件包
sudo apt-get install package --reinstall
重新安装包
sudo apt-get -f install
修复安装
sudo apt-get remove package --purge
删除包,包括配置文件等
sudo apt-get build-dep package
安装相关的编译环境
sudo apt-get upgrade
更新已安装的包
sudo apt-get dist-upgrade
升级系统
sudo apt-cache depends package
了解使用该包依赖那些包
sudo apt-cache rdepends package
查看该包被哪些包依赖
sudo apt-get source package
下载该包的源代码
寻找国内镜像源(提高应用下载速度)
1、先找到国内优质的镜像源
2、备份 Ubuntu 默认的源地址
sudo cp /etc/apt/sources.list /etc/apt/sources.list.backup
3、更新源服务器列表
先清空 sources.list 文件(该文件地址见上面代码),随后复制镜像网站的地址,拷贝至该文件内(清空可直接用echo '' > sources.list
)
4、更新源
sudo apt-get update
17远程登录Ubuntu
ssh 介绍
SSH 为 Secure Shell 的缩写,由 IETF 的网络工作小组(Network Working Group)所制定;SSH 为建立在应用层和传输层基础上的安全协议。
SSH 是目前较可靠,专为远程登录会话和其他网络服务ᨀ供安全性的协议。常用于远程登录。几乎所有 UNIX/LInux平台都可运行 SSH。
使用 SSH 服务,需要安装相应的服务器和客户端。客户端和服务器的关系:如果,A 机器想被 B 机器远程控制,那么,A 机器需要安装 SSH 服务器,B 机器需要安装 SSH 客户端。
安装 SSH 和启用
sudo apt-get install openssh-server
执行上面指令后,在当前这台 Linux 上就安装了 SSH 服务端和客户端(都装了)。
service sshd restart
执行上面的指令,就启动了 sshd 服务。会监听端口 22
在 Windows 使用 XShell6/XFTP6 登录 Ubuntu
从一台 linux 系统远程登陆另外一台 linux 系统
指令:ssh 用户名@IP
//一句话即可,随后输入主机密码即可进入!
退出时:exit或者logout
PS:使用 ssh 访问,如访问出现错误。可查看是否有该文件 ~/.ssh/known_ssh 尝试删除该文件解决,一般不会有问题