云起实验室 夏季训练营(1.17-3.8)
可补卡!!!
五期夏季实战,从入门到进阶,以最佳实际帮忙开发者,疾速云上实际,云上学习。
体验有礼,点击返回:https://developer.aliyun.com/adc/series/wintercamp
夏季实战营第一期:从零到一上手玩转云服务器
单期工作处分:实战营技能证书 + 定制鼠标
三期工作处分:全网首发冬奥限量版云小宝
五期工作处分:夏季实战营奖牌 + 定制书包 + 无影试用
体验简介
本场景将提供一台配置了 Aliyun Linux 2 的 ECS 实例(云服务器)。您能够参考本教程学习 Linux 零碎中的文本编辑工具 Vim 以及文本处理命令。
背景常识
云服务器 ECS
云服务器(Elastic Compute Service,简称 ECS)是阿里云提供的性能卓越、稳固牢靠、弹性扩大的 IaaS(Infrastructure as a Service)级别云计算服务。云服务器 ECS 免去了您洽购 IT 硬件的后期筹备,让您像应用水、电、天然气等公共资源一样便捷、高效地应用服务器,实现计算资源的即开即用和弹性伸缩。阿里云 ECS 继续提供创新型服务器,解决多种业务需要,助力您的业务倒退。
Aliyun Linux 2
Aliyun Linux 2 是阿里云推出的下一代 Linux 发行版,它为云上应用程序环境提供 Linux 社区的最新加强性能,在提供云上最佳用户体验的同时,也针对阿里云基础设施做了深度的优化。Aliyun Linux 2 OS 镜像能够运行在阿里云全规格系列 VM 实例上,包含弹性裸金属服务器 (神龙)。
Vim
Vim 是从 vi 倒退进去的一个文本编辑器。代码补全、编译及谬误跳转等不便编程的性能特地丰盛,在程序员中被宽泛应用,和 Emacs 并列成为类 Unix 零碎用户最喜爱的文本编辑器。Vim 的设计理念是命令的组合。用户学习了各种各样的文本间挪动、跳转的命令和其余的一般模式的编辑命令,并且可能灵便组合应用的话,可能比那些没有模式的编辑器更加高效的进行文本编辑。同时 Vim 与很多快捷键设置和正则表达式相似, 能够辅助记忆。并且 Vim 针对程序员做了优化。
目录一:文本编辑工具 Vim
文本编辑工具 Vim
vim 的三种操作模式
vim 有三种操作模式,别离是命令模式(Command mode)、输出模式(Insert mode)和底线命令模式(Last line mode)。
三种模式切换快捷键:
模式 | 快捷键 |
---|---|
命令模式 | ESC |
输出模式 | i 或 a |
底线命令模式 | : |
命令模式
在命令模式中管制光标挪动和输出命令,可对文本进行复制、粘贴、删除和查找等工作。
应用命令 vim filename 后进入编辑器视图后,默认模式就是命令模式,此时敲击键盘字母会被辨认为一个命令,例如在键盘上间断敲击两次 d,就会删除光标所在行。
以下是在命令模式中罕用的快捷操作:
操作 | 快捷键 |
---|---|
光标左移 | h |
光标右移 | l(小写 L) |
光标上移 | k |
光标下移 | j |
光标挪动到下一个单词 | w |
光标挪动到上一个单词 | b |
挪动游标到第 n 行 | nG |
挪动游标到第一行 | gg |
挪动游标到最初一行 | G |
疾速回到上一次光标所在位置 | Ctrl+o |
删除以后字符 | x |
删除前一个字符 | X |
删除整行 | dd |
删除一个单词 | dw 或 daw |
删除至行尾 | d$ 或 D |
删除至行首 | d^ |
删除到文档开端 | dG |
删除至文档首部 | d1G |
删除 n 行 | ndd |
删除 n 个间断字符 | nx |
将光标所在位置字母变成大写或小写 | ~ |
复制游标所在的整行 | yy(3yy 示意复制 3 行) |
粘贴至光标后(下) | p |
粘贴至光标前(上) | P |
剪切 | dd |
替换上下行 | ddp |
替换整行,即删除游标所在行并进入插入模式 | cc |
撤销一次或 n 次操作 | u{n} |
撤销以后行的所有批改 | U |
复原撤销操作 | Ctrl+r |
整行将向右缩进 | >> |
整行将向左退回 | << |
若档案没有更动,则不贮存来到,若档案曾经被更动过,则贮存后来到 | ZZ |
输出模式
在命令模式下按 i 或 a 键就进入了输出模式,在输出模式下,您能够失常的应用键盘按键对文本进行插入和删除等操作。
底线命令模式
在命令模式下按: 键就进入了底线命令模式,在底线命令模式中能够输出单个或多个字符的命令。
以下是底线命令模式中罕用的快捷操作:
操作 | 命令 |
---|---|
保留 | :w |
退出 | :q |
保留并退出 | :wq(:wq! 示意强制保留退出) |
将文件另存为其余文件名 | :w new_filename |
显示行号 | :set nu |
勾销行号 | :set nonu |
使本行内容居中 | :ce |
使本行文本靠右 | :ri |
使本行内容靠左 | :le |
向光标之下寻找一个名称为 word 的字符串 | :/word |
向光标之上寻找一个字符串名称为 word 的字符串 | :?word |
反复前一个搜查的动作 | :n |
从第一行到最初一行寻找 word1 字符串,并将该字符串取代为 word2 | :1,$s/word1/word2/ g 或 :%s/word1/word2/g |
应用示例
1.List item
新建一个文件并进入 vim 命令模式。
vim 静夜思.txt
2. 按下 i 进入输出模式,输出《静夜思》的诗名。
3. 按下 ECS 键回到命令模式,并输出底线命令:ce,使诗名居中。
4. 按下 o 键换行并进入输出模式,输出第一行诗。
5. 按下 ECS 键回到命令模式,并输出底线命令:ce,使第一行诗居中。
6. 按下 o 键换行并进入输出模式,输出第二行诗。
7. 按下 ECS 键回到命令模式,并输出底线命令:ce,使第二行诗居中。
8. 在命令模式中执行底线命令:wq 来到 vim。
目录二:文本文件查看命令
cat
命令形容:cat 命令用于查看内容较少的纯文本文件。
命令格局:cat [选项] [文件]。
命令参数阐明:
参数 | 阐明 |
---|---|
- n 或 –number | 显示行号 |
- b 或 –number-nonblank | 显示行号,然而不对空白行进行编号 |
- s 或 –squeeze-blank | 当遇到有间断两行以上的空白行,只显示一行的空白行 |
命令应用示例:
1. 将一个自增序列写入 test.txt 文件中。
for i in $(seq 1 10); do echo $i >> test.txt ; done
2. 查看文件内容。
cat test.txt
命令输入后果:
3. 将文件内容清空。
cat /dev/null > test.txt
- 再次查看文件内容。
cat test.txt
命令输入后果:
more
命令形容:more 命令从前向后分页显示文件内容。
罕用操作命令:
操作 | 作用 |
---|---|
Enter | 向下 n 行,n 须要定义,默认为 1 行 |
Ctrl+ F 或空格键(Space) | 向下滚动一页 |
Ctrl+B | 向上滚动一页 |
= | 输入以后行的行号 |
! 命令 | 调用 Shell 执行命令 |
q | 退出 more |
命令应用示例:
从第 20 行开始分页查看系统日志文件 /var/log/messages。
more +20 /var/log/messages
命令输入后果:
less
命令形容:less 命令能够对文件或其它输入进行分页显示,与 moe 命令类似,但应用 less 能够随便浏览文件,而 more 仅能向前挪动,却不能向后挪动。
命令格局:less [参数] 文件。
命令参数阐明:
参数 | 阐明 |
---|---|
-e | 当文件显示完结后,主动来到 |
-m | 显示相似 more 命令的百分比 |
-N | 显示每行的行号 |
-s | 显示间断空行为一行 |
命令罕用操作:
快捷键 | 阐明 |
---|---|
/ 字符串 | 向下搜寻字符串 |
? 字符串 | 向上搜寻字符串 |
n | 反复前一个搜寻 |
N | 反向反复前一个搜寻 |
b 或 pageup 键 | 向上翻一页 |
空格键或 pagedown 键 | 向下翻一页 |
u | 向前翻半页 |
d | 向后翻半页 |
y | 向前滚动一行 |
回车键 | 向后滚动一行 |
q | 退出 less 命令 |
命令应用示例:
查看命令历史应用记录并通过 less 分页显示。
history | less
head
命令形容:head 命令用于查看文件结尾指定行数的内容。
命令格局:head [参数] [文件]。
命令参数阐明:
参数 | 阐明 |
---|---|
-n [行数] | 显示结尾指定行的文件内容,默认为 10 |
-c [字符数] | 显示结尾指定个数的字符数 |
-q | 不显示文件名字信息,实用于多个文件,多文件时默认会显示文件名 |
命令应用示例:
查看 /etc/passwd 文件的前 5 行内容。
head -5 /etc/passwd
命令输入后果:
tail
命令形容:tail 命令用于查看文档的后 N 行或继续刷新内容。
命令格局:tail [参数] [文件]。
命令参数阐明:
参数 | 阐明 |
---|---|
-f | 显示文件最新追加的内容 |
-q | 当有多个文件参数时,不输入各个文件名 |
-v | 当有多个文件参数时,总是输入各个文件名 |
-c [字节数] | 显示文件的尾部 n 个字节内容 |
-n [行数] | 显示文件的尾部 n 行内容 |
命令应用示例:
查看 /var/log/messages 系统日志文件的最新 10 行,并放弃实时刷新。
tail -f -n 10 /var/log/messages
按 ctrl+ c 键退出文本实时查看界面。
stat
命令形容:用来显示文件的详细信息,包含 inode、atime、mtime、ctime 等。
命令应用示例:
查看 /etc/passwd 文件的详细信息。
stat /etc/passwd
命令输入后果:
wc
命令形容:wc 命令用于统计指定文本的行数、字数、字节数。
命令格局:wc [参数] [文件]。
命令参数阐明:
参数 | 阐明 |
---|---|
-l | 只显示行数 |
-w | 只显示单词数 |
-c | 只显示字节数 |
命令应用示例:
统计 /etc/passwd 文件的行数。
wc -l /etc/passwd
命令输入后果:
file
命令形容:file 命令用于辨识文件类型。
命令格局:file [参数] [文件]。
命令参数阐明:
参数 | 阐明 |
---|---|
-b | 列出辨识后果时,不显示文件名称 |
-c | 具体显示指令执行过程,便于排错或分析程序执行的情景 |
-f [文件] | 指定名称文件,其内容有一个或多个文件名称时,让 file 依序辨识这些文件,格局为每列一个文件名称 |
-L | 间接显示符号连贯所指向的文件类别 |
命令应用示例:
查看 /var/log/messages 文件的文件类型。
file /var/log/messages
命令输入后果:
diff
命令形容:diff 命令用于比拟文件的差别。
命令应用示例:
1. 结构两个类似的文件
echo -e '第一行 \n 第二行 \n 我是 log1 第 3 行 \n 第四行 \n 第五行 \n 第六行' > 1.log
echo -e '第一行 \n 第二行 \n 我是 log2 第 3 行 \n 第四行' > 2.log
2. 别离查看两个文件
3. 应用 diff 查看两个文件的差别
比照后果中的 3c3 示意两个文件在第 3 行有不同,5,6d4 示意 2.log 文件相比 1.log 文件在第 4 行处开始少了 1.log 文件的第 5 和第 6 行。
文本文件解决命令
grep
命令形容:grep 命令用于查找文件里符合条件的字符串。
grep 全称是 Global Regular Expression Print,示意全局正则表达式版本,它能应用正则表达式搜寻文本,并把匹配的行打印进去。
在 Shell 脚本中,grep 通过返回一个状态值来示意搜寻的状态:
0:匹配胜利。
1:匹配失败。
2:搜寻的文件不存在。
命令格局:grep [参数] [正则表达式] [文件]。
命令罕用参数阐明:
参数 | 阐明 |
---|---|
- c 或 –count | 计算合乎款式的列数 |
-d recurse 或 -r | 指定要查找的是目录而非文件 |
-e [范本款式] | 指定字符串做为查找文件内容的款式 |
-E 或 –extended-regexp | 将款式为延长的正则表达式来应用 |
-G 或 –basic-regexp | 将款式视为一般的表示法来应用 |
-i 或 –ignore-case | 疏忽字符大小写的差异 |
-n 或 –line-number | 在显示合乎款式的那一行之前,标示出该行的列数编号 |
-v 或 –revert-match | 显示不蕴含匹配文本的所有行 |
命令应用示例:
查看 sshd 服务配置文件中监听端口配置所在行编号。
grep -n Port /etc/ssh/ssh_config
命令输入后果:
查问字符串在文本中呈现的行数。
grep -c localhost /etc/hosts
命令输入后果:
反向查找,不显示符合条件的行。
ps -ef | grep sshd
ps -ef | grep -v grep | grep sshd
命令输入后果:
以递归的形式查找目录下含有关键字的文件。
grep -r *.sh /etc
命令输入后果:
应用正则表达式匹配 httpd 配置文件中异样状态码响应的相干配置。
grep ‘ntp[0-9].aliyun.com’ /etc/ntp.conf
命令输入后果:
sed
命令形容:sed 是一种流编辑器,它是文本处理中十分中的工具,可能完满的配合正则表达式应用。
- 解决时,把以后解决的行存储在长期缓冲区中,称为模式空间(pattern space)。
- 接着用 sed 命令解决缓冲区中的内容,解决实现后,把缓冲区的内容送往屏幕。
- 接着解决下一行,这样一直反复,直到文件开端。
留神:
sed 命令不会批改原文件,例如删除命令只示意某些行不打印输出,而不是从原文件中删去。
如果要扭转源文件,须要应用 - i 选项。
命令格局:sed [参数] [动作] [文件]。
参数阐明:
参数 | 阐明 |
---|---|
-e [script] | 执行多个 script |
-f [script 文件] | 执行指定 script 文件 |
-n | 仅显示 script 解决后的后果 |
-i | 输入到原文件,静默执行(批改原文件) |
动作阐明:
动作 | 阐明 |
---|---|
a | 在行前面减少内容 |
c | 替换行 |
d | 删除行 |
i | 在行后面插入 |
p | 打印相干的行 |
s | 替换内容 |
命令应用示例:
删除第 3 行到最初一行内容。
sed '3,$d' /etc/passwd
命令输入后果:
在最初一行新增行。
sed '$a admin:x:1000:1000:admin:/home/admin:/bin/bash' /etc/passwd
命令输入后果:
替换内容。
sed 's/SELINUX=disabled/SELINUX=enforcing/' /etc/selinux/config
命令输入后果:
替换行。
sed '1c abcdefg' /etc/passwd
命令输入后果:
awk
命令形容:和 sed 命令相似,awk 命令也是逐行扫描文件(从第 1 行到最初一行),寻找含有指标文本的行,如果匹配胜利,则会在该行上执行用户想要的操作;反之,则不对行做任何解决。
命令格局:awk [参数] [脚本] [文件]。
参数阐明:
参数 | 阐明 |
---|---|
-F fs | 指定以 fs 作为输出行的分隔符,awk 命令默认分隔符为空格或制表符 |
-f file | 读取 awk 脚本 |
-v val=val | 在执行处理过程之前,设置一个变量 var,并给其设置初始值为 val |
内置变量:
变量 | 用处 |
---|---|
FS | 字段分隔符 |
$n | 指定分隔的第 n 个字段,如 $1、$3 别离示意第 1、第三列 |
$0 | 以后读入的整行文本内容 |
NF | 记录以后解决行的字段个数(列数) |
NR | 记录以后已读入的行数 |
FNR | 以后行在源文件中的行号 |
awk 中还能够指定脚本命令的运行机会。默认状况下,awk 会从输出中读取一行文本,而后针对该行的数据执行程序脚本,但有时可能须要在解决数据前运行一些脚本命令,这就须要应用 BEGIN 关键字,BEGIN 会在 awsk 读取数据前强制执行该关键字后指定的脚本命令。
和 BEGIN 关键字绝对应,END 关键字容许咱们指定一些脚本命令,awk 会在读完数据后执行它们。
命令应用示例:
查看本机 IP 地址。
ifconfig eth0 |awk '/inet/{print $2}'
命令输入后果:
查看本机残余磁盘容量。
df -h |awk '/\/$/{print $4}'
命令输入后果:
统计零碎用户个数。
awk -F: '$3<1000{x++} END{print x}' /etc/passwd
命令输入后果:
输入其中登录 Shell 不以 nologin 结尾(对第 7 个字段做!~ 反向匹配)的用户名、登录 Shell 信息。
awk -F: '$7!~/nologin$/{print $1,$7}' /etc/passwd
命令输入后果:
输入 /etc/passwd 文件中前三行记录的用户名和用户 uid。
head -3 /etc/passwd | awk 'BEGIN{FS=":";print"name\tuid"}{print $1,"\t"$3}END{print"sum lines "NR}'
命令输入后果:
查看 tcp 连接数。
netstat -na | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
命令输入后果:
敞开指定服务的所有的过程。
ps -ef | grep httpd | awk {'print $2'} | xargs kill -9
cut
命令形容:cut 命令次要用来切割字符串,能够对输出的数据进行切割而后输入。
命令格局:cut [参数] [文件]。
参数阐明:
参数 | 阐明 |
---|---|
-b | 以字节为单位进行宰割 |
-c | 以字符为单位进行宰割 |
-d | 自定义分隔符,默认为制表符 |
命令应用示例:
按字节进行切割。
按字符进行切割。
按指定字符进行切割。
tr
命令形容:tr 命令用于对来自规范输出的字符进行替换、压缩和删除。
命令格局:tr [参数] [文本]。
参数阐明:
参数 | 阐明 |
---|---|
-c | 反选指定字符 |
-d | 删除指定字符 |
-s | 将反复的字符缩减成一个字符 |
-t [第一字符集] [第二字符集] | 删除第一字符集较第二字符集多出的字符,使两个字符集长度相等 |
命令应用示例:
将输出字符由大写转换为小写。
echo "HELLO WORLD" | tr 'A-Z' 'a-z'
命令输入后果:
删除字符。
echo "hello 123 world 456" | tr -d '0-9'
命令输入后果:
压缩字符。
echo "thissss is a text linnnnnnne." | tr -s 'sn'
命令输入后果:
产生随机明码。
cat /dev/urandom | tr -dc a-zA-Z0-9 | head -c 13
命令输入后果: