
命令 | 英文 | 功能 |
|---|---|---|
y(复制命令) | copy | 复制 |
yy | copy | 复制一行,可以nyy复制多行 |
d(剪切命令) | delete | 剪切 |
dd(剪切) | delete | 剪切一行, 可以 ndd 剪切n行 |
p | paste | 粘贴 |
提示:
注意
Ctrl + C 复制的内容, 不能再 vi 中通过 p 命令粘贴命令 | 英文 | 功能 | 工作模式 |
|---|---|---|---|
r | replace | 替换当前字符 | 命令模式 |
R | replace | 替换当前行光标后的字符 | 替换模式 |
R 命令可以进入 替换模式, 替换完成后, 按下ESC , 按下 ESC 可以回到 命令模式常规查找
命令 | 功能 |
|---|---|
/str | 查找str |
Next 查找下一个出现的位置- `n` : 查找下一个
- `N` : 查找上一个如果不想看到高亮显示, 可以随便查找一个文件中不存在的内容即可命令 | 功能 |
|---|---|
* | 向后查找当前光标所在单词 |
向前查找当前光标所在单词 |
vi 中查找和替换命令需要在 末行模式 下执行:%s///g:s/旧文本/新文本/gc confirm 确认
y - yes 替换n - no 不替换a - all 替换所有q -quit 退出替换l - last 最后一个, 并把光标移动到行首^E 向下滚屏^Y 向上滚屏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)
********** 连续10个星号要实现这个效果可以在 命令模式 下
10, 表示要重复10次i 进入 编辑模式* 也就是重复的文字ESC 返回 命令模式, 返回之后 vi 就会把 第 2、3 两步的操作重复 10 次提示: 正常开发时, 在 进入编辑模式之前,不要按数字
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
tree /export
find命令 在特定目录下(包含它的后代目录) 搜索 符合条件的文件1 的文件.txt 为扩展名的文件1开头的文件序号 | 命令格式 | 作用 |
|---|---|---|
01 | find 路径 -name ‘*.txt’ | 查找指定路径下扩展名是 .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*"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
jar : java rar java项目的压缩包
war : web rar web项目的压缩包
.tar 结尾.tar 打包命令格式
# 将 一系列文件 打包成 一个大文件
tar -cvf 打包名.tar 被打包的目录
tar -cvf 打包名.tar 被打包的文件1 被打包的文件2 被打包的文件3tar 选项说明
命令 | 英文 | 含义 |
|---|---|---|
c | create | 生成档案文件, 创建打包文件 |
v | verbosely(啰嗦的) | 像 ‘唐僧’ 一样报告进度 |
f | file | 指定档案的文件名称, f后面一定是 .tar 文件, 所以必须放到左后 |
练习1: 将1.txt、2.txt、3.txt 打包成 123.tar文件
练习2: 将有内容的aaa目录 打包成 aaa.tar 文件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 指定解包位置 ]Linux 中, 最常用的压缩文件格式是 xxx.tar.gztar 命令中有一个选项 -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 指定解包位置 ]bzip 是压缩的第二种方式Linux 中, bzip2 压缩文件格式是 xxx.tar.bz2tar 命令中有一个选项 -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序号 | 权限 | 英文 | 缩写 | 数字序号 |
|---|---|---|---|---|
01 | 读 | read | r | 4 |
02 | 写 | write | w | 2 |
03 | 执行 | execute | x | 1 |
04 | 无权限 | | - | 0 |


外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lwckbqR0-1624685398660)(assets%5CUsers%5CAdministrator%5CAppData%5CRoaming%5CTypora%5Ctypora-user-images%5C1570973470529.png)
ls -l 可以查看文件夹下文件的详细信息, 从左到右 依次是:- **权限**, 第一个字符如果是 `d` 表示目录
- **硬链接数**, 通俗的讲就是有多少种方式, 可以访问当前目录和文件
- **拥有者**, 家目录下 文件 / 木兰路 的拥有者通常都是 当前用户
- **组**, 在linux中, 很多时候, 会出现组名 和 用户名 相同的情况, 后续会讲
- **大小**
- **时间**
- **名称**

