首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux 常用命令 vim常用命令 速查

Linux 常用命令 vim常用命令 速查

原创
作者头像
大鹅
发布2021-06-03 16:25:27
3.5K0
发布2021-06-03 16:25:27
举报

toc

这篇博客会记录常用的Linux命令,可以直接使用Ctrl+F来快速查找命令~

进程类

top

  1. 概述
top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。
可以直接使用top命令后,查看%MEM的内容。可以选择按进程查看或者按用户查看,如想查看oracle用户的进程内存使用情况的话可以使用如下的命令:

  $ top -u oracle

  1. 格式
`top [-] [d delay] [q] [c] [S] [s] [i] [n]`
  1. 主要参数
d:指定更新的间隔,以秒计算。
q:没有任何延迟的更新。如果使用者有超级用户,则top命令将会以最高的优先序执行。
c:显示进程完整的路径与名称。
S:累积模式,会将己完成或消失的子行程的CPU时间累积起来。
s:安全模式。
i:不显示任何闲置(Idle)或无用(Zombie)的行程。
n:显示更新的次数,完成后将会退出top。
  1. 内容解释
PID(Process ID):进程标示号。
USER:进程所有者的用户名。
PR:进程的优先级别。
NI:进程的优先级别数值。
VIRT:进程占用的虚拟内存值。
RES:进程占用的物理内存值。
SHR:进程使用的共享内存值。
S:进程的状态,其中S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值是负数。
%CPU:该进程占用的CPU使用率。
%MEM:该进程占用的物理内存和总内存的百分比。
TIME+:该进程启动后占用的总的CPU时间。
Command:进程启动的启动命令名称,如果这一行显示不下,进程会有一个完整的命令行。

pmap

  可以根据进程查看进程相关信息占用的内存情况,(进程号可以通过ps查看)如下所示:

  pmap -d 14596

ps

  1. 作用
ps显示瞬间进程 (process) 的动态,使用权限是所有使用者。
  1. 格式
`ps [options] [--help]`
  1. 主要参数
-A:列出所有的进程。
-l:显示长列表。
-m:显示内存信息。
-w:显示加宽可以显示较多的信息。
-e:显示所有进程。
a:显示终端上的所有进程,包括其它用户的进程。
-au:显示较详细的信息。
-aux:显示所有包含其它使用者的进程。
  1. 应用实例

在进行系统维护时,经常会出现内存使用量惊人,而又不知道是哪一个进程占用了大量进程的情况。除了可以使用top命令查看内存使用情况之外,还可以使用下面的命令:

ps aux | sort +5n

文件类

grep

  1. 概要
**grep**全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。

grep命令可以指定文件中搜索特定的内容,并将含有这些内容的行标准输出。

  1. 格式
`grep [options]`
  1. 主要参数
[options]主要参数:
-c:只输出匹配行的计数。
-I:不区分大小写(只适用于单字符)。
-h:查询多文件时不显示文件名。
-l:查询多文件时只输出包含匹配字符的文件名。
-n:显示匹配行及行号。
-s:不显示不存在或无匹配文本的错误信息。
-v:显示不包含匹配文本的所有行。
pattern正则表达式主要参数:
/:忽略正则表达式中特殊字符的原有含义。
^:匹配正则表达式的开始行。
$: 匹配正则表达式的结束行。
/<:从匹配正则表达式的行开始。
/>:到匹配正则表达式的行结束。
[ ]:单个字符,如[A]即A符合要求 。
[ - ]:范围,如[A-Z],即A、B、C一直到Z都符合要求 。
。:所有的单个字符。
* :有字符,长度可以为0。
>正则表达式是Linux/Unix系统中非常重要的概念。正则表达式(也称为“regex”或“regexp”)是一个可以描述一类字符串的模式(Pattern)。如果一个字符串可以用某个正则表达式来描述,我们就说这个字符和该正则表达式匹配(Match)。这和DOS中用户可以使用通配符 “*”代表任意字符类似。在Linux系统上,正则表达式通常被用来查找文本的模式,以及对文本执行“搜索-替换”操作和其它功能。
  1. 应用实例
