目录

  • 引用
  • 虚拟机篇1 网络连接的三种方式
  • 虚拟机篇2 虚拟机克隆
  • 虚拟机篇3 虚拟机快照
  • 虚拟机篇4 vmtools下的共享文件夹
  • 0 快捷键
  • 1 目录结构---Linux世界里,一切皆文件
  • 2 Vim编辑器的使用
    • 编辑器的三种模式
    • 快捷键
  • 3 开机、重启和用户登录注销
    • 关机&重启指令
    • 指定运行级别
    • Ubuntu的root用户
  • 4 用户管理
    • 添加用户
    • 指定/修改密码
    • 删除用户
    • 查询用户信息
    • 切换用户
    • 查看当前登录用户
  • 5 组管理
    • a、用户所在组的创建、删除与修改
      • 用户和组相关文件
    • b、文件/目录的所有者
    • c、文件/目录的所在组
    • d、其它组
  • 6权限管理
    • 权限的基本介绍
    • rwx 权限详解
    • 修改文件或者目录的权限
    • 修改文件或者目录的所有者及所在组
    • 5和6的综合例题
  • 7 帮助指令
    • 获得帮助信息(查看指令的详细选项)
    • 获得 shell 内置命令的帮助信息
  • 8 文件目录类
    • 显示当前工作目录的绝对路径
    • 查看目录求文件的内容信息
    • 切换到指定目录(包括进入文件夹,返回文件夹)
    • 创建目录
    • 删除空白目录
    • 创建空文件
    • 拷贝文件到指定目录
    • 删除文件或目录
    • 移动文件与目录或重命名
    • 显示文件内容(只读打开)
    • more指令(文本过滤器,方便读)
    • 分屏查看文件内容(动态加载)
    • 输出内容到控制台
    • 显示文件的开头部分内容
    • 显示出文件中尾部的内容(包括实时追踪文件更新)
    • > 输出重定向指令 和 >> 追加指令
    • 软链接(符号链接)
    • 查看已经执行过历史命令
  • 9 时间日期类
    • 显示当前日期
    • 设置日期
    • 显示日历
  • 10 搜索查找类
    • find指令
    • locate指令
    • 查看指令在哪个目录下
    • grep指令和管道符号 |
  • 11 压缩和解压类
    • gzip/gunzip 指令---*.gz文件
    • zip/unzip 指令---*.zip文件
    • tar指令---*.tar.gz文件
  • 12 定时任务调度
    • crond 任务调度
    • at 定时任务
  • 13Linux 磁盘分区、挂载
    • 查看所有设备挂载情况
    • 如何挂载一块新硬盘
    • 查询系统整体磁盘使用情况
    • 查询指定目录的磁盘占用情况
      • 统计/可视化文件夹下的各种个数
  • 14网络配置
    • 查看 windows 环境的网络配置
    • 查看linux 环境的网络配置
    • 测试主机之间网络连通性
    • IP配置
    • 设置主机名
    • 设置 hosts 映射
    • 主机名解析过程分析(Hosts、DNS)--三个保险
    • 监控网络状态(netstat)
  • 15进程管理
    • 显示系统执行的进程
    • 终止进程
    • 服务管理
    • 动态监控进程
  • 16 APT 软件管理
    • 安装ubuntu软件
    • 寻找国内镜像源(提高应用下载速度)
  • 17远程登录Ubuntu
    • ssh 介绍
    • 安装 SSH 和启用
    • 在 Windows 使用 XShell6/XFTP6 登录 Ubuntu
    • 从一台 linux 系统远程登陆另外一台 linux 系统

引用

本汇总主要针对《老韩的一周学会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 、显示行号等的动作则是在此模式中达成的!

快捷键

复制、删除、查找、显示行号、快速定位某行

  1. 拷贝当前行 yy , 拷贝当前行向下的 5 行 5yy,并粘贴(输入 p)。【正常模式】
  2. 删除当前行 dd , 删除当前行向下的 5 行 5dd【正常模式】
  3. 在文件中查找某个单词 [命令行下 /关键字 , 回车 查找 , 输入 n 就是查找下一个]【命令行模式】
  4. 移动光标,到某个字符的后面,按下x,是删除单个字符【插入模式】
  5. 设置文件的行号,取消文件的行号.[命令行下 : set nu 和 :set nonu]【命令行模式】
  6. 编辑 /etc/profile 文件,在一般模式下, 使用快捷键到该文档的最末行[G]和最首行[gg]
  7. 在一个文件中输入 “hello” ,在一般模式下, 然后又撤销这个动作 u
  8. 一般模式下,快速移动到某行直接使用: 行数

3 开机、重启和用户登录注销