本质: 给 同一类型用户 分配权限
序号 | 命令 | 作用 |
|---|---|---|
01 | groupadd 组名 | 添加组 |
02 | groupdel 组名 | 删除组 |
03 | cat /etc/group | 确认组信息 |
04 | chgrp 组名 文件/目录名 | 修改文件/目录的所属组 |
提示:
/etc/group 文件中/etc 目录是专门用来保存 系统配置信息 的目录演练目标
aaa 目录dev 组aaa 目录的组修改为 dev命令 | 作用 | 说明 |
|---|---|---|
useradd -m -g 组 新建用户名 | 添加新用户 | -m 自动建立用户家目录 -g 指定用户所在的组, 否则会建立一个和同名的组 |
passwd 用户名 | 设置用户密码 | 如果是普通用户,直接用 passwd可以修改自己的账号密码 |
userdel -r 用户名 | 删除用户 | -r 选项会自动删除用户家目录 |
cat /etc/passwd | grep 用户名 | 确认用户信息 | 新建用户后,用户信息会保存在 /etc/passwd文件夹中 |
提示:
-m 选项指定新用户的家目录 – 最简单的方式就是删除用户,重新创建/etc/passwd 文件存放的是用户的信息, 由6个分好组成的7个信息, 分别是

序号 | 命令 | 作用 |
|---|---|---|
01 | id 用户名 | 查看用户UID 和 GID 信息 |
02 | who | 查看当前所有登录的用户列表 |
03 | whoami | 查看当前登录用户的账户名 |
su 切换用户
序号 | 命令 | 作用 | 说明 |
|---|---|---|---|
01 | su - 用户名 | 切换用户, 并且企划目录 |
|
02 | exit | 退出当前登录用户 | |
su 不接用户名, 可以切换到 root , 但是不推荐使用, 因为不安全exit 示意图如下:
su -u root 可以切换到 root用户, 但是 存在严重的 安全隐患root 账号通常 用于系统的维护和管理, 对操作系统的所有资源 具有访问权限rm -rf ... ... , 就可能将系统搞瘫痪sudo 命令用来以其他身份来执行命令, 预设的身份为 rootsudo 时, 必须先输入密码, 之后5分钟的有效期限, 超过期限则必须重新输入密码
提示: 若其未经授权的用户企图使用 sudo, 则会发出警告邮件给管理员vim /etc/sudoers
# 默认存在: root用户 具备所有的权限
root ALL=(ALL) ALL
# 授予 zhangsan 用户 所有的权限
zhangsan ALL=(ALL) ALL 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序号 | 命令 | 作用 |
|---|---|---|
01 | chmod | 修改权限 |
# 1. 使用 root 删除目录的可读 可写 可执行权限
# 2. 使用 其他用户如 zhangsan 无法切换到 这个目录
# 3. 使用 root 增加目录的执行权限, 再次 使用 zhangsan 切换到目录试试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用户给 所属用户分配 可读、可写、可执行 权限,
所属组 分配 可读、可执行 权限,
其他人 分配 可读、可执行 权限 chmod -R 755 文件|目录
常用数字组合有( u 表示用户 / g 表示组 / o 表示其他)
777 ===> u=rwx, g=rwx, o=rwx755 ===> u=rwx, g=rx, o=rx644 ===> u=rw, g=r, o=r# 1 使用root用户给 所属用户分配 可读、可写、可执行 权限,
所属组 分配 可读、可执行 权限,
其他人 分配 可读、可执行 权限 datecaldfdupstopkill命令 | 作用 |
|---|---|
date | 查看系统时间(默认) |
date +"%Y-%m-%d %H:%M:%S" | 查看系统时间(指定格式) |
date -s “时间字符串” | 设置系统时间 |
# 显示时间
date
# 按照指定格式显示时间
date +"%Y-%m-%d %H:%M:%S"date -s "时间字符串"序号 | 命令 | 作用 |
|---|---|---|
01 | cal | 查看当前月的日历 |
02 | cal -y | 查看当前年的日历 |
03 | cal 2020 | 查看2020年的日历 |
04 | cal 10 2020 | 查看2020年10月的日历 |
序号 | 命令 | 作用 |
|---|---|---|
01 | df -h | disk free 显示磁盘剩余空间 |
02 | du -h 目录名 | disk usage 显示目录下的目录大小 |
参数 | 含义 |
|---|---|
-h | 以人性化的方式显示文件的大小 |
序号 | 命令 | 作用 |
|---|---|---|
01 | ps aux | process status 查看进程的详细情况 |
02 | top | 动态显示运行中进程并且排序 |
03 | kill -9 进程代号 | 终止指定代号的进程 -9 表示强行终止 |
ps默认只会显示当前用户通过终端启动的应用程序
ps 选项说明功能
选项含义a显示终端上的所有进程,包括其他用户的进程u显示进程的详细状态x显示没有控制终端的进程 提示: 使用kill命令时, 最好只终止由当前用户开启的进程, 而不要终止root身份开启的进程, 否则可能导致系统崩溃top 可以直接输入 qtop

us 用户空间占用CPU百分比
sy 内核空间占用CPU百分比
ni 用户进程空间内改变过优先级的进程占用CPU百分比
id 空闲CPU百分比
wa 等待输入输出的CPU时间百分比
hi 硬件中断
si 软件中断
st: 实时
PID 进程号
USER 用户名
PR 优先级
NI nice值。负值表示高优先级,正值表示低优先级m
RES 进程使用的、未被换出的物理内存大小,单位kb
SHR 共享内存大小,单位kb
S 进程状态。
D=不可中断的睡眠状态
R=运行
S=睡眠
T=跟踪/停止
Z=僵尸进程
%CPU CPU使用率
%MEM 进程使用的物理内存百分比
TIME+ 进程使用的CPU时间总计,单位1/100秒
COMMAND 执行的命令
cutsortwcuniqteetrsplitawksedgrep准备工作
vim 1.txt
111:aaa:bbb:ccc
222:ddd:eee:fff
333:ggg:hhh
444:iiicut 根据条件 从命令结果中 提取 对应内容命令 | 含义 |
|---|---|
cut 动作 文件 | 从指定文件 截取内容 |
参数 | 英文 | 含义 |
|---|---|---|
-c | characters | 按字符选取内容 |
head -2 1.txt | cut -c 5参数 | 英文 | 含义 |
|---|---|---|
-d '分隔符' | delimiter | 指定分隔符 |
-f n1,n2 | fields | 分割以后显示第几段内容, 使用 , 分割 |
范围控制
范围 | 含义 |
|---|---|
n | 只显示第n项 |
n- | 显示 从第n项 一直到行尾 |
n-m | 显示 从第n项 到 第m项(包括m) |
head -2 1.txt | cut -d ':' -f 1,2head -2 1.txt | cut -d ':' -f 1-2cut 动作 目标文件 可以根据条件 提取对应内容[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 | 使次序颠倒 |
参数 | 英文 | 含义 |
|---|---|---|
-t | field-separator | 指定字段分隔符 |
-k | key | 根据那一列排序 |
‘’
# 根据第二段成绩 进行倒序显示 所有内容
sort -t ',' -k2nr score.txt /etc 目录下 有多少个 子内容命令 | 含义 |
|---|---|
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
240wc 文件 就可以 统计 文件的 字节数、单词数、行数.uniq 命令用于检查及删除文本文件中重复出现的行,一般与 sort 命令结合使用。
命令 | 英文 | 含义 |
|---|---|---|
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 赵六 95uniq [选项] 文件 就可以完成 去重行 和 统计次数tee 可以将命令结果 通过管道 输出到 多个文件中命令 | 含义 |
|---|---|
命令结果 | tee 文件1 文件2 文件3 | 通过 tee 可以将命令结果 通过管道 输出到 多个文件中 |
tee 可以将命令结果 通过管道 输出到 多个文件中tr 命令用于 替换 或 删除 文件中的字符。命令 | 英文 | 含义 |
|---|---|---|
命令结果 | 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 | 删除指定的字符 |
echo 'abc1d4e5f' | tr -d '[0-9]'[root@hadoop01 export]# cat words.txt
hello,world,hadoop
hive,sqoop,flume,hello
kitty,tom,jerry,world
hadoop1 将, 换成 换行
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 worldsplit 命令将大文件 切分成 若干小文件命令 | 英文 | 含义 |
|---|---|---|
split -b 10k 文件 | byte | 将大文件切分成若干10KB的小文件 |
命令 | 英文 | 含义 |
|---|---|---|
split -l 1000 文件 | lines | 将大文件切分成若干1000行 的小文件 |
awk 实现 模糊查询, 按需提取字段, 还可以进行 判断 和 简单的运算等.命令 | 含义 |
|---|---|
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 -F ‘,’ ‘{print toupper($2)}’ 1.txt | 操作1.txt文件, 根据 逗号 分割, 打印 第一段 第二段 第三段 内容 |
常用函数如下:
函数名 | 含义 | 作用 |
|---|---|---|
toupper() | upper | 字符 转成 大写 |
tolower() | lower | 字符 转成小写 |
length() | length | 返回 字符长度 |
命令 | 含义 |
|---|---|
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命令 | 含义 |
|---|---|
sed 可选项 目标文件 | 对目标文件 进行 过滤查询 或 替换 |
可选参数
可选项 | 英文 | 含义 |
|---|---|---|
p | 打印 | |
$ | | 代表 最后一行 |
-n | | 仅显示处理后的结果 |
-e | expression | 根据表达式 进行处理 |
sed -n -e '1,5p' 1.txt sed -n -e '1,$p' 1.txt 可选项 | 含义 |
|---|---|
= | 打印当前行号 |
sed -n -e '1,$=' -e '1,$p' 1.txt
简化版
cat -n 1.txt
cat -b 1.txt
nl 1.txt答案:
sed -n -e '/root/p' 1.txt可选项 | 英文 | 含义 |
|---|---|---|
I | ignore | 忽略大小写 |
答案:
nl 1.txt | sed -n -e '/root/Ip'
nl 01.txt | grep -i root
cat -n 01.txt | grep -i rootr后面是多个t的行,并显示行号可选项 | 英文 | 含义 |
|---|---|---|
-r | regexp-extended | 识别正则 |
答案:
nl 01.txt | sed -nr -e '/r+t/p'或者
sed -nr -e '/r+t/p' -e '/r+t/=' 01.txt可选项 | 英文 | 含义 |
|---|---|---|
d | delete | 删除指定内容 |
答案:
nl 01.txt | sed -e '1,3d'答案:
nl 01.txt | sed -e '5,$d'
nl 1.txt | sed -n -e '1,4p'参数 | 英文 | 含义 |
|---|---|---|
i | insert | 目标前面 插入内容 |
a | append | 目标后面 追加内容 |
答案:
nl 01.txt | sed -e '2a aaaaa'答案:
nl 01.txt | sed -e '1i bbbbb' | 英文 | 含义 |
|---|---|---|
s/oldString/newString/ | replace | 替换 |
答案:
nl 1.txt | sed -e 's/nologin/huawei/'选项 | 英文 | |
|---|---|---|
2c 新字符串 | replace | 使用新字符串 替换 选中的行 |
答案:
nl passwd | sed -e '1,2c aaa'参数 | 英文 | 含义 |
|---|---|---|
-i | in-place | 替换原有文件内容 |
答案:
sed -i -e 's/nologin/huawei/' 01.txt答案:
sed -i -e '2,3c aaa' 01.txt注意:在进行操作之前,最好是对数据进行备份,放置操作失误,数据无法恢复!
答案:
sed -i -e '1,2d' 01.txt
nl passwd 查看数据答案:
ifconfig eth0 | grep "inet addr" | sed -e 's/^.*inet addr://' | sed -e 's/Bcast:.*$//' 答案:
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}' #只显示替换内容的行答案:
nl 01.txt | sed -e '1,2d' | sed -e 's/nologin/itheima/'
命令 | 英文 | 含义 |
|---|---|---|
lsblk -f | list block devices | 查看所有设备的挂载情况 |
参数 | 英文 | 含义 |
|---|---|---|
-f | file system | 文件系统 |
外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-F5x3IfHz-1624685690449)(assets/1558957195965.png)
lsblk 的记忆小窍门: 老师不离开 的首字母
命令 | 英文 | 含义 |
|---|---|---|
fdisk /dev/sdb | partition | 开始指定磁盘分区 |
分区命令可选项
选项 | 英文 | 含义 |
|---|---|---|
m | menu | 显示命令列表 |
n | new | 新增分区 |
p | partition | 显示磁盘分区 |
d | delete | 删除分区 |
w | write and exit | 写入 并 退出 |
fdisk /dev/sdb 开始分区m , 进入 目录列表n , 新增分区p , 开始分区, 后面按回车w, 保存 且 退出lsblk -f 查看是否成功
命令 | 英文 | 含义 |
|---|---|---|
mkfs -t ext4 /dev/sdb1 | build a Linux file system | 格式化指定分区 |
参数 | 英文 | 含义 |
|---|---|---|
-t | file system type | 指定文件系统类型 |
mkfs -t ext4 /dev/sdb1 格式化指定分区lsblk -f 查看是否成功

