大数据开发工程师基本功修炼之史上最全Linux学习笔记(建议)_a)将三台虚拟机恢复到快照“大数据环境启动完成”

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取


### ====================================================================================================================================================================================


我把四篇笔记整合在一篇,如果不方便阅读,从可以看其余的三篇  
 `Linux学习笔记系列`:


[大数据开发工程师基本功修炼之Linux学习笔记(二)](https://bbs.csdn.net/topics/618545628)   
 [大数据开发工程师基本功修炼之Linux学习笔记(三)](https://bbs.csdn.net/topics/618545628)


[大数据开发工程师基本功修炼之Linux学习笔记(四)](https://bbs.csdn.net/topics/618545628)


## VI编辑器\_终端编辑器(重点重点重点)


## 目标


1. vi简介
2. 打开和新建文件
3. 三种工作模式
4. 常用命令查询


## 1 简介


### 1.1 学习vi的目的


* 在工作中, 要对 服务器上的 **文件**进行 简单 的修改, 可以使用 ssh 登录到远程服务器上, 并且使用 vi编辑器 进行简单的编辑即可
* 需要修改的文件包括


	+ 源代码
	+ 配置文件
		- 例如: tomcat服务器的配置文件
		- 例如: 网卡信息的配置文件在没有图形界面的环境下, 要编辑文件, vi是最佳选择  
 每一个使用linux的程序员,都应该或多或少的学习一些vi的常用命令


### 1.2 vi 和 vim


#### 1.2.1 VI


* vi是 `visual interface`的简称, 是linux中**最经典**的文本编辑器
* vi 的**核心设计思想**
	+ **让程序员的手指始终保持在键盘的 核心区域, 就能完成所有的编辑操作**
* vi的特点
	+ 只能是编辑 **文本内容**, 不能对 字体 段落进行排版
	+ **不支持鼠标操作**
	+ **没有菜单**
	+ **只有命令**
* vi编辑器在 **系统管理 服务器管理** 编辑文件时, **其功能永远不是图形界面的编辑器能比拟的**


#### 1.2.2 VIM


viM 是从vi发展出来的文本编辑器, 支持**代码补全、编译 及 错误跳转**等方便编程的功能提别丰富, 在程序员中被广泛使用, 被称为**编辑器之神**


## 2 打开和新建文件


* 在终端中输入vim在后面跟上 文件名 即可



vim 文件名


* 如果文件已经存在, 会直接打开该文件
* 如果文件不存在, 保存且退出时 就会新建一个文件



1 vim 没有的文件名
2 编辑内容
2.1 输出一行语句
2.2 复制粘贴 2.1内容 19次
2.3 保存且退出
3 查看


注意: 本节重点是 打开 和 新建文件, 其他命令后面会一一讲解


### 2.1 打开文件并且定位行


* 在日常工作中, 有可能会遇到打开一个文件, 并定位到指定行的情况
* 例如: 在开发是, 知道某一行代码有错误, 可以 快速定位 到出错误代码的位置
* 这个时候, 可以使用以下命令打开文件



vim 文件名 +行数



> 
> 提示: 如果只带上+ 而不指定行号, 会直接定位到文件末尾
> 
> 
> 


### 2.2 VI三种工作模式


* VI有三种工作模式


1. 命令模式
	* **打开文件首先进入命令模式**, 是使用vi的**入口**
	* 通过 **命令** 对文件进行常规的编辑操作, 例如 **定位 翻页 复制 粘贴 删除** … …
	* 在其他图形编辑器下, 通过 快捷键 或者 鼠标 实现的操作, 都在 **命令模式** 下实现
2. 末行模式 – 执行 **保存 退出**等操作
	* 要退出 vi 返回到控制台, 需要在莫行模式下输入命令
	* **末行模式** 是 vi 的**出口**
3. **编辑模式** – 正常的编辑文字


### 2.4 末行模式命令




| 命令 | 英文 | 功能 |
| --- | --- | --- |
| w | write | 保存 |
| q | quit | 退出,如果没有保存,不允许退出 |
| q! | quit | 强行退出,不保存退出 |
| wq | write & quit | 保存且退出(莫行模式) |
| x |  | 保存并退出(莫行模式) |
| ZZ |  | 保存并退出(命令模式) |


## 3 常用命令


### 学习提示


1. vi命令较多, **不要期望一下子全部都记住**, 个别命令忘记了, 只是会影响编辑速度而已  
 . 在使用vi命令时, **注意 关闭中文输入法**


### 3.1 移动


要熟练使用vi, 首先应该学会怎么在 命令模式下 快速移动光标  
 编辑操作命令 能够和移动命令一起使用


#### 1) 上 下 左 右


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-U5rRQWfx-1624685398652)(F:/%E4%BC%A0%E6%99%BA%E6%92%AD%E5%AE%A2/%E4%BC%A0%E6%99%BA%E4%B8%93%E4%BF%AE%E5%AD%A6%E9%99%A2/1812/01linux/%E8%AE%B2%E4%B9%89/02\_%E6%89%93%E5%8C%85%E5%8E%8B%E7%BC%A9\_vim%E7%BC%96%E8%BE%91%E5%99%A8\_%E7%B3%BB%E7%BB%9F%E7%AE%A1%E7%90%86\_%E7%94%A8%E6%88%B7%E6%9D%83%E9%99%90/%E7%AC%94%E8%AE%B0/assets/1558278451153.png)]




| 命令 | 功能 | 手指 |
| --- | --- | --- |
| h | 向左 | 食指 |
| j | 向下 | 食指 |
| k | 向上 | 中指 |
| l | 向右 | 无名指 |


#### 2) 行内移动




| 命令 | 英文 | 功能 |
| --- | --- | --- |
| w | word | 向后移动一个单词 |
| b | back | 向前移动一个单词 |
| 0 |  | 行首 |
| ^ |  | 行首, 第一个不是空白字符的位置 |
| $ |  | 行尾 |


#### 3) 行数移动




| 命令 | 英文 | 功能 |
| --- | --- | --- |
| gg | go | 文件顶部 |
| G | go | 文件末尾 |
| 数字gg | go | 移动到 数字 对应行数 |
| 数字G | go | 移动到 数字 对应行数 |
| : 数字 |  | 移动到数字对应的 行数 |


#### 4) 屏幕移动




| 命令 | 英文 | 功能 |
| --- | --- | --- |
| Ctrl + b | back | 向上翻页 |
| Ctrl + f | forward | 向下翻页 |
| H | Head | 屏幕顶部 |
| M | Middle | 屏幕中间 |
| L | Low | 屏幕底部 |


### 3.2 移动(程序)


#### 1) 段落移动


* vim中使用 空行 来区分段落
* 程序开发时, 通常 **一段功能相关的代码会写在一起** – 之间没有空行



| 命令 | 功能 |
| --- | --- |
| { | 上一段 |
| } | 下一段 |


#### 2) 括号切换


* 在程序世界中, \*\*()、[]、{}\*\*使用率很高, 而且 **都是成对出现的.**



| 命令 | 功能 |
| --- | --- |
| % | 括号匹配及切换 |


### 3.3 选中文本(可视模式)


* 学习 复制 命令前, 应该先学会 **怎么样选中 要复制的代码**
* 在 vi 中要选择文本, 需要显示 visual 命令切换到 **可视模式**
* vi 中提供了 **三种** 可视模式, 可以方便程序员的选择 **选中文本的方式**
* 按 ESC 可以放弃选中, 返回到 **命令模式**




| 命令 | 模式 | 功能 |
| --- | --- | --- |
| v | 可视模式 | 从光标位置开始按照正常模式选择文本 |
| V | 可视化模式 | 选中光标经过的完整行 |
| Ctrl + v | 可视块模式 | 垂直方向选中文本 |


* 可视模式下, 可以和 移动命令 连用, 例如 ggVG 能够 选中所有的内容


### 3.4 撤销和恢复撤销(保命指令)


在学习编辑命令之前,先要知道怎样撤销之前一次 错误的 编辑操作




| 命令 | 英文 | 功能 |
| --- | --- | --- |
| u | undo | 撤销上次的命令(ctrl + z) |
| Ctrl + r | uredo | 恢复撤销的命令 |


### 3.5 删除文本




| 命令 | 英文 | 功能 |
| --- | --- | --- |
| x | cut | 删除光标所在的字符,或者选中的文字 |
| d(移动命令) | delete | 删除移动命令对应的内容 |
| dd | delete | 删除光标所在行, 可以ndd删除多行 |
| D | delete | 删除至行尾 |


提示: 如果使用 可视模式 已经选中了一段文本, 那么无论使用 d 还是 x, 都可以删除选中文本


删除命令可以和移动命令连用, 以下是常见的组合命令:




| 命令 | 作用 |
| --- | --- |
| dw | 从光标位置删除到单词末尾 |
| d0 | 从光标位置删除到一行的起始位置 |
| d} | 从光标位置删除到段落末尾 |
| ndd | 从光标位置向下连续删除 n 行 |
|  |  |


### 3.6 复制和剪切


* vi 中提供有一个 被复制文本的缓冲区
	+ 复制 命令会将选中的文字保存在缓冲区
	+ 删除 命令删除的文字会被保存在缓冲区
	+ 在需要的位置, 使用 粘贴 命令可以将缓冲对的文字插入到光标所在的位置




| 命令 | 英文 | 功能 |
| --- | --- | --- |
| y(复制命令) | copy | 复制 |
| yy | copy | 复制一行,可以nyy复制多行 |
| d(剪切命令) | delete | 剪切 |
| dd(剪切) | delete | 剪切一行, 可以 ndd 剪切n行 |
| p | paste | 粘贴 |


提示:


* 命令 d 、x 类似于图形界面的 **剪切操作** – ctrl + x
* 命令 y 类似于 图形界面的 **复制操作** – Ctrl + C
* 命令 p 类似于图形界面的 **粘贴操作** – Ctrl + v
* vi中的文本缓冲区只有一个,如果后续做过 复制、剪切操作, 之前缓冲区中的内容会被替换.