查询DNS服务是日常工作之一,这意味着要维护覆盖不同网络的大量IP地址。有时IP地址会超过2000个。如果要查看nnn.nnn网络地址,但是却忘了第二部分中的其余部分,只知到有两个句点,例如nnn nn..。要抽取其中所有nnn.nnn IP地址,使用`[0-9 ]/{3 /}/.[0-0/{3/}/`。含义是任意数字出现3次,后跟句点,接着是任意数字出现3次,后跟句点。
`$grep '[0-9 ]/{3 /}/.[0-0/{3/}/' ipfile`
补充说明,grep家族还包括**fgrep**和**egrep**。fgrep是fix grep,允许查找字符串而不是一个模式;egrep是扩展grep,支持基本及扩展的正则表达式,但不支持/q模式范围的应用及与之相对应的一些更加规范的模式。  

awk

  1. 概要
awk其名称得自于它的创始人 Alfred Aho 、Peter Weinberger 和 Brian Kernighan 姓氏的首个字母。实际上 AWK 的确拥有自己的语言: AWK 程序设计语言 , 三位创建者已将它正式定义为“样式扫描和处理语言”。它允许您创建简短的程序,这些程序读取输入文件、为数据排序、处理数据、对输入执行计算以及生成报表,还有无数其他的功能。
简单来说awk就是**把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理**。
  1. 格式
`awk [选项参数] 'script' var=value file(s)`
`awk [选项参数] -f scriptfile var=value file(s)`
  1. 主要参数
-F fs or --field-separator fs
指定输入文件折分隔符,fs是一个字符串或者是一个正则表达式,如-F:。
-v var=value or --asign var=value
赋值一个用户定义变量。
-f scripfile or --file scriptfile
从脚本文件中读取awk命令。
-mf nnn and -mr nnn
对nnn值设置内在限制,-mf选项限制分配给nnn的最大块数目;-mr选项限制记录的最大数目。这两个功能是Bell实验室版awk的扩展功能,在标准awk中不适用。
-W compact or --compat, -W traditional or --traditional
在兼容模式下运行awk。所以gawk的行为和标准的awk完全一样,所有的awk扩展都被忽略。
-W copyleft or --copyleft, -W copyright or --copyright
打印简短的版权信息。
-W help or --help, -W usage or --usage
打印全部awk选项和每个选项的简短说明。
-W lint or --lint
打印不能向传统unix平台移植的结构的警告。
-W lint-old or --lint-old
打印关于不能向传统unix平台移植的结构的警告。
-W posix
打开兼容模式。但有以下限制,不识别:/x、函数关键字、func、换码序列以及当fs是一个空格时,将新行作为一个域分隔符;操作符**和**=不能代替^和^=;fflush无效。
-W re-interval or --re-inerval
允许间隔正则表达式的使用,参考(grep中的Posix字符类),如括号表达式[[:alpha:]]。
-W source program-text or --source program-text
使用program-text作为源代码,可与-f命令混用。
-W version or --version
打印bug报告信息的版本。
  1. 应用实例
log.txt文本内容如下:
>2 this is a test
3 Are you like awk
This's a test
10 There are orange,apple,mongo
用法一:
`awk '{[pattern] action}' {filenames} `  行匹配语句 awk '' 只能用单引号
实例:
每行按空格或TAB分割,输出文本中的1、4项

awk '{print $1,$4}' log.txt 2 a

3 like

This's

10 orange,apple,mongo

格式化输出

awk '{printf "%-8s %-10s\n",$1,$4}' log.txt

2 a

3 like

This's

10 orange,apple,mongo

可以参考http://www.runoob.com/linux/linux-comm-awk.html 

sed

  1. 概要 Linux sed命令是利用script来处理文本文件。 sed可依照script的指令,来处理、编辑文本文件。 Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。
  2. 格式
`sed [-hnV][-e<script>][-f<script文件>][文本文件]`
  1. 主要参数
参数说明:
-e< script> 或--expression=< script> 以选项中指定的script来处理输入的文本文件。
-f< script文件>或--file=< script文件> 以选项中指定的script文件来处理输入的文本文件。
-h或--help 显示帮助。
-n或--quiet或--silent 仅显示script处理后的结果。
-V或--version 显示版本信息。
动作说明:
a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)
c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
p :打印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行
s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 
  1. 应用实例
在testfile文件的第四行后添加一行,并将结果输出到标准输出,在命令行提示符下输入如下命令:
`sed -e 4a\newLine testfile `
首先查看testfile中的内容如下:
>$ cat testfile #查看testfile 中的内容  
HELLO LINUX!  
Linux is a free unix-type opterating system.  
This is a linux testfile!  
Linux test 
使用sed命令后,输出结果如下:
>$ sed -e 4a\newline testfile #使用sed 在第四行后添加新字符串  
HELLO LINUX! #testfile文件原有的内容  
Linux is a free unix-type opterating system.  
This is a linux testfile!  
Linux test  
newline 
跟多可以参考http://www.runoob.com/linux/linux-comm-sed.html