命令 | 含义 |
|---|---|
mount 设备名称 挂载目录 | 建立 设备分区 和 系统目录 的映射关系 |
umount 设备名称 或 umount 挂载目录 | 取消 设备分区 和 系统目录 的映射关系 |
mkdir -p /home/newdiskmount /dev/sdb1 /home/newdisk 建立 设备分区 和 系统目录 的映射关系lsblk -f 查看是否挂载成功
/etc/fstabmount -a 重新加载/etc/fstab 文件 ; mount 显示 /etc/fstab 文件内容lsblk -f
/mnt/cdromrpm命令 实现对软件 的安装、查询、卸载选项 | 英文 | 含义 |
|---|---|---|
-q | query | 查询 |
-a | all | 所有 |
-i | info | 信息 |
-l | list | 显示所有相关文件 |
-f | file | 文件, 显示文件对应 rpm包 |
命令 | 英文 | 含义 |
|---|---|---|
rpm -e 软件包名称 | erase 清除 | 卸载rpm软件包 |
rpm -e --nodeps 软件包名称 | Don’t check dependencies | 卸载前 跳过 依赖检查 |

命令 | 含义 |
|---|---|
rpm -ivh rpm包的全路径 | 安装 rpm 包 |
参数 | 英文 | 含义 |
|---|---|---|
-i | install | 安装 |
-v | verbose | 打印提示信息 |
-h | hase | 显示安装进度 |
# 1 查询
rpm -qa | grep rpm包
# 2 卸载
rpm -e rpm全包名
rpm -e --nodeps rpm全包名
# 3 安装
rpm -ivh rpm包的全路径 Yum(全称为 Yellow dog Updater, Modified)本质上 也是一个 软件包管理器。RPM 包管理,能够从指定的服务器 自动下载、 自动安装、 自动处理依赖性关系yum 源yum 源

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