注意


* vi中的 **文本缓冲区** 和 系统的 **剪切板** 不是同一个
* 所以在其他软件中使用 `Ctrl + C` 复制的内容, 不能再 `vi` 中通过 `p` 命令粘贴
* 可以在 **编辑模式** 下使用 **鼠标右键粘贴**


### 3.7 替换




| 命令 | 英文 | 功能 | 工作模式 |
| --- | --- | --- | --- |
| r | replace | 替换当前字符 | 命令模式 |
| R | replace | 替换当前行光标后的字符 | 替换模式 |


* `R` 命令可以进入 **替换模式**, 替换完成后, 按下`ESC` , 按下 `ESC` 可以回到 **命令模式**
* **替换命令** 的作用就是不用进入 **编辑模式**, 对文件进行 **轻量级的修改**


### 3.8 查找


常规查找




| 命令 | 功能 |
| --- | --- |
| /str | 查找str |


* 查找到指定内容之后, 使用 `Next` 查找下一个出现的位置


	+ `n` : 查找下一个
	+ `N` : 查找上一个
* 如果不想看到高亮显示, 可以随便查找一个文件中不存在的内容即可
* 单词快速匹配




| 命令 | 功能 |
| --- | --- |
| \* | 向后查找当前光标所在单词 |
| # | 向前查找当前光标所在单词 |


* 在开发中, 通过单词快速匹配, 可以快速看到这个单词在其他位置使用过


### 3.9 查找并替换


* 在 `vi` 中查找和替换命令需要在 **末行模式** 下执行
* 记忆命令格式



:%s///g


1. 全局替换


* 一次向 替换文件中的 所有出现的旧文本
* 命令格式如下

 

:%s/旧文本/新文本/g



2. 可视区域替换


* **先选中** 要替换文字的 **范围**
* 命令格式如下



😒/旧文本/新文本/g


3. 确认替换


c confirm 确认


* 如果把末尾的 `g` 改成 `gc` 在替换的时候, 会有提示! 推荐使用
* 命令格式如下

 

:%s/旧文本/新文本/gc



1. `y` - `yes` 替换
2. `n` - `no` 不替换
3. `a` - `all` 替换所有
4. `q` -`quit` 退出替换
5. `l` - `last` 最后一个, 并把光标移动到行首
6. `^E` 向下滚屏
7. `^Y` 向上滚屏


### 3.10 插入命令(重要)


* 在 vi 中除了常用 `i` 进入**编辑模式** 外, 还提供了一下命令同样可以进入编辑模式




| 命令 | 英文 | 功能 | 常用 |
| --- | --- | --- | --- |
| i | insert | 在当前字符前插入文本 | 常用 |
| I | insert | 在行首插入文本 | 较常用 |
| a | append | 在当前字符后添加文本 |  |
| A | append | 在行末添加文本 | 较常用 |
| o |  | 在当前行后面插入一空行 | 常用 |
| O |  | 在当前行前面插入一空行 | 常用 |


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RqHjJGgN-1624685398655)(F:/%E4%BC%A0%E6%99%BA%E6%92%AD%E5%AE%A2/%E4%BC%A0%E6%99%BA%E4%B8%93%E4%BF%AE%E5%AD%A6%E9%99%A2/1812/01linux/%E8%AE%B2%E4%B9%89/02\_%E6%89%93%E5%8C%85%E5%8E%8B%E7%BC%A9\_vim%E7%BC%96%E8%BE%91%E5%99%A8\_%E7%B3%BB%E7%BB%9F%E7%AE%A1%E7%90%86\_%E7%94%A8%E6%88%B7%E6%9D%83%E9%99%90/%E7%AC%94%E8%AE%B0/assets/1558543477231.png)]


### 3.11 练习


#### 演练1 – 编辑命令 和 数字连用


* 在开发中, 可能会遇到连续输入 N 个同样的字符
* 例如: `**********` 连续10个星号


要实现这个效果可以在 **命令模式** 下


1. 输入 `10`, 表示要重复10次
2. 输入 `i` 进入 **编辑模式**
3. 输入 `*` 也就是重复的文字
4. 按下 `ESC` 返回 **命令模式**, 返回之后 `vi` 就会把 第 `2、3` 两步的操作重复 `10` 次


提示: 正常开发时, 在 **进入编辑模式之前,不要按数字**


## 搜索命令


## 2.find 搜索


###### 准备工作


###### 切换目录到 /export/ 且 清空内容


cd /export/ && rm -rf /export/\* && tree


###### 新增目录 且 切换目录 且 新增文件


mkdir -p /export/aaa/bbb/ccc/ddd/eee/  
 touch /export/aaa/bbb/ccc/ddd/eee/abc.txt  
 touch /export/aaa/123.txt  
 touch /export/aaa/312.txt


###### 查看 /export 目录中的内容


tree /export


### 目标


* 通过`find`命令 **在特定目录下(包含它的后代目录)** 搜索 **符合条件**的文件


### 2.1 路径


* 第一步: 搜索指定目录下, 文件是 abc.txt的文件
* 第二步: 搜索指定目录下, 文件名 包含 `1` 的文件
* 第三步: 搜索指定目录下,所有以`.txt` 为扩展名的文件
* 第四步: 搜索指定目录下, 以数字`1`开头的文件


### 2.2实现 : 在指定目录中 根据名称 搜索


* #### 命令格式




| 序号 | 命令格式 | 作用 |
| --- | --- | --- |
| 01 | find [路径] -name ‘\*.txt’ | 查找指定路径下扩展名是 .txt的文件, 包括子目录 |


* 如果省略路径, 表示在当前文件夹下查找
* 之前学习的通配符, 在使用find命令时同时可用


* ##### 第一步: 搜索指定目录下, 文件是 abc.txt的文件



=实现目标==========

方式一: 指定全目录

find /export/ -name ‘abc.txt’

方式二: 当前目录

find . -name ‘abc.txt’

方式三: 当前目录 可以 省略 不写

find -name ‘abc.txt’


* ##### 第二步: 搜索指定目录下, 文件名 包含 `1` 的文件



===准备工作=

1 创建测试文件

touch /export/12.txt /export/616.txt /export/321.txt

===实现目录=

find /export/ -name “1


* ##### 第三步: 搜索指定目录下,所有以`.txt` 为扩展名的文件



find /export/ -name “*.txt”


* ##### 第四步: 搜索指定目录下, 以数字`1`开头的文件



find /export -name “1*”


### 2.3 小结


* 通过 `find [path] -name "*1*"` 完成根据名称搜索文件


## 解压缩命令


* 准备工作



清空指定目录内容

cd /export/ && rm -rf *

创建测试文件

touch 1.txt 2.txt 3.txt

创建有内容的测试目录

mkdir -p /export/aaa/
touch /export/aaa/4.txt /export/aaa/5.txt

查看结果

tree /export


## 目标