关机&重启指令

  1. shutdown –h now 立该进行关机
  2. shudown -h 1 1 分钟后关机
  3. shutdown –r now 现在重新启动计算机
  4. halt 关机,作用和上面一样.(上面的-h中的h就是这个)
  5. reboot 现在重新启动计算机
  6. 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用户设置密码并使用】

  1. 输入 sudo passwd 命令,设定 root 用户密码。
  2. 设定 root 密码成功后,输入 su 命令,并输入刚才设定的 root 密码,就可以切换成 root 了。提示符$代表一般用户以及提示符#代表 root 用户
  3. 上述操作后,就可以使用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

  1. 创建组 groupadd police ; groupadd bandit;
  2. 创建用户
    useradd -g police jack ; useradd -g police jerry
    useradd -g bandit xh; useradd -g bandit xq
  3. jack 创建一个文件,自己可以读 r 写 w,本组人可以读,其它组没人任何权限
    首先 jack 登录 ;vim jack.txt ; chmod 640 jack.txt
  4. jack 修改该文件,让其它组人可以读, 本组人可以读写
    chmod o=r,g=r jack.txt
  5. xh 投靠 警察,看看是否可以读写.
    usermod -g police xh
  6. 测试,看看 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 尝试删除该文件解决,一般不会有问题

Linux系统结构以及各类命令的汇总相关推荐

  1. linux系统结构与文件管理命令

                   ----------linux系统结构---------- 1.linux系统结构是倒树形的 /bin                     #二进制可执行文件,即系统 ...

  2. suse zypper mysql_SUSE Linux系统中zypper命令用法汇总

    Zypper是SUSE Linux下用于管理软件的程序,拥有多种功能,那么Linux下要如何使用Zypper命令来管理软件呢?下面小编就给大家介绍下SUSE Linux使用Zypper命令的方法,感兴 ...

  3. Linux性能分析命令工具汇总

    转自:http://rdc.hundsun.com/portal/article/731.html?ref=myread 出于对Linux操作系统的兴趣,以及对底层知识的强烈欲望,因此整理了这篇文章. ...

  4. Linux压缩和解压缩命令汇总(tar命令汇总)

    linux 中压缩文件非常常见,以下为本人对Linux压缩和解压缩命令进行了简单汇总,具体如下: 第一:打包+解包 打包命令(注意打包文件大小并没有压缩) tar -cvf xxx.tar +要打包的 ...

  5. linux 下的vi命令汇总

    linux 下的vi命令汇总 linux 下的vi 主要作用是什么? Vi是Unix及Linux系统bai下标准的编辑器,由美国加州大学伯克利分校的Bill Joy所创立. 基本上vi可以分为三种状态 ...

  6. manjaro(linux)系统各类命令合集(渐渐更新)

    manjaro(linux)系统各类命令合集(渐渐更新) wlan开启 系统默认的wlan是关闭的 sudo rmmod ideapad_laptop 查找以及安装命令 系统很多软件都是自带安装包的, ...

  7. linux服务器性能监控命令汇总(一)

    一.uptime 目录 一.uptime 1.使用 uptime 命令 2.以更人性化的格式显示时间 3.让 uptime 显示系统启动的日期/时间 4.获取版本信息和帮助信息 结论 二.top 1. ...

  8. Linux常用的命令--60个命令总结汇总

    Linux常用60个命令--实例详解 注:Linux系统中的命令实在是太多了,不可能像在MS DOS中把所有的命令及参数都记住.Linux系统提供了一些方法,比如可以通过"help" ...

  9. 操作系统实践 linux命令期末汇总

    操作系统实践 linux命令 Linux 1 简介 linux介绍 GPL linux发行版 linux系统标准化 登入与登出 常用快捷键 补充内容 Linux 2 Shell Shell 环境变量 ...

最新文章

  1. 免费的私人代码托管(bitbucket) 和 常用git指令
  2. appium+python自动化45-夜神模拟器连不上(adb server version (36) doesn't match this client (39); killing...)...
  3. yolov5 多版本共存
  4. Linux 内核开发 - Eclipse内核开发环境搭建
  5. 2.2.3 C语言中的整数类型及类型转换(为什么强制类型转换值发生改变?带你从机器码的角度分析)
  6. SQL注入(SQL注入(SQLi)攻击)攻击-联合注入
  7. android往天气接口里面传城市,Android使用中国天气网API数据通过城市名称获取天气情况...
  8. io多路复用的原理和实现_IO多路复用的三种机制:select 、poll 、epoll
  9. 步步为营-77-Ajax简介
  10. JavaScript对SEO的影响及解决之道
  11. Redis(案例一:注册登录-图形验证码+谷歌开源Kaptcha)
  12. 自己的利益,还是用户的名义?
  13. Asp.net2.0页面的生命周期
  14. 的mvc_你写的MVC,真的是MVC吗?
  15. discuz x2.5 广告位开发学习(第一步:摸索)
  16. 软件工程--螺旋模型详解
  17. CAS (4) —— CAS浏览器SSO访问顺序图详解(CAS Web Flow Diagram by Example)
  18. Pollard-rho的质因数分解
  19. 免费从Springer Link数据库中下载论文
  20. FEEDSKY获得风险投资

热门文章

  1. 芒课 —— 2464试题
  2. 蓝湖--UI切图软件,适用于ios,安卓,Web
  3. 光线追踪与全域光渲染keyshot中文
  4. 使用会议管理系统的高效办会思路
  5. 怎么实现EDIUS中添加的图片素材一样大
  6. 在Markdown文档中插入数学公式
  7. 【面试】上海 java开发工程师/自动化测试开发工程师 面试题
  8. 读书笔记 -《一生的计划》
  9. 小米电视怎么样?五大标准最有发言权
  10. Appium(Python)测试混血App