# 安装软件
yum -y install 软件包
卸载软件
yum -y remove 软件包/export/soft , 解压到 /export/install# 查询已安装的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 && lljavac 和 javaJAVA_HOME=/export/install/jdk1.8.0_141
PATH=/export/install/jdk1.8.0_141/bin:$PATH
export JAVA_HOME PATHsource /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
/export/soft , 解压到 /export/install[root@hadoop01 yum.repos.d]# rpm -qa | grep mysql
mysql-libs-5.1.73-8.el6_8.x86_64yum install -y mysql-serverservice mysqld start

# 设置密码
/usr/bin/mysqladmin -u root password '123456'
# 进入mysql
mysql -uroot -p123456由于MySQL编码原因会导致数据库出现乱码。
解决办法:
修改MySQL数据库字符编码为UTF-8,UTF-8包含全世界所有国家需要用到的字符,是国际编码。
具体操作:
# 进入mysql
mysql -uroot -p123456
# 查看编码集 发现不是utf8
show variables like 'character_set_%';
# 清空 mysql 配置文件内容
[root@Hadoop-NN-01 ~]# >/etc/my.cnf
# 修改mysql 软件的编码集
[root@Hadoop-NN-01 ~]# vi /etc/my.cnf修改内容如下:
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
character-set-server=utf8[root@Hadoop-NN-01 ~]# service mysqld restart #查看MySQL字符集
show variables like 'character_set_%'; 
MySQL数据库字符集编码修改完成!
连接之前需要关闭防火墙


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


vim /etc/udev/rules.d/70-persistent-net.rules 