* 从第三方 **下载** 压缩包, **解压缩后** 安装到 服务器上![1558527865552](https://img-blog.csdnimg.cn/img_convert/8d8925d0546135c1b7684b55ba4f7483.png)
* 通过 **打包压缩** 备份文件


jar : java rar java项目的压缩包


war : web rar web项目的压缩包


## 路径


* **2.1 第一步: 打包 和 解包**
* \*\*2.2 第二步: 打包压缩 和 解包解压缩 \*\*


## 3.实现


#### 3.1 第一步: 打包 和 解包


##### 3.1.1 打包


* **类似将 冬天的衣服 放到 袋**
* 打包之后的大文件 需要以 `.tar` 结尾.


`tar` **打包**命令格式



将 一系列文件 打包成 一个大文件

tar -cvf 打包名.tar 被打包的目录
tar -cvf 打包名.tar 被打包的文件1 被打包的文件2 被打包的文件3


`tar` 选项说明




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| c | create | 生成档案文件, 创建打包文件 |
| v | verbosely(啰嗦的) | 像 ‘唐僧’ 一样报告进度 |
| f | file | 指定档案的文件名称, f后面一定是 `.tar` 文件, 所以必须放到左后 |



练习1: 将1.txt、2.txt、3.txt 打包成 123.tar文件

练习2: 将有内容的aaa目录 打包成 aaa.tar 文件


##### 3.1.2 解包


* **类似将 冬天的衣服 从 袋子里取出来**


`tar` **解包**命令格式



将一个打包后的 分解成 一系列小文件, 分解位置为 当前目录

tar -xvf 打包名.tar

将一个打包后的 分解成 一系列小文件, 分解位置为 指定目录

tar -xvf 打包名.tar -C 解包路径位置




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| x | extract (提取) | 解包 |
| C (大写C) | directory (目录) | 默认保存到当前目录, 通过`-C` 更改解压目录, 注意: 解压目录必须存在 |



练习1: 将 123.tar 解压到 当前目录中

练习2: 将 aaa.tar 解包到 /export/test/a1/b1/c1/ 目录中


##### 小结



打包: tar -cvf 打包之后的文件名.tar 被打包的目录或文件名

解包: tar -xvf 打包之后的文件名.tar [ -C 指定解包位置 ]


* 准备工作

 

清空指定目录内容

cd /export/ && rm -rf *

创建测试文件

touch 1.txt 2.txt 3.txt

创建有内容的测试目录

mkdir -p /export/aaa/
touch /export/aaa/4.txt /export/aaa/5.txt

查看结果

tree /export



#### 3.2 第二步: 使用gzip格式 压缩 和 解压缩


* **打包** 和 **压缩** 是两件事
* **类似与 先将冬天衣服放到压缩袋, 再抽取里面的空气**
* 在 `Linux` 中, 最常用的压缩文件格式是 `xxx.tar.gz`
* 在 `tar` 命令中有一个选项 -z 可以调用 `gzip` , 从而可以方便的实现压缩和解压缩的功能


命令格式如下



压缩文件

tar -zcvf 打包压缩文件名.tar.gz 被压缩的文件/目录

解压缩文件(记忆敲门: 至孝潍坊)

tar -zxvf 打包文件.tar.gz

解压缩到指定路径

tar -zxvf 打包文件.tar.gz -C 目录路径


`tar` 的选项说明




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| z | gzip | 使用gzip压缩和解压缩 |
| j | bzip2 | 使用bzip2压缩和解压缩 |



练习1: 将1.txt、2.txt、3.txt 打包压缩成 123.tar.gz文件(gzip压缩格式)

练习2: 将有内容的aaa目录 打包成 aaa.tar.gz 文件(gzip压缩格式)

练习3: 将 123.tar.gz 解压到 当前目录中(gzip压缩格式)

练习4: 将 aaa.tar.gz 解包到 /export/bbb 目录中(gzip压缩格式)


#### 小结



打包压缩: tar -zcvf 打包之后的文件名.tar.gz 被打包压缩的目录或文件名

解包解压缩: tar -zxvf 打包之后的文件名.tar.gz [ -C 指定解包位置 ]


* 准备工作

 

清空指定目录内容

cd /export/ && rm -rf *

创建测试文件

touch 1.txt 2.txt 3.txt

创建有内容的测试目录

mkdir -p /export/aaa/
touch /export/aaa/4.txt /export/aaa/5.txt

查看结果

tree /export



#### 3.3 第三步: 使用 bzip2 格式 压缩 和 解压缩


* `bzip` 是压缩的第二种方式
* **类似与 先将冬天衣服放到压缩袋, 再抽取里面的空气**
* 在 `Linux` 中, bzip2 压缩文件格式是 `xxx.tar.bz2`
* 在 `tar` 命令中有一个选项 -j 可以调用 `bzip2` , 从而可以方便的实现压缩和解压缩的功能


命令格式如下



压缩文件

tar -jcvf 打包压缩文件名.tar.bz2 被压缩的文件/目录

解压缩文件 (绩效潍坊)

tar -jxvf 打包文件.tar.bz2

解压缩到指定路径

tar -jxvf 打包文件.tar.bz2 -C 目录路径


`tar` 的选项说明




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| z | gzip | 使用gzip压缩和解压缩 |
| j | bzip2 | 使用bzip2压缩和解压缩 |



练习1: 将1.txt、2.txt、3.txt 打包压缩成 123.tar.bz2文件(bzip2压缩格式)

练习2: 将有内容的aaa目录 打包成 aaa.tar.bz2 文件(bzip2压缩格式)

练习3: 将 123.tar.bz2 解压到 当前目录中(bzip2压缩格式)

练习4: 将 aaa.tar.bz2 解包到 /export/bbb 目录中(bzip2压缩格式)


#### 小结



打包压缩: tar -jcvf 打包之后的文件名.tar.bz2 被打包压缩的目录或文件名

解包解压缩: tar -jxvf 打包之后的文件名.tar.bz2 [ -C 指定解包位置 ]


关机



halt


重启



reboot


## 4 用户权限相关命令


### 目标


* 理解 **用户** 和 **权限** 的基本概念
* **用户管理** 终端命令
* **组管理** 终端命令
* **修改权限** 终端命令


### 用户和权限的基本概念


#### 4.1 基本概念


* **用户** 是Linux系统工作中重要的一环, 用户管理包括 **用户** 与 **组** 管理
* 在Linux系统中, 不论是由本级或是远程登录系统, 每个系统都**必须拥有一个账号**, 并且**对于不同的系统资源拥有不同的使用权限**
* 对 **文件 / 目录** 的权限包括:




| 序号 | 权限 | 英文 | 缩写 | 数字序号 |
| --- | --- | --- | --- | --- |
| 01 | 读 | read | r | 4 |
| 02 | 写 | write | w | 2 |
| 03 | 执行 | execute | x | 1 |
| 04 | 无权限 |  | - | 0 |


* 在 Linux中 ,可以指定 **每一个用户** 针对 **不同的文件或者目录** 的 **不同权限**


![1558581559021](https://img-blog.csdnimg.cn/img_convert/f240de290992c749511983321eda47cb.png)


#### 4.2 组


* 为了方便用户管理, 提出了 **组** 的概念, 如下图所示![1558487112521](https://img-blog.csdnimg.cn/img_convert/6c87fda349d2c5c7260df2bb202333c0.png)


#### 4.3 ls -l 扩展


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lwckbqR0-1624685398660)(assets%5CUsers%5CAdministrator%5CAppData%5CRoaming%5CTypora%5Ctypora-user-images%5C1570973470529.png)]


* `ls -l` 可以查看文件夹下文件的详细信息, 从左到右 依次是:


	+ **权限**, 第一个字符如果是 `d` 表示目录
	+ **硬链接数**, 通俗的讲就是有多少种方式, 可以访问当前目录和文件
	+ **拥有者**, 家目录下 文件 / 木兰路 的拥有者通常都是 当前用户
	+ **组**, 在linux中, 很多时候, 会出现组名 和 用户名 相同的情况, 后续会讲
	+ **大小**
	+ **时间**
	+ **名称**![1558487141422](https://img-blog.csdnimg.cn/img_convert/5d60ca543df3747b8918ef5a6b4ce200.png)

 ![1558583116607](https://img-blog.csdnimg.cn/img_convert/fe9b2d1721acfba27fb43d7a7cf7ce46.png)


### 4.4.组管理 终端命令


**本质: 给 同一类型用户 分配权限**




| 序号 | 命令 | 作用 |
| --- | --- | --- |
| 01 | groupadd 组名 | 添加组 |
| 02 | groupdel 组名 | 删除组 |
| 03 | cat /etc/group | 确认组信息 |
| 04 | chgrp 组名 文件/目录名 | 修改文件/目录的所属组 |



> 
> 提示:
> 
> 
> * 组信息保存在 `/etc/group` 文件中
> * `/etc` 目录是专门用来保存 **系统配置信息** 的目录
> 
> 
> 


* 在实际应用中, 可以预先针对 **组** 设置好权限, 然后 **将不同的用户添加到对应的组中**, 从而**不用依次为每一个用户设置权限**


**演练目标**


1. 在 指定目录下 创建 `aaa` 目录
2. 新建 `dev` 组
3. 将 `aaa` 目录的组修改为 `dev`


### 4.5.用户管理 终端命令


#### (1) 创建用户 / 设置密码 / 删除用户




| 命令 | 作用 | 说明 |
| --- | --- | --- |
| useradd -m -g 组 新建用户名 | 添加新用户 | `-m` 自动建立用户家目录 `-g` 指定用户所在的组, 否则会建立一个和同名的组 |
| passwd 用户名 | 设置用户密码 | 如果是普通用户,直接用 passwd可以修改自己的账号密码 |
| userdel -r 用户名 | 删除用户 | `-r` 选项会自动删除用户家目录 |
| cat /etc/passwd | grep 用户名 | 确认用户信息 | 新建用户后,用户信息会保存在 `/etc/passwd`文件夹中 |



> 
> 提示:
> 
> 
> * 创建用时, 如果忘记添加 `-m` 选项指定新用户的家目录 – 最简单的方式就是**删除用户,重新创建**
> * 创建用户时, 默认会创建一个和**用户名**同名的**组名**
> * 用户信息保存在 **/etc/passwd** 文件中
> 
> 
> 


`/etc/passwd` 文件存放的是用户的信息, 由6个分好组成的7个信息, 分别是


![1558487197175](https://img-blog.csdnimg.cn/img_convert/06093c08a0514ac6cd1f0842937e3fb9.png)


1. 用户名
2. 密码 (x, 表示加密的密码)
3. UID (用户标志)
4. GID(组标志)
5. 用户全名或本地账号
6. 家目录
7. 登录使用的Shell, 就是登录之后, 使用的终端命令


#### (2) 查看用户信息




| 序号 | 命令 | 作用 |
| --- | --- | --- |
| 01 | id [用户名] | 查看用户UID 和 GID 信息 |
| 02 | who | 查看当前所有登录的用户列表 |
| 03 | whoami | 查看当前登录用户的账户名 |


#### (3) `su` 切换用户


![1558614565424](https://img-blog.csdnimg.cn/img_convert/86962a174629d68cb5f92d53ec6f8209.png)


* **因为 普通用户 不能使用某些权限, 所以需要 切换用户**




| 序号 | 命令 | 作用 | 说明 |
| --- | --- | --- | --- |
| 01 | su `-` 用户名 | 切换用户, 并且企划目录 | `-` 可以切换到用户家目录, 否则保持位置不变 |
| 02 | exit | 退出当前登录用户 |  |


* `su` 不接用户名, 可以切换到 `root` , 但是不推荐使用, 因为不安全
* `exit` 示意图如下:


![1558487219340](https://img-blog.csdnimg.cn/img_convert/025f7ac4c2163bbfea08806de88e7766.png)


#### (4) **sudo**


* **虽然** 通过 `su -u root` 可以切换到 **root用户**, **但是** 存在严重的 **安全隐患**


* linux系统中的 `root` 账号通常 **用于系统的维护和管理**, 对操作系统的所有资源 **具有访问权限**
* 如果不小心使用 `rm -rf ... ...` , 就可能将系统搞瘫痪
* 在大多数版本的linux中, 都不推荐 **直接只用 root 账号登录系统**
* `sudo` 命令用来以其他身份来执行命令, 预设的身份为 `root`
* 用户使用 `sudo` 时, 必须先输入密码, 之后**5分钟的有效期限**, 超过期限则必须重新输入密码



> 
> 提示: 若其未经授权的用户企图使用 sudo, 则会发出警告邮件给管理员
> 
> 
>


#### (4.1) 给 指定用户 授予 权限


* **本质: 通知 服务器 给 特定用户 分配 临时管理员权限**


vim /etc/sudoers



默认存在: root用户 具备所有的权限

root ALL=(ALL) ALL

授予 zhangsan 用户 所有的权限

zhangsan ALL=(ALL) ALL


#### (4.2) 使用 用户 `zhangsan` 登录, 操作管理员命令


* 本质: **使用临时管理员权限**



不切换root用户, 也可以完成 添加用户的功能

sudo useradd -m -g dev zhaoliu


准备工作: 使用root用户操作



清空目录中的内容

rm -rf /export/*

创建测试目录

mkdir -p /export/aaa/

创建测试文件

touch /export/aaa/01.txt /export/aaa/02.txt

查看指定目录内容

tree /export


### (5).修改用户权限




| 序号 | 命令 | 作用 |
| --- | --- | --- |
| 01 | chmod | 修改权限 |


### 5.1 方式一: 修改用户权限


* `chmod` 可以修改 **用户/组** 对 **文件/目录** 的权限
* 命令格式如下:

 

chmod +/- rwx 文件名|目录名



> 
> 提示: 已上方式会一次向修改 `拥有者` / `组`权限
> 
> 
>


#### 目标演练:



1. 使用 root 删除目录的可读 可写 可执行权限

2. 使用 其他用户如 zhangsan 无法切换到 这个目录

3. 使用 root 增加目录的执行权限, 再次 使用 zhangsan 切换到目录试试


### 5.2 方式二


* 虽然 方式一 直接修改**文件|目录**的 **读|写|执行** 权限, 但是不能精确到 **拥有者|组|其他** 权限
* 命令格式如下:( `u` 表示所属用户 / `g` 表示所属组 / `o` 表示其他)



chmod -R u=rwx,g=rx,o=rwx 文件|目录




| 序号 | 权限 | 英文 | 缩写 | 数字序号 |
| --- | --- | --- | --- | --- |
| 01 | 读 | read | r | 4 |
| 02 | 写 | write | w | 2 |
| 03 | 执行 | execute | x | 1 |
| 04 | 无权限 |  | - | 0 |


#### 目标演练:



1 使用root用户给 所属用户分配 可读、可写、可执行 权限,

所属组 分配 可读、可执行 权限, 
其他人 分配 可读、可执行 权限 

### 5.3 方式三: 简化方式二


* 命令格式如下:



chmod -R 755 文件|目录


* 说明 **第一个数字** 是 **拥有者权限**, **第二个数字** 是 **组权限**, **第三个数字** 是 **其他用户权限**


![1558487247085](https://img-blog.csdnimg.cn/img_convert/a1b8003a38d7cf217e704f570aec6033.png)


常用数字组合有( `u` 表示用户 / `g` 表示组 / `o` 表示其他)


* `777` ===> `u=rwx, g=rwx, o=rwx`
* `755` ===> `u=rwx, g=rx, o=rx`
* `644` ===> `u=rw, g=r, o=r`


#### 目标演练:



1 使用root用户给 所属用户分配 可读、可写、可执行 权限,

所属组 分配 可读、可执行 权限, 
其他人 分配 可读、可执行 权限 

## 系统信息相关命令


* 本节内容主要是为了方便通过远程终端维护服务器时, 查看服务器上当前 **系统日期和时间 / 磁盘空间占用情况 /程序执行情况**
* 本小结学习终端命令都是查询命令, 通过这些命令对系统资源的使用情况有个了解


## 目标


* 时间和日期
	+ `date`
	+ `cal`
* 磁盘和目录空间
	+ `df`
	+ `du`
* 进程信息
	+ `ps`
	+ `top`
	+ `kill`


## 1.时间和日期


### 1.1 date 时间




| 命令 | 作用 |
| --- | --- |
| date | 查看系统时间(**默认**) |
| date +"%Y-%m-%d %H:%M:%S" | 查看系统时间(**指定格式**) |
| date -s “时间字符串” | 设置系统时间 |


#### 第一步: 显示当前时间



显示时间

date

按照指定格式显示时间

date +“%Y-%m-%d %H:%M:%S”


#### 第二步: 设置系统时间



date -s “时间字符串”


### 1.2 cal 日历




| 序号 | 命令 | 作用 |
| --- | --- | --- |
| 01 | cal | 查看当前月的日历 |
| 02 | cal -y | 查看当前年的日历 |
| 03 | cal 2020 | 查看2020年的日历 |
| 04 | cal 10 2020 | 查看2020年10月的日历 |


## 02.磁盘信息




| 序号 | 命令 | 作用 |
| --- | --- | --- |
| 01 | df -h | disk free 显示磁盘剩余空间 |
| 02 | du -h [目录名] | disk usage 显示目录下的目录大小 |


* 选项说明




| 参数 | 含义 |
| --- | --- |
| -h | 以人性化的方式显示文件的大小 |


## 03.进程信息


* 所谓 **进程**, 通俗的说就是 **当前正在执行的一个进程**




| 序号 | 命令 | 作用 |
| --- | --- | --- |
| 01 | ps aux | process status 查看进程的详细情况 |
| 02 | top | 动态显示运行中进程并且排序 |
| 03 | kill [-9] 进程代号 | 终止指定代号的进程 -9 表示强行终止 |



> 
> `ps` 默认只会显示当前用户通过终端启动的应用程序
> 
> 
> 


* `ps` 选项说明功能



| 选项 | 含义 |
| --- | --- |
| a | 显示终端上的所有进程,包括其他用户的进程 |
| u | 显示进程的详细状态 |
| x | 显示没有控制终端的进程 |


> 
> 提示: 使用`kill`命令时, 最好只终止由当前用户开启的进程, 而不要终止`root`身份开启的进程, 否则可能导致系统崩溃
> 
> 
>
* 要退出 `top` 可以直接输入 `q`


top


![在这里插入图片描述](https://img-blog.csdnimg.cn/20210626133237640.png)



us 用户空间占用CPU百分比
sy 内核空间占用CPU百分比
ni 用户进程空间内改变过优先级的进程占用CPU百分比
id 空闲CPU百分比
wa 等待输入输出的CPU时间百分比
hi 硬件中断
si 软件中断
st: 实时


![在这里插入图片描述](https://img-blog.csdnimg.cn/20210626133227731.png)


PID 进程号  
 USER 用户名  
 PR 优先级  
 NI nice值。负值表示高优先级,正值表示低优先级m  
 RES 进程使用的、未被换出的物理内存大小,单位kb  
 SHR 共享内存大小,单位kb  
 S 进程状态。  
 D=不可中断的睡眠状态  
 R=运行  
 S=睡眠  
 T=跟踪/停止  
 Z=僵尸进程  
 %CPU CPU使用率  
 %MEM 进程使用的物理内存百分比  
 TIME+ 进程使用的CPU时间总计,单位1/100秒  
 COMMAND 执行的命令


## 管道相关命令


### 目标


* `cut`
* `sort`
* `wc`
* `uniq`
* `tee`
* `tr`
* `split`
* `awk`
* `sed`
* `grep`


* 准备工作

 

zhangsan 68 99 26
lisi 98 66 96
wangwu 38 33 86
zhaoliu 78 44 36
maq 88 22 66
zhouba 98 44 46

* 以上是成绩表信息
* 使用 逗号 分割, 第一列 是 姓名, 第二列是 语文成绩, 第三列是 数学成绩, 第四列是 英语成绩


准备工作


vim 1.txt



111:aaa:bbb:ccc
222:ddd:eee:fff
333:ggg:hhh
444:iii


## 1 cut


### 1.1 目标


* `cut` 根据条件 从命令结果中 **提取** 对应内容


### 1.2 实现


#### 第一步: 截取出1.txt文件中前2行的第5个字符




| 命令 | 含义 |
| --- | --- |
| cut 动作 文件 | 从指定文件 截取内容 |


* 参数




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| -c | characters | 按字符选取内容 |



head -2 1.txt | cut -c 5


#### 第二步: 截取出1.txt文件中前2行以”:”进行分割的第1,2段内容




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| `-d '分隔符'` | delimiter | 指定分隔符 |
| `-f n1,n2` | fields | 分割以后显示第几段内容, 使用 `,` 分割 |


**范围控制**




| 范围 | 含义 |
| --- | --- |
| `n` | 只显示第n项 |
| `n-` | 显示 从第n项 一直到行尾 |
| `n-m` | 显示 从第n项 到 第m项(包括m) |



head -2 1.txt | cut -d ‘:’ -f 1,2



head -2 1.txt | cut -d ‘:’ -f 1-2


### 1.3 小结


* 通过 `cut 动作 目标文件` 可以根据条件 提取对应内容


* 准备工作

 vim score.txt

 

zhangsan 68 99 26
lisi 98 66 96
wangwu 38 33 86
zhaoliu 78 44 36
maq 88 22 66
zhouba 98 44 46



## 2 sort


### 2.1 目标


* sort可针对文本文件的内容,以行为单位来排序。


### 2.2 路径


* 第一步: 对字符串排序
* 第二步: 去重排序
* 第三步: 对数值排序
* 第四步: 对成绩排序


### 2.3 实现


#### 第一步: 对字符串排序



[root@node01 tmp]# cat 2.txt
banana
apple
pear
orange
pear

[root@node01 tmp]# sort 2.txt
apple
banana
orange
pear
pear


#### 第二步: 去重排序




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| `-u` | unique | 去掉重复的 |


它的作用很简单,就是在输出行中去除重复行。



[root@node01 tmp]# sort -u 2.txt
apple
banana
orange
pear


#### 第三步: 对数值排序




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| `-n` | numeric-sort | 按照数值大小排序 |
| `-r` | reverse | 使次序颠倒 |


* 准备数据

 

[root@node01 tmp]# cat 3.txt
1
3
5
7
11
2
4
6
10
8
9

* 默认按照`字符串`排序

 

[root@node01 tmp]# sort 2.txt
1
10
11
2
3
4
5
6
7
8
9

* 升序

 

[root@node01 tmp]# sort -n 2.txt
1
2
3
4
5
6
7
8
9
10
11

* 倒序

 

[root@node01 tmp]# sort -n -r 2.txt
11
10
9
8
7
6
5
4
3
2
1

* 合并式

 

[root@node01 tmp]# sort -nr 2.txt
11
10
9
8
7
6
5
4
3
2
1



#### 第四步: 对成绩排序




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| `-t` | field-separator | 指定字段分隔符 |
| `-k` | key | 根据那一列排序 |


‘’



根据第二段成绩 进行倒序显示 所有内容

sort -t ‘,’ -k2nr score.txt


## 3 wc命令


### 3.1 目标


* 显示指定**文件** **字节数, 单词数, 行数** 信息.


### 3.2 路径


* 第一步: 显示指定**文件** **字节数, 单词数, 行数** 信息.
* 第二步: 只显示 文件 的行数
* 第三步: 统计多个文件的 行数 单词数 字节数
* 第四步: 查看 `/etc` 目录下 有多少个 子内容


### 3.3 实现


#### 第一步: 显示指定**文件** **字节数, 单词数, 行数** 信息.




| 命令 | 含义 |
| --- | --- |
| wc 文件名 | 显示指定**文件** **字节数, 单词数, 行数** 信息 |



[root@hadoop01 export]# cat 4.txt
111
222 bbb
333 aaa bbb
444 aaa bbb ccc
555 aaa bbb ccc ddd
666 aaa bbb ccc ddd eee

[root@hadoop01 export]# wc 4.txt
6 21 85 4.txt


#### 第二步: 只显示 文件 的行数




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| `-c` | bytes | 字节数 |
| `-w` | words | 单词数 |
| `-l` | lines | 行数 |



[root@hadoop01 export]# wc 4.txt
6 21 85 3.txt


#### 第三步: 统计多个文件的 行数 单词数 字节数



[root@hadoop01 export]# wc 1.txt 2.txt 3.txt
4 4 52 1.txt
11 11 24 2.txt
6 21 85 3.txt
21 36 161 总用量

[root@hadoop01 export]# wc *.txt
4 4 52 1.txt
11 11 24 2.txt
6 21 85 3.txt
6 6 95 score.txt
27 42 256 总用量


#### 第四步: 查看 `/etc` 目录下 有多少个 子内容



[root@hadoop01 export]# ls /etc | wc -w
240


### 3.4 小结


* 通过 `wc 文件` 就可以 **统计** 文件的 **字节数、单词数、行数**.


## 4 uniq


uniq 命令用于检查及删除文本文件中重复出现的行,一般与 sort 命令结合使用。


### 4.1 目标


* ###### uniq 命令用于检查及删除文本文件中重复出现的行,一般与 sort 命令结合使用。


### 4.2路径


* 第一步:实现去重效果
* 第二步:不但去重,还要 统计出现的次数


### 4.3 实现


#### 第一步:实现去重效果




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| `uniq [参数] 文件` | unique 唯一 | 去除重复行 |



准备内容

[root@hadoop01 export]# cat 5.txt
张三 98
李四 100
王五 90
赵六 95
麻七 70
李四 100
王五 90
赵六 95
麻七 70

排序

[root@hadoop01 export]# cat 5.txt | sort
李四 100
李四 100
麻七 70
麻七 70
王五 90
王五 90
张三 98
赵六 95
赵六 95

去重

[root@hadoop01 export]# cat 5.txt | sort | uniq
李四 100
麻七 70
王五 90
张三 98
赵六 95


#### 第二步:不但去重,还要 统计出现的次数




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| `-c` | count | 统计每行内容出现的次数 |



[root@hadoop01 export]# cat 5.txt | sort | uniq -c
2 李四 100
2 麻七 70
2 王五 90
1 张三 98
2 赵六 95


### 4.4 小结


* 通过 `uniq [选项] 文件` 就可以完成 去重行 和 统计次数


## 5 tee


### 5.1 目标


* 通过 `tee` 可以将命令结果 **通过管道** 输出到 **多个文件**中


### 5.2 实现




| 命令 | 含义 |
| --- | --- |
| 命令结果 | tee 文件1 文件2 文件3 | 通过 `tee` 可以将命令结果 **通过管道** 输出到 **多个文件**中 |


* #### 将去重统计的结果 放到 a.txt、b.txt、c.txt 文件中

 

cat 5.txt | sort | uniq -c | tee a.txt b.txt c.txt



### 5.3 小结


* 通过 `tee` 可以将命令结果 **通过管道** 输出到 **多个文件**中


## 6 tr


### 6.1 目标


* 通过 `tr` 命令用于 **替换** 或 **删除** 文件中的字符。


### 6.2 路径


* 第一步: 实现 **替换** 效果
* 第二步: 实现 **删除** 效果
* 第三步: 完成 **单词计数** 案例


### 6.3 实现


#### 第一步: 实现 替换效果




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| 命令结果 | tr 被替换的字符 新字符 | translate | 实现 替换效果 |



将 小写i 替换成 大写 I

把itheima的转换为大写

把 HELLO 转成 小写



将 小写i 替换成 大写 I

echo “itheima” | tr ‘i’ ‘I’

把itheima的转换为大写

echo “itheima” |tr ‘[a-z]’ ‘[A-Z]’

把 HELLO 转成 小写

echo “HELLO” |tr ‘[A-Z]’ ‘[a-z]’


#### 第二步: 实现删除效果




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| 命令结果 | tr -d 被删除的字符 | delete | 删除指定的字符 |


* **需求: 删除abc1d4e5f中的数字**



echo ‘abc1d4e5f’ | tr -d ‘[0-9]’


#### 第三步: 单词计数


###### 准备工作



[root@hadoop01 export]# cat words.txt
hello,world,hadoop
hive,sqoop,flume,hello
kitty,tom,jerry,world
hadoop


1 将, 换成 换行


2 排序


3 去重


4 计数



统计每个单词出现的次数

[root@hadoop01 export]# cat words.txt | tr ‘,’ ‘\n’ | sort | uniq -c
1 flume
2 hadoop
2 hello
1 hive
1 jerry
1 kitty
1 sqoop
1 tom
2 world


* 准备工作

 

查看 /etc目录下 以.conf以结尾的文件的内容

cat -n /etc/*.conf

将命令结果 追加到 /export/v.txt 文件中

cat -n /etc/*.conf >> /export/v.txt



## 7 split


### 7.1 目标


* 通过 `split` 命令将**大文件** **切分成** 若干**小文件**


### 7.2 路径


* 第一步: 按 **字节** 将 大文件 切分成 若干小文件
* 第二步: 按 **行数** 将 大文件 切分成 若干小文件


### 7.3 实现


#### 第一步: 按 **字节** 将 大文件 切分成 若干小文件




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| split -b 10k 文件 | byte | 将大文件切分成若干**10KB**的小文件 |


#### 第二步: 按 **行数** 将 大文件 切分成 若干小文件




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| split -l 1000 文件 | lines | 将大文件切分成若干**1000行** 的小文件 |


### 7.4 小结


* 通过 `split 选项 文件名` 命令将**大文件** **切分成** 若干**小文件**
* 准备工作1:

 vim score.txt

 

zhangsan 68 99 26
lisi 98 66 96
wangwu 38 33 86
zhaoliu 78 44 36
maq 88 22 66
zhouba 98 44 46



## 8 awk


### 8.1 目标


* 通过 `awk` 实现 **模糊查询**, **按需提取字段**, 还可以进行 **判断** 和 简单的**运算**等.


### 8.2 步骤


* 第一步: 模糊查询
* 第二步: 指定分割符, 根据下标显示内容
* 第三步: 指定输出字段的分割符
* 第四步: 调用 awk 提供的函数
* 第五步: 通过if语句判断$4是否及格
* 第六步: 段内容 求和


### 8.3 实现


#### 第一步: 搜索 zhangsan 和 lisi 的成绩




| 命令 | 含义 |
| --- | --- |
| awk ‘/zhangsan|lisi/’ score.txt | 模糊查询 |


#### 第二步: 指定分割符, 根据下标显示内容




| 命令 | 含义 |
| --- | --- |
| awk -F ‘,’ ‘{print $1, $2, $3}’ 1.txt | 操作1.txt文件, 根据 逗号 分割, 打印 第一段 第二段 第三段 内容 |


选项




| 选项 | 英文 | 含义 |
| --- | --- | --- |
| `-F ','` | field-separator | 使用 **指定字符** 分割 |
| `$ + 数字` |  | 获取**第几段**内容 |
| `$0` |  | 获取 **当前行** 内容 |
| `NF` | field | 表示当前行共有多少个字段 |
| `$NF` |  | 代表 最后一个字段 |
| `$(NF-1)` |  | 代表 倒数第二个字段 |
| `NR` |  | 代表 处理的是第几行 |


#### 第三步: 指定分割符, 根据下标显示内容




| 命令 | 含义 |
| --- | --- |
| awk -F ’ ’ ‘{OFS="==="}{print $1, $2, $3}’ 1.txt | 操作1.txt文件, 根据 逗号 分割, 打印 第一段 第二段 第三段 内容 |


选项




| 选项 | 英文 | 含义 |
| --- | --- | --- |
| `OFS="字符"` | output field separator | 向外输出时的段分割字符串 |


#### 第四步: 调用 awk 提供的函数




| 命令 | 含义 |
| --- | --- |
| awk -F ‘,’ ‘{print toupper($2)}’ 1.txt | 操作1.txt文件, 根据 逗号 分割, 打印 第一段 第二段 第三段 内容 |


常用函数如下:




| 函数名 | 含义 | 作用 |
| --- | --- | --- |
| toupper() | upper | 字符 转成 大写 |
| tolower() | lower | 字符 转成小写 |
| length() | length | 返回 字符长度 |


#### 第五步: if语句 查询及格的学生信息




| 命令 | 含义 |
| --- | --- |
| awk -F ‘,’ ‘{if($4>60) print $1, $4 }’ score.txt | 如果及格,就显示 $1, $4 |
| awk -F ‘,’ ‘{if($4>60) print $1, $4, “及格”; else print $1, $4, “不及格”}’ score.txt | 显示 姓名, $4, 是否及格 |


选项




| 参数 | 含义 |
| --- | --- |
| if($0 ~ “aa”) print $0 | 如果这一行包含 “aa”, 就打印这一行内容 |
| if($1 ~ “aa”) print $0 | 如果\*\*第一段 \*\*包含 “aa”, 就打印这一行内容 |
| if($1 == “lisi”) print $0 | 如果**第一段 等于** “lisi”, 就打印这一行内容 |


#### 第六步: 段内容 求学科平均分




| 命令 | 含义 |
| --- | --- |
| awk ‘BEGIN{初始化操作}{每行都执行} END{结束时操作}’ 文件名 | BEGIN{ 这里面放的是执行前的语句 }{这里面放的是处理每一行时要执行的语句}END {这里面放的是处理完所有的行后要执行的语句 } |



awk -F ‘,’ ‘BEGIN{}{total=total+$4}END{print total, NR, (total/NR)}’ score.txt


* 准备工作

 vim 1.txt

 

aaa java root
bbb hello
ccc rt
ddd root nologin
eee rtt
fff ROOT nologin
ggg rttt



## 9 sed


### 9.1 目标


* 通过 sed 可以实现 **过滤** 和 **替换** 的功能.


### 9.2 路径


* 第一步: 实现 查询 功能
* 第二步: 实现 删除 功能
* 第三步: 实现 修改 功能
* 第四步: 实现 替换 功能
* 第五步: 对 原文件 进行操作
* 第六步: 综合 练习


### 9.3 实现


#### 第一步: 实现 查询 功能




| 命令 | 含义 |
| --- | --- |
| sed 可选项 目标文件 | 对目标文件 进行 **过滤查询** 或 **替换** |


可选参数




| 可选项 | 英文 | 含义 |
| --- | --- | --- |
| p | print | 打印 |
| $ |  | 代表 最后一行 |
| `-n` |  | 仅显示处理后的结果 |
| `-e` | expression | 根据表达式 进行处理 |


* ##### 练习1 列出 1.txt的 1~5行 的数据



sed -n -e ‘1,5p’ 1.txt


* ##### 练习2 列出01.txt的所有数据



sed -n -e ‘1,$p’ 1.txt


* ##### 练习3 列出01.txt的所有数据 且 显示行号




| 可选项 | 含义 |
| --- | --- |
| = | 打印当前行号 |



sed -n -e ‘1, = ′ − e ′ 1 , =' -e '1, =e1,p’ 1.txt

简化版
cat -n 1.txt
cat -b 1.txt
nl 1.txt


* ##### 练习4: 查找01.txt中包含root行


答案:



sed -n -e ‘/root/p’ 1.txt


* ##### 练习5 列出01.txt中包含root的内容,root不区分大小写,并显示行号




| 可选项 | 英文 | 含义 |
| --- | --- | --- |
| I | ignore | 忽略大小写 |


答案:



nl 1.txt | sed -n -e ‘/root/Ip’

nl 01.txt | grep -i root

cat -n 01.txt | grep -i root


* ##### 练习6 查找出1.txt中 字母`r`后面是多个t的行,并显示行号




| 可选项 | 英文 | 含义 |
| --- | --- | --- |
| `-r` | regexp-extended | 识别正则 |


答案:



nl 01.txt | sed -nr -e ‘/r+t/p’


或者



sed -nr -e ‘/r+t/p’ -e ‘/r+t/=’ 01.txt


#### 第二步: 实现 删除 功能


* ##### 练习1 删除01.txt中前3行数据,并显示行号




| 可选项 | 英文 | 含义 |
| --- | --- | --- |
| `d` | delete | 删除指定内容 |


答案:



nl 01.txt | sed -e ‘1,3d’


* ##### 练习2 保留1.txt中前4行数据,并显示行号


答案:



nl 01.txt | sed -e ‘5,$d’

nl 1.txt | sed -n -e ‘1,4p’


#### 第三步: 实现 修改 功能


* ##### 练习1: 在01.txt的第二行后添加aaaaa,并显示行号




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| i | insert | 目标**前面** 插入内容 |
| a | append | 目标**后面** 追加内容 |


答案:



nl 01.txt | sed -e ‘2a aaaaa’


* ##### 练习2 在1.txt的第1行前添加bbbbb,并显示行号


答案:



nl 01.txt | sed -e ‘1i bbbbb’


#### 第四步: 实现 替换 功能


* ##### 练习1 把1.txt中的nologin替换成为huawei,并显示行号




|  | 英文 | 含义 |
| --- | --- | --- |
| s/oldString/newString/ | replace | 替换 |


答案:



nl 1.txt | sed -e ‘s/nologin/huawei/’


* ##### 练习2 把01.txt中的1,2行替换为aaa,并显示行号




| 选项 | 英文 |  |
| --- | --- | --- |
| `2c 新字符串` | replace | 使用新字符串 替换 选中的行 |


答案:



nl passwd | sed -e ‘1,2c aaa’


#### 第五步: 对 原文件 进行操作


* ##### 练习1 在01.txt中把nologin替换为 huawei




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| -i | in-place | 替换原有文件内容 |


答案:



sed -i -e ‘s/nologin/huawei/’ 01.txt


* ##### 练习2 在01.txt文件中第2、3行替换为aaaaaa


答案:



sed -i -e ‘2,3c aaa’ 01.txt


注意:在进行操作之前,最好是对数据进行备份,放置操作失误,数据无法恢复!


* ##### 练习3 删除01.txt中前2行数据,并且删除原文件中的数据


答案:



sed -i -e ‘1,2d’ 01.txt

nl passwd 查看数据


#### 第六步: 综合 练习


* ##### 练习1 获取ip地址


答案:



ifconfig eth0 | grep “inet addr” | sed -e ‘s/^.inet addr://’ | sed -e 's/Bcast:.$//’


* ##### 练习2 从1.txt中提出数据,匹配出包含root的内容,再把nologin替换为itheima


答案:



nl 01.txt | grep ‘root’ | sed -e ‘s/nologin/itheima/’

或者

nl 01.txt | sed -n -e ‘/root/p’ | sed -e ‘s/nologin/itheima/’

或者

nl 01.txt | sed -n -e ‘/root/{s/nologin/itheima/p}’ #只显示替换内容的行


* ##### 练习3 从1.txt中提出数据,删除前2行,并把nologin替换为itheima,并显示行号


答案:



nl 01.txt | sed -e ‘1,2d’ | sed -e ‘s/nologin/itheima/’


## 1 挂载新的硬盘


### 1.1 目标


* 虚拟机 增加一块 硬盘


### 1.2 路径


* 第一步: 了解linux系统分区的原理
* 第二步: 查看系统分区情况
* 第三步: 虚拟机 增加 硬盘
* 第四步: 分区
* 第五步: 格式化
* 第六步: 挂载
* 第七步: 设置重启后 挂载不失效


### 1.3 实现


#### 第一步: 了解linux系统分区的原理


* 一个硬盘可以分成多个分区
* 用户不能直接操作硬件, 需要 让硬件和系统的目录 **建立映射关系(挂载)** 才可以操作, 称为 挂载


![1558956599018](https://img-blog.csdnimg.cn/img_convert/4f244ab3d7b7bbcf039b86d495808d1d.png)


#### 第二步: 查看系统分区挂载情况




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| `lsblk -f` | list block devices | 查看所有设备的挂载情况 |




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| `-f` | file system | 文件系统 |


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-F5x3IfHz-1624685690449)(assets/1558957195965.png)]


* `lsblk` 的记忆小窍门: **老师不离开** 的首字母


#### 第三步: 虚拟机 增加 硬盘


* 模拟将买的硬盘插入到 **服务器中**


1. 选中 目标虚拟机 右键 **设置**
2. 选中 **硬盘** 点击 **添加按钮**
3. 点击 **下一步**
4. 选择 **创建新虚拟磁盘**
5. 指定 磁盘大小为**10G**
6. 完成
7. 注意: **重启** 才可以生效


![1558958276486](https://img-blog.csdnimg.cn/img_convert/03886f845cf123e08d0665e122b72068.png)


#### 第四步: 分区




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| `fdisk /dev/sdb` | partition | 开始指定磁盘分区 |


分区命令可选项




| 选项 | 英文 | 含义 |
| --- | --- | --- |
| m | menu | 显示命令列表 |
| n | new | 新增分区 |
| p | partition | 显示磁盘分区 |
| d | delete | 删除分区 |
| w | write and exit | 写入 并 退出 |


##### 操作如下:


1. `fdisk /dev/sdb` 开始分区
2. 输入 `m` , 进入 目录列表
3. 输入 `n` , 新增分区
4. 输入 `p` , 开始分区, 后面按回车
5. 最后 输入 `w`, 保存 且 退出
6. `lsblk -f` 查看是否成功


![1558959380950](https://img-blog.csdnimg.cn/img_convert/2d3f7adda27d51e7f87e68d5a0929706.png)


#### 第五步: 格式化




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| `mkfs -t ext4 /dev/sdb1` | build a Linux file system | 格式化指定分区 |




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| `-t` | file system type | 指定文件系统类型 |


##### 操作如下


1. `mkfs -t ext4 /dev/sdb1` 格式化指定分区
2. `lsblk -f` 查看是否成功


![1558959798742](https://img-blog.csdnimg.cn/img_convert/2c28087161b9935466e4ebeda856fd44.png)


#### 第六步: 挂载


![1558959972626](https://img-blog.csdnimg.cn/img_convert/d89e64a6c5a40325eb2cd3bb06b810ea.png)




| 命令 | 含义 |
| --- | --- |
| `mount 设备名称 挂载目录` | **建立** **设备分区** 和 **系统目录** 的映射关系 |
| `umount 设备名称` 或 `umount 挂载目录` | **取消** **设备分区** 和 **系统目录** 的映射关系 |


##### 操作步骤


1. 创建目录 `mkdir -p /home/newdisk`
2. `mount /dev/sdb1 /home/newdisk` **建立** **设备分区** 和 **系统目录** 的映射关系
3. `lsblk -f` 查看是否挂载成功


![1558960469613](https://img-blog.csdnimg.cn/img_convert/2e702614fa6a69a75707ab36549b9071.png)


* 注意: **重启后 挂载失效**


#### 第七步: 设置重启不失效


##### 操作步骤


* 第一步: 将映射关系写到配置文件中 `/etc/fstab`
* 第二步: `mount -a` 重新加载`/etc/fstab` 文件 ; `mount` 显示 `/etc/fstab` 文件内容
* 第三步: 重启操作系统后, 测试 `lsblk -f`


### 1.4 小结


* 用户**不能**直接访问 硬件设备
* 需要将硬件设备 **挂载**到 系统目录上, 用户才可以让用户访问


### 1.5 挂载 持有系统镜像 光驱


#### 1.5.1 目标


* 因为 linux系统镜像中包含了常用的软件包, 就不用从网上下载了
* 所以需要**挂载** 持有系统镜像 的 **光驱**


#### 1.5.2 路径


![1559232643477](https://img-blog.csdnimg.cn/img_convert/daf4d3546da3e9bf764b99a5e5cd6db7.png)


* ##### 第一步: 将 **linux系统镜像** 放到光驱中
* ##### 第二步: 创建目录 `/mnt/cdrom`
* ##### 第三步: 通过挂载 建立 硬件 和 系统目录的关系
* ##### 第四步: 到镜像中 寻找按照包


#### 1.5.3 实现


1. 目标虚拟机, 右键 **设置**
2. 选中 CD/DVD, 浏览 选中本地的 **centOS 镜像**

 ![1559003152261](https://img-blog.csdnimg.cn/img_convert/deef26b8b4a239648bc022645eb6da49.png)
3. 创建目录 `mkdir -p /mnt/cdrom`
4. 挂载镜像文件 `mount /dev/sr0 /mnt/cdrom`
5. 进入挂载目录, 找到 安照包

 

切换到安装包目录中

cd /mnt/cdrom/Packages/

搜索tree安装包

ls | grep tree



### 1.5.4 小结


* ##### 通过 挂载 系统光驱, 就可以 获取系统镜像中 软件包
* ##### 注意: 系统镜像目录中 不能有中文, 不能有空格


## 2 rpm 软件包管理器


### 2.1 目标


* 通过 `rpm命令` 实现对软件 的安装、查询、卸载
* RPM 是Red-Hat Package Manager(RPM软件包管理器)的缩写
* 虽然 打上了 red-hat 的标记, 但是理念开放, 很多发行版都采用, 已经成为行业标准


### 2.2 路径


* 第一步: rpm包 的 查询命令
* 第二步: rpm包 的 卸载
* 第三步: rpm包 的 安装


### 2.3 实现


#### 第一步: rpm包 的 查询命令




| 选项 | 英文 | 含义 |
| --- | --- | --- |
| `-q` | query | 查询 |
| `-a` | all | 所有 |
| `-i` | info | 信息 |
| `-l` | list | 显示所有相关文件 |
| `-f` | file | 文件, 显示文件对应 `rpm`包 |


* 查询已安装的**rpm**列表

 

rpm -qa | grep XXX
rpm -qa | less

* 查询软件包信息

 

rpm -qi 软件全包名

* 查看一个rpm包中的文件安装到那里去了?

 

rpm -ql 软件全包名

* 查看指定文件归属于那个软件包

 

rpm -qf 文件的全路径



#### 第二步: rpm包 的 卸载




| 命令 | 英文 | 含义 |
| --- | --- | --- |
| `rpm -e 软件包名称` | erase 清除 | 卸载rpm软件包 |
| `rpm -e --nodeps 软件包名称` | Don’t check dependencies | 卸载前 跳过 依赖检查 |


![1559195615885](https://img-blog.csdnimg.cn/img_convert/916ce7a2d3b85f916bbe538681bd0921.png)


#### 第三步: rpm包 的 安装




| 命令 | 含义 |
| --- | --- |
| `rpm -ivh rpm包的全路径` | 安装 rpm 包 |




| 参数 | 英文 | 含义 |
| --- | --- | --- |
| `-i` | install | 安装 |
| `-v` | verbose | 打印提示信息 |
| `-h` | hase | 显示安装进度 |


### 2.4 小结



1 查询

rpm -qa | grep rpm包

2 卸载

rpm -e rpm全包名
rpm -e --nodeps rpm全包名

3 安装

rpm -ivh rpm包的全路径


## 3 yum


### 3.1 目标


* `Yum`(全称为 `Yellow dog Updater, Modified`)**本质上** 也是一个 **软件包管理器**。
* **特点:** 基于 `RPM` 包管理,能够从指定的服务器 **自动下载、 自动安装、 自动处理依赖性关系**


### 3.2 路径


* ##### 第一步: yum的原理
* ##### 第二步: 常用指令 (重点)
* ##### 第三步: 制作 本地 `yum` 源
* ##### 第四步: 制作 局域网 `yum` 源


### 3.3 实现


#### 3.3.1 yum的原理


![1559213467056](https://img-blog.csdnimg.cn/img_convert/ea5ba61afcd291513d4126b7f53f5efa.png)


![1559213519625](https://img-blog.csdnimg.cn/img_convert/e19b2c5bfd41c9afb39adbd07154c76b.png)


#### 3.3.2 常用命令(重点)


注意: **必须联网**




| 命令 | 含义 |
| --- | --- |
| `yum list | grep 需要的软件名` | 查询服务器是否有需要安装的软件 |
| `yum -y install 需要的软件包` | 下载安装 |
| `yum -y remove 需要卸载的软件包` | 卸载 |
| `yum repolist` | 列出设定yum源信息 |
| `yum clean all` | 清除yum缓存信息 |


#### 3.3.3 制作本地yum源


* ##### 原因: 因为大数据集群 为了安全, 不让连接外网
* ##### 原理

 ![1559237181246](https://img-blog.csdnimg.cn/img_convert/56e91bade2b3fe334c9477d70e7fd191.png)
* ##### 实现


	+ ##### 第一步 挂载 持有系统镜像的 光驱, 请参考 1.5 小结
	+ ##### 第二步: 备份默认yum源仓库

切换到保存yum信息的目录

cd /etc/yum.repos.d/

备份所有的配置文件

rename .repo .repo.bak *

查看是否备份成功

ll

 ![1559005714539](https://img-blog.csdnimg.cn/img_convert/68643fd4772a062233bfa04d0106841b.png)


	+ ##### 第三步: 新增本地yum源 `vim CentOS-Local.repo`

vi CentOS-Local.repo

 编辑内容如下

 

[base]
name=CentOS-Local
baseurl=file:///mnt/cdrom
gpgcheck=0
enabled=1

 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0RnaPeNs-1624685690462)(assets%5CUsers%5CAdministrator%5CAppData%5CRoaming%5CTypora%5Ctypora-user-images%5C1571065658421.png)]


	+ 注意: 必须以 `.repo` 结尾
	+ ##### 第五步: 断网 测试是否可以安装
	
	 
	```
	# 查看 yum 源仓库
	yum repolist
	
	# 清空缓存
	yum clean all
	
	# 卸载 tree 软件
	yum -y remove tree
	
	# 重新安装 tree 观察是否成功
	yum -y install tree
	
	```


#### 3.3.4 制作局域网yum源


* ##### 原理

 ![1559238297553](https://img-blog.csdnimg.cn/img_convert/87ca1c60f218403b09de677e818c966f.png)


##### 3.3.5.1 安装httpd软件


* ##### 安装httpd:

 

yum -y install httpd

* ##### 启动 httpd 服务

 

service httpd start

* ##### 测试

 

http://192.168.100.201:80

* ##### 问题: 发现无法访问?


	+ ##### 原因: 因为 linux 的防火墙 禁止他人 访问自己的80端口
	+ ##### 解决: 通知 防火墙放行
* ##### 关闭防火墙


	+ ##### 原因: 为了方便 内网中集群间机器的相互操作, 通常会关闭防火墙
	+ ##### 关闭防火墙
	
	 
	```
	service iptables stop
	
	```
	+ 重启之后不要开防火墙
	
	 
	```
	chkconfig iptables off
	
	```


##### 3.3.4.3 制作局域网 yum源


* ##### 使用浏览器访问`http://192.168.100:201:80`

 ![1559003991020](https://img-blog.csdnimg.cn/img_convert/d562b8c9b36aae20019a67eb6e7a1bdc.png)
* ##### 第一步: 将常用软件包 复制到指定目录下

 

拷贝yum源到httpd服务的默认工作路径下

cp -r /mnt/cdrom/* /var/www/html/CentOS-6.9

* ##### 第二步: 浏览器访问`http://192.168.100.201/CentOS-6.9/`

 ![1559004235896](https://img-blog.csdnimg.cn/img_convert/8f78ce77bb2f655af8eb12654e74ea6c.png)
* ##### 第三步: 更新其他节点的 本地yum源(在其他节点上测试)


	+ ##### 1) 备份默认yum源
	
	 
	```
	cd /etc/yum.repos.d/
	mv CentOS-Local.repo CentOS-Local.repo.bak
	
	```
	+ ##### 2) 制作本地yum源
	
	 
	```
	cd /etc/yum.repos.d/
	vi CentOS-Local.repo
	
	```
	 
	```
	[base]
	name=CentOS-Local
	baseurl=http://192.168.100.201/CentOS-6.9/
	gpgcheck=0
	enabled=1
	gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
	
	```
* ##### 第四步: 测试是否成功(在其他节点上测试)

 

yum clean all
yum repolist
yum install -y tree



### 3.4 小结



安装软件

yum -y install 软件包

卸载软件
yum -y remove 软件包


## 4 安装jdk


### 4.1 路径


* ##### 第一步: 卸载linux系统 提供的jdk
* ##### 第二步: 上传按照包到 `/export/soft` , 解压到 `/export/install`
* ##### 第三步: 将 jdk路径 放到 环境变量中
* ##### 第四步: 重新加载 环境变量的配置文件
* ##### 第五步: 测试是否安装成功


### 4.2 实现


#### 第一步: 卸载linux系统 提供的jdk



查询已安装的jdk

rpm -qa | grep java

卸载

rpm -e --nodeps 软件包名


#### 第二步: 上传按照包到 `/export/soft` , 解压到 `/export/install`



1 创建保存软件包目录

mkdir -p /export/soft/
cd /export/soft/ && ll

2 上传软件包

3 创建安装软件目录

mkdir -p /export/install

4 将压缩包解压到指定目录

tar -zxvf jdk-8u141-linux-x64.tar.gz -C /export/install
cd /export/install && ll


#### 第三步: 将 jdk路径 放到 环境变量中


* 目的: 为了能够在任何目录下都可以使用 `javac` 和 `java`



JAVA_HOME=/export/install/jdk1.8.0_141
PATH=/export/install/jdk1.8.0_141/bin:$PATH
export JAVA_HOME PATH


#### 第四步: 重新加载 环境变量的配置文件


* 为了生效, 要么重启电脑, 要么 重新加载配置文件



source /etc/profile

测试

java -version


#### 第五步: 测试是否安装成功



需求: 编写一个简单的Hello.java, 输出 Hello World!


vim Hello.java



[root@hadoop01 export]# cat Hello.java
public class Hello{
public static void main(String[] args) {
System.out.println(“Hello java!”);
}
}


使用 `javac Hello.java` 编译


执行 `java Hello`


## 5 安装tomcat


### 5.1 目标


* ##### 实际工作中我们可能需要发布web项目到tomcat中


### 5.2 路径


* ##### 第一步: 将安装包上传到 `/export/soft` , 解压到 `/export/install`
* ##### 第二步: 启动tomcat 且 查看日志
* ##### 第三步: 上传项目 测试


### 5.3 实现


* #### 第一步: 将安装包上传到 `/export/soft` , 解压到 `/export/install`

 

切换到保存软件的目录

cd /export/soft

解压到 /export/install 安装目录

tar -zxvf apache-tomcat-7.0.82.tar.gz -C /export/install/

* #### 第二步: 启动tomcat 且 查看日志

 

切换启动命令的目录

cd /export/install/apache-tomcat-7.0.82/bin

启动 且 查看日志

./startup.sh && tail -100f …/logs/catalina.out

* #### 第三步: 测试

 

http://192.168.100.201:8080/

 ![1559021688305](https://img-blog.csdnimg.cn/img_convert/75b6fa1b8462d447f77683da7fe1ecb8.png)


	+ ##### 将需要发布的项目 放到 `tomcat目录/webapps` 目录下
	+ ##### 提示: 防火墙要么关闭, 要么开放tomcat指定的端口,否则无法访问


## 6 安装mysql


### 6.1 yum安装原理:


* ##### yum安装是通过执行yum命令,自动分析依赖关系, 自动下载, 自动安装


### 6.2 yum安装优点:


* ##### 安装简单、快速


### 6.3 缺点:


* ##### 由于不同的yum仓库只有特定的几个版本,所以可选的版本较少。


### 6.4 yum安装实战


* 下面看看如何在CentOS7系统上安装 MySQL5.6.44


#### 1 查询系统自带的mysql



[root@hadoop01 yum.repos.d]# rpm -qa | grep mysql
mysql-libs-5.1.73-8.el6_8.x86_64


#### 2 安装mysql



yum install -y mysql-server


#### 3 启动服务



service mysqld start


![1559027389601](https://img-blog.csdnimg.cn/img_convert/6acfe00c2351d67496d22b029d3784a9.png)


#### 4 修改密码


![1559025747654](https://img-blog.csdnimg.cn/img_convert/1bf26465e024de48f147817fb9227518.png)



设置密码

/usr/bin/mysqladmin -u root password ‘123456’

进入mysql

mysql -uroot -p123456


#### 5 问题1: 解决中文乱码


由于MySQL编码原因会导致数据库出现乱码。


**解决办法:**


修改MySQL数据库字符编码为UTF-8,UTF-8包含全世界所有国家需要用到的字符,是国际编码。


**具体操作:**


##### 1 进入MySQL控制台



进入mysql

mysql -uroot -p123456

查看编码集 发现不是utf8

show variables like ‘character_set_%’;


![1559290263489](https://img-blog.csdnimg.cn/img_convert/cb63d29d7f4d00daa665bde318bf0f39.png)


##### 2 修改mysql配置文件



清空 mysql 配置文件内容

[root@Hadoop-NN-01 ~]# >/etc/my.cnf

修改mysql 软件的编码集

[root@Hadoop-NN-01 ~]# vi /etc/my.cnf


修改内容如下:





![img](https://img-blog.csdnimg.cn/img_convert/fa451c215432322ed6d2f560e136c379.png)
![img](https://img-blog.csdnimg.cn/img_convert/cd403c326748734e2e1df147953bb292.png)

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

测试是否安装成功


### 4.2 实现


#### 第一步: 卸载linux系统 提供的jdk



查询已安装的jdk

rpm -qa | grep java

卸载

rpm -e --nodeps 软件包名


#### 第二步: 上传按照包到 `/export/soft` , 解压到 `/export/install`



1 创建保存软件包目录

mkdir -p /export/soft/
cd /export/soft/ && ll

2 上传软件包

3 创建安装软件目录

mkdir -p /export/install

4 将压缩包解压到指定目录

tar -zxvf jdk-8u141-linux-x64.tar.gz -C /export/install
cd /export/install && ll


#### 第三步: 将 jdk路径 放到 环境变量中


* 目的: 为了能够在任何目录下都可以使用 `javac` 和 `java`



JAVA_HOME=/export/install/jdk1.8.0_141
PATH=/export/install/jdk1.8.0_141/bin:$PATH
export JAVA_HOME PATH


#### 第四步: 重新加载 环境变量的配置文件


* 为了生效, 要么重启电脑, 要么 重新加载配置文件



source /etc/profile

测试

java -version


#### 第五步: 测试是否安装成功



需求: 编写一个简单的Hello.java, 输出 Hello World!


vim Hello.java



[root@hadoop01 export]# cat Hello.java
public class Hello{
public static void main(String[] args) {
System.out.println(“Hello java!”);
}
}


使用 `javac Hello.java` 编译


执行 `java Hello`


## 5 安装tomcat


### 5.1 目标


* ##### 实际工作中我们可能需要发布web项目到tomcat中


### 5.2 路径


* ##### 第一步: 将安装包上传到 `/export/soft` , 解压到 `/export/install`
* ##### 第二步: 启动tomcat 且 查看日志
* ##### 第三步: 上传项目 测试


### 5.3 实现


* #### 第一步: 将安装包上传到 `/export/soft` , 解压到 `/export/install`

 

切换到保存软件的目录

cd /export/soft

解压到 /export/install 安装目录

tar -zxvf apache-tomcat-7.0.82.tar.gz -C /export/install/

* #### 第二步: 启动tomcat 且 查看日志

 

切换启动命令的目录

cd /export/install/apache-tomcat-7.0.82/bin

启动 且 查看日志

./startup.sh && tail -100f …/logs/catalina.out

* #### 第三步: 测试

 

http://192.168.100.201:8080/

 ![1559021688305](https://img-blog.csdnimg.cn/img_convert/75b6fa1b8462d447f77683da7fe1ecb8.png)


	+ ##### 将需要发布的项目 放到 `tomcat目录/webapps` 目录下
	+ ##### 提示: 防火墙要么关闭, 要么开放tomcat指定的端口,否则无法访问


## 6 安装mysql


### 6.1 yum安装原理:


* ##### yum安装是通过执行yum命令,自动分析依赖关系, 自动下载, 自动安装


### 6.2 yum安装优点:


* ##### 安装简单、快速


### 6.3 缺点:


* ##### 由于不同的yum仓库只有特定的几个版本,所以可选的版本较少。


### 6.4 yum安装实战


* 下面看看如何在CentOS7系统上安装 MySQL5.6.44


#### 1 查询系统自带的mysql



[root@hadoop01 yum.repos.d]# rpm -qa | grep mysql
mysql-libs-5.1.73-8.el6_8.x86_64


#### 2 安装mysql



yum install -y mysql-server


#### 3 启动服务



service mysqld start


![1559027389601](https://img-blog.csdnimg.cn/img_convert/6acfe00c2351d67496d22b029d3784a9.png)


#### 4 修改密码


![1559025747654](https://img-blog.csdnimg.cn/img_convert/1bf26465e024de48f147817fb9227518.png)



设置密码

/usr/bin/mysqladmin -u root password ‘123456’

进入mysql

mysql -uroot -p123456


#### 5 问题1: 解决中文乱码


由于MySQL编码原因会导致数据库出现乱码。


**解决办法:**


修改MySQL数据库字符编码为UTF-8,UTF-8包含全世界所有国家需要用到的字符,是国际编码。


**具体操作:**


##### 1 进入MySQL控制台



进入mysql

mysql -uroot -p123456

查看编码集 发现不是utf8

show variables like ‘character_set_%’;


![1559290263489](https://img-blog.csdnimg.cn/img_convert/cb63d29d7f4d00daa665bde318bf0f39.png)


##### 2 修改mysql配置文件



清空 mysql 配置文件内容

[root@Hadoop-NN-01 ~]# >/etc/my.cnf

修改mysql 软件的编码集

[root@Hadoop-NN-01 ~]# vi /etc/my.cnf


修改内容如下:





[外链图片转存中...(img-rNj6b581-1715742813976)]
[外链图片转存中...(img-OqM6Vea6-1715742813976)]

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值