awk、sed、grep对比

  • grep 更适合单纯的查找或匹配文本
  • sed 更适合编辑匹配到的文本
  • awk 更适合格式化文本,对文本进行较复杂格式处理

rm

  1. 概要:
删除一个目录中的一个或多个文件或目录,如果没有使用- r选项,则rm不会删除目录。如果使用 rm 来删除文件,通常仍可以将该文件恢复原状。
rm是一个危险的命令,使用的时候要特别当心,尤其对于新手,否则整个系统就会毁在这个命令(比如在/(根目录)下执行`rm * -rf`)。
  1. 命令格式:
`rm [选项] 文件… `
  1. 命令参数:
-f, --force    忽略不存在的文件,从不给出提示。
-i, --interactive 进行交互式删除
-r, -R, --recursive   指示rm将参数中列出的全部目录和子目录均递归地删除。
-v, --verbose    详细显示进行的步骤
  	--help     显示此帮助信息并退出
  	--version  输出版本信息并退出
  1. 应用实例
删除任何.log文件;删除前逐一询问确认 
`rm -i *.log`

其他常用命令

大文件查找

find . -type f -size +800M

系统信息

uname -a               # 查看内核/操作系统/CPU信息
head -n 1 /etc/issue   # 查看操作系统版本
cat /proc/cpuinfo      # 查看CPU信息
hostname               # 查看计算机名
lspci -tv              # 列出所有PCI设备
lsusb -tv              # 列出所有USB设备
lsmod                  # 列出加载的内核模块
env                    # 查看环境变量

资源

free -m                # 查看内存使用量和交换区使用量
df -h                  # 查看各分区使用情况
du -sh <目录名>        # 查看指定目录的大小
grep MemTotal /proc/meminfo   # 查看内存总量
grep MemFree /proc/meminfo    # 查看空闲内存量
uptime                 # 查看系统运行时间、用户数、负载
cat /proc/loadavg      # 查看系统负载

抓包

tcpdump -i any -Xnnlps0 tcp and port 6379

抓6379端口的包(redis)

vi / vim 常用命令

一、vi / vim 的使用:

vi / vim: 进入vim编辑器 (默认为命令模式) 如: vi a.txt 或者 vim a.txt

二、vi / vim 的三种工作方式:

命令模式: 在这种模式下,可以通过输入vi的命令对文件的内容就行处理(复制,删除,移动等),也可以通过按光标来移动光标

编辑模式: 在这种模式下,可以在光标处输入内容

命令项模式: 在命令模式下,用户输入冒号后,光标会跳到底行,然后输入命令

模式之间的转换:

命令模式: 输入a A i I o O等命令 -> 编辑模式

编辑模式: 按ESC键 -> 命令模式

命令项模式: 输入冒号 -> 命令项模式

三、在命令模式下,可以输入以下命令;

1.光标移动命令 h:左 l:右 k:上 j:下

2.插入命令

i:在光标处插入 I:在第一行插入内容

a:在光标后插入内容 A:在当前行的尾部插入内容

o:在当前行的下面插入新行 O:在当前行的上面插入新行

3.删除命令

x: 删除光标处的字符 X:删除光标前的一个字符

d0: 删除光标所在行的第一个字符到当前光标的前一个字符的一串字符

D: 删除从当前光标所在字符到当前光标所在行的最后一个字符的一串字符

dd: 删除光标所在行的所有字符/剪切当前行

dw: 删除从光标处字符开始的第一个单词

u: 撤销命令,一步一步撤销

4.复制粘贴、剪切、移动

yy: 复制当前行 nyy: 复制当前行开始的n行

先按 v 进入自由选择模式:

使用光标移动命令选择区域,按 y 复制选中行 ,按 d 剪切选中行,在需要粘贴处按 P或p 即可。p(小): 在当前光标处下面粘贴内容 P(大): 在当前光标处上面粘贴内容

四、退出 vi / vim 命令

:w 保存文件 不退出vi :wq 保存文件,退出vi :q! 不保存文件,退出vi

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 进程类
    • top
      • pmap
        • ps
        • 文件类
          • grep
            • awk
              • sed
                • awk、sed、grep对比
                  • rm
                  • 其他常用命令
                    • 大文件查找
                      • 系统信息
                        • 资源
                          • 抓包
                            • vi / vim 常用命令
                            相关产品与服务
                            云服务器
                            云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
                            领券
                            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档