vim /etc/sysconfig/network-scripts/ifcfg-eth0 
reboot三台机器执行以下命令(root用户来执行)
# 查看防火墙的状态
service iptables status
# 启动防火墙服务
service iptables start
# 重启 防火墙 服务
service iptables restart
# 停止 防火墙 服务
service iptables stop
# 彻底关闭防火墙
chkconfig iptables off
vim /etc/selinux/config
vim /etc/sysconfig/network


vim /etc/hosts192.168.100.201 hadoop01
192.168.100.202 hadoop02
192.168.100.203 hadoop03ping 192.168.100.202
ping hadoop02
scp 远程文件拷贝remote file copy program 的缩写, scp是远程文件拷贝命令。
scp /export/aaa/01.txt root@192.168.100.202:/export
scp /export/aaa/02.txt root@hadoop02:/export
scp /export/aaa/02.txt hadoop02:/exportscp -r /export/aaa root@192.168.100.202:/export
scp -r /export/aaa root@hadoop02:/export
scp -r /export/aaa hadoop02:/export

scp root@192.168.100.202:/export/a1/111.txt /export
scp root@hadoop02:/export/a1/222.txt /export
scp hadoop02:/export/a1/222.txt /export
scp -r root@192.168.100.202:/export/a1 /export
scp -r hadoop02:/export/a1 /export

ssh 基于密码的远程登录(了解)ssh 基于密匙 实现 免密码登录(掌握)ssh 基于密码的远程登录命令 | 含义 |
|---|---|
ssh ip地址 | 远程登录到指定服务器上(必须知道正确的密码) |
yes/no , 以后可能就不会了ssh 基于密匙 实现 免密码登录(掌握)外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wbswp140-1624685690479)(assets%5CUsers%5CAdministrator%5CAppData%5CRoaming%5CTypora%5Ctypora-user-images%5C1571066755061.png)
第一步: ssh-keygen -t rsa 在hadoop1和hadoop2和hadoop3上面都要执行,产生公钥和私钥
第二步:ssh-copy-id hadoop01 将公钥拷贝到hadoop1上面去
第三步:
ssh-copy-id hadoop02
ssh-copy-id hadoop03注意1: 第三步需要在/root/.ssh/目录下.

/export/文件中5个占位符的说明

| 含义 | 范围 |
|---|---|---|
第一个 * | 一小时当中的第几分钟 | 0~59 |
第二个 * | 一天当中的第几小时 | 0~23 |
第三个 * | 一个月当中的第几天 | 1~31 |
第四个 * | 一年当中的第几月 | 1~12 |
第五个 * | 一周当中的星期几 | 0~7(0和7都代表星期日) |
例子
命令 | 含义 |
|---|---|
* * * * * command | 实例1:每1分钟执行一次command |
3,15 * * * * command | 实例2: 每小时的第3和第15分钟执行 |
3,15 8-11 * * * command | 实例3: 在上午8点到11点的第3和第15分钟执行 |
3,15 8-11 */2 * * command | 实例4: 每隔两天的上午8点到11点的第3和第15分钟执行 |
3,15 8-11 * * 1 command | 实例5: 每个星期一的上午8点到11点的第3和第15分钟执行 |
30 21 * * * /etc/init.d/smb restart | 实例6: 每晚的21:30重启smb |
45 4 1,10,22 * * /etc/init.d/smb restart | 实例7: 每月1、10、22日的4 : 45重启smb |
10 1 * * 6,0 /etc/init.d/smb restart | 实例8:每周六、周日的1 : 10重启smb |
0,30 18-23 * * * /etc/init.d/smb restart | 实例9:每天18 : 00至23 : 00之间每隔30分钟重启smb |


命令 | 英文 | 含义 |
|---|---|---|
ntpdate 互联网时间服务器地址; | Network Time Protocol | 同步时间 |

rpm -qa | grep ntpd外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Z3YZJYn9-1624685690482)(assets/1559323516074.png)
/etc/ntp.conf练习路径:
1 设置防火墙
2 一台机器上: rpm 安装 jdk tomcat mysql
3 搭建服务器集群(下午)
4 挂载 硬盘 和 光驱
5 yum源: 网络yum源 本地yum源 局域网yum源
以上便是大数据开发工程师基本功修炼之史上最全Linux学习笔记 ,喜欢的小伙伴欢迎一键三连!!!
