1、cd命令

这是一个非常基本,也是大家经常需要使用的命令,它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径。如:

  1. cd /root/Docements # 切换到目录/root/Docements
  2. cd ./path          # 切换到当前目录下的path目录中,“.”表示当前目录
  3. cd ../path         # 切换到上层目录中的path目录中,“..”表示上一层目录

2、ls命令

这是一个非常有用的查看文件与目录的命令,list之意,它的参数非常多,下面就列出一些我常用的参数吧,如下:

  1. -l :列出长数据串,包含文件的属性与权限数据等
  2. -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)
  3. -d :仅列出目录本身,而不是列出目录的文件数据
  4. -h :将文件容量以较易读的方式(GB,kB等)列出来
  5. -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来

注:这些参数也可以组合使用,下面举两个例子:

  1. ls -l #以长数据串的形式列出当前目录下的数据文件和目录
  2. ls -lR #以长数据串的形式列出当前目录下的所有文件

3、grep命令

该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为

  1. grep [-acinv] [--color=auto] '查找字符串' filename

它的常用参数如下:

  1. -a :将binary文件以text文件的方式查找数据
  2. -c :计算找到‘查找字符串’的次数
  3. -i :忽略大小写的区别,即把大小写视为相同
  4. -v :反向选择,即显示出没有‘查找字符串’内容的那一行
  5. # 例如:
  6. # 取出文件/etc/man.config中包含MANPATH的行,并把找到的关键字加上颜色
  7. grep --color=auto 'MANPATH' /etc/man.config
  8. # 把ls -l的输出中包含字母file(不区分大小写)的内容输出
  9. ls -l | grep -i file

grep [options]

[options]主要参数:

-c:只输出匹配行的计数。

-I:不区分大 小写(只适用于单字符)。

-h:查询多文件时不显示文件名。

-l:查询多文件时只输出包含匹配字符的文件名。

-n:显示匹配行及 行号。

-s:不显示不存在或无匹配文本的错误信息。

-v:显示不包含匹配文本的所有行。

pattern正则表达式主要参数:

\: 忽略正则表达式中特殊字符的原有含义。

^:匹配正则表达式的开始行。

$: 匹配正则表达式的结束行。

\<:从匹配正则表达 式的行开始。

\>:到匹配正则表达式的行结束。

[ ]:单个字符,如[A]即A符合要求 。

[ - ]:范围,如[A-Z],即A、B、C一直到Z都符合要求 。

。:所有的单个字符。

* :有字符,长度可以为0。

grep命令使用简单实例

$ grep ‘test’ d*

显示所有以d开头的文件中包含 test的行。

$ grep ‘test’ aa bb cc

显示在aa,bb,cc文件中匹配test的行。

$ grep ‘[a-z]\{5\}’ aa

显示所有包含每个字符串至少有5个连续小写字符的字符串的行。

$ grep ‘w\(es\)t.*\1′ aa

如果west被匹配,则es就被存储到内存中,并标记为1,然后搜索任意个字符(.*),这些字符后面紧跟着 另外一个es(\1),找到就显示该行。如果用egrep或grep -E,就不用”\”号进行转义,直接写成’w(es)t.*\1′就可以了。

grep命令使用复杂实例

假设您正在’/usr/src/Linux/Doc’目录下搜索带字符 串’magic’的文件:

$ grep magic /usr/src/Linux/Doc/*

sysrq.txt:* How do I enable the magic SysRQ key?

sysrq.txt:* How do I use the magic SysRQ key?

其中文件’sysrp.txt’包含该字符串,讨论的是 SysRQ 的功能。

默认情况下,’grep’只搜索当前目录。如果 此目录下有许多子目录,’grep’会以如下形式列出:

grep: sound: Is a directory

这可能会使’grep’ 的输出难于阅读。这里有两种解决的办法:

明确要求搜索子目录:grep -r

或忽略子目录:grep -d skip

如果有很多 输出时,您可以通过管道将其转到’less’上阅读:

$ grep magic /usr/src/Linux/Documentation/* | less

这样,您就可以更方便地阅读。

有一点要注意,您必需提供一个文件过滤方式(搜索全部文件的话用 *)。如果您忘了,’grep’会一直等着,直到该程序被中断。如果您遇到了这样的情况,按 <CTRL c> ,然后再试。

下面还有一些有意思的命令行参数:

grep -i pattern files :不区分大小写地搜索。默认情况区分大小写,

grep -l pattern files :只列出匹配的文件名,

grep -L pattern files :列出不匹配的文件名,

grep -w pattern files :只匹配整个单词,而不是字符串的一部分(如匹配’magic’,而不是’magical’),

grep -C number pattern files :匹配的上下文分别显示[number]行,

grep pattern1 | pattern2 files :显示匹配
pattern1 或 pattern2 的行,

grep pattern1 files | grep pattern2 :显示既匹配
pattern1 又匹配 pattern2 的行。

grep -n pattern
files  即可显示行号信息

grep -c pattern
files  即可查找总行数

这里还有些用于搜索的特殊符号:

\< 和 \> 分别标注单词的开始与结尾。

例如:

grep man * 会匹配 ‘Batman’、’manic’、’man’等,

grep ‘\<man’ * 匹配’manic’和’man’,但不是’Batman’,

grep ‘\<man\>’ 只匹配’man’,而不是’Batman’或’manic’等其他的字符串。

‘^’:指匹配的字符串在行首,

‘$’:指匹配的字符串在行 尾,

4、find命令

find是一个基于查找的功能非常强大的命令,相对而言,它的使用也相对较为复杂,参数也比较多,所以在这里将给把它们分类列出,它的基本语法如下:

  1. find [PATH] [option] [action]
  2. # 与时间有关的参数:
  3. -mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件;
  4. -mtime +n : 列出在n天之前(不含n天本身)被更改过的文件名;
  5. -mtime -n : 列出在n天之内(含n天本身)被更改过的文件名;
  6. -newer file : 列出比file还要新的文件名
  7. # 例如:
  8. find /root -mtime 0 # 在当前目录下查找今天之内有改动的文件
  9. # 与用户或用户组名有关的参数:
  10. -user name : 列出文件所有者为name的文件
  11. -group name : 列出文件所属用户组为name的文件
  12. -uid n : 列出文件所有者为用户ID为n的文件
  13. -gid n : 列出文件所属用户组为用户组ID为n的文件
  14. # 例如:
  15. find /home/ljianhui -user ljianhui # 在目录/home/ljianhui中找出所有者为ljianhui的文件
  16. # 与文件权限及名称有关的参数:
  17. -name filename :找出文件名为filename的文件
  18. -size [+-]SIZE :找出比SIZE还要大(+)或小(-)的文件
  19. -tpye TYPE :查找文件的类型为TYPE的文件,TYPE的值主要有:一般文件(f)、设备文件(b、c)、
  20. 目录(d)、连接文件(l)、socket(s)、FIFO管道文件(p);
  21. -perm mode :查找文件权限刚好等于mode的文件,mode用数字表示,如0755;
  22. -perm -mode :查找文件权限必须要全部包括mode权限的文件,mode用数字表示
  23. -perm +mode :查找文件权限包含任一mode的权限的文件,mode用数字表示
  24. # 例如:
  25. find / -name passwd # 查找文件名为passwd的文件
  26. find . -perm 0755 # 查找当前目录中文件权限的0755的文件
  27. find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte

5、cp命令

该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,它的常用参数如下:

  1. -a :将文件的特性一起复制
  2. -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份
  3. -i :若目标文件已经存在时,在覆盖时会先询问操作的进行
  4. -r :递归持续复制,用于目录的复制行为
  5. -u :目标文件与源文件有差异时才会复制

例如 :

  1. cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2
  2. cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中

6、mv命令

该命令用于移动文件、目录或更名,move之意,它的常用参数如下:

  1. -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖
  2. -i :若目标文件已经存在,就会询问是否覆盖
  3. -u :若目标文件已经存在,且比目标文件新,才会更新

注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。

例如:

  1. mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中
  2. mv file1 file2 # 把文件file1重命名为file2

7、rm命令

该命令用于删除文件或目录,remove之间,它的常用参数如下:

  1. -f :就是force的意思,忽略不存在的文件,不会出现警告消息
  2. -i :互动模式,在删除前会询问用户是否操作
  3. -r :递归删除,最常用于目录删除,它是一个非常危险的参数

例如:

  1. rm -i file # 删除文件file,在删除之前会询问是否进行该操作
  2. rm -fr dir # 强制删除目录dir中的所有文件

8、ps命令

该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:

  1. -A :所有的进程均显示出来
  2. -a :不与terminal有关的所有进程
  3. -u :有效用户的相关进程
  4. -x :一般与a参数一起使用,可列出较完整的信息
  5. -l :较长,较详细地将PID的信息列出

其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,如下:

  1. ps aux # 查看系统所有的进程数据
  2. ps ax # 查看不与terminal有关的所有进程
  3. ps -lA # 查看系统所有的进程数据
  4. ps axjf # 查看连同一部分进程树状态

9、kill命令

该命令用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用,它的基本语法如下:

  1. kill -signal PID

signal的常用参数如下:

注:最前面的数字为信号的代号,使用时可以用代号代替相应的信号。

  1. 1:SIGHUP,启动被终止的进程
  2. 2:SIGINT,相当于输入ctrl+c,中断一个程序的进行
  3. 9:SIGKILL,强制中断一个进程的进行
  4. 15:SIGTERM,以正常的结束进程方式来终止进程
  5. 17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行

例如:

  1. # 以正常的结束进程方式来终于第一个后台工作,可用jobs命令查看后台中的第一个工作进程
  2. kill -SIGTERM %1
  3. # 重新改动进程ID为PID的进程,PID可用ps命令通过管道命令加上grep命令进行筛选获得
  4. kill -SIGHUP PID

10、killall命令

该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:

  1. killall [-iIe] [command name]

它的参数如下:

  1. -i :交互式的意思,若需要删除时,会询问用户
  2. -e :表示后面接的command name要一致,但command name不能超过15个字符
  3. -I :命令名称忽略大小写
  4. # 例如:
  5. killall -SIGHUP syslogd # 重新启动syslogd

11、file命令

该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了,它的用法非常简单,基本语法如下:

  1. file filename
  2. #例如:
  3. file ./test

12、tar命令

该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:

  1. -c :新建打包文件
  2. -t :查看打包文件的内容含有哪些文件名
  3. -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
  4. -j :通过bzip2的支持进行压缩/解压缩
  5. -z :通过gzip的支持进行压缩/解压缩
  6. -v :在压缩/解压缩过程中,将正在处理的文件名显示出来
  7. -f filename :filename为要处理的文件
  8. -C dir :指定压缩/解压缩的目录dir

上面的解说可以已经让你晕过去了,但是通常我们只需要记住下面三条命令即可:

  1. 压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称
  2. 查询:tar -jtv -f filename.tar.bz2
  3. 解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录

注:文件名并不定要以后缀tar.bz2结尾,这里主要是为了说明使用的压缩程序为bzip2

13、cat命令

该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:

  1. cat text | less # 查看text文件中的内容
  2. # 注:这条命令也可以使用less text来代替

14、chgrp命令

该命令用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:

  1. chgrp [-R] dirname/filename
  2. -R :进行递归的持续对所有文件和子目录更改
  3. # 例如:
  4. chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users

15、chown命令

该命令用于改变文件的所有者,与chgrp命令的使用方法相同,只是修改的文件属性不同,不再详述。

16、chmod命令

该命令用于改变文件的权限,一般的用法如下:

  1. chmod [-R] xyz 文件或目录
  2. -R:进行递归的持续更改,即连同子目录下的所有文件都会更改

同时,chmod还可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭配来对文件的权限进行更改。

  1. # 例如:
  2. chmod 0755 file # 把file的文件权限改变为-rxwr-xr-x
  3. chmod g+w file # 向file的文件权限中加入用户组可写权限

18、vim命令

该命令主要用于文本编辑,它接一个或多个文件名作为参数,如果文件存在就打开,如果文件不存在就以该文件名创建一个文件。vim是一个非常好用的文本编辑器,它里面有很多非常好用的命令,在这里不再多说。你可以从这里下载vim常用操作的详细说明。

19、gcc命令

对于一个用Linux开发C程序的人来说,这个命令就非常重要了,它用于把C语言的源程序文件,编译成可执行程序,由于g++的很多参数跟它非常相似,所以这里只介绍gcc的参数,它的常用参数如下:

  1. -o :output之意,用于指定生成一个可执行文件的文件名
  2. -c :用于把源文件生成目标文件(.o),并阻止编译器创建一个完整的程序
  3. -I :增加编译时搜索头文件的路径
  4. -L :增加编译时搜索静态连接库的路径
  5. -S :把源文件生成汇编代码文件
  6. -lm:表示标准库的目录中名为libm.a的函数库
  7. -lpthread :连接NPTL实现的线程库
  8. -std= :用于指定把使用的C语言的版本
  9. # 例如:
  10. # 把源文件test.c按照c99标准编译成可执行程序test
  11. gcc -o test test.c -lm -std=c99
  12. #把源文件test.c转换为相应的汇编程序源文件test.s
  13. gcc -S test.c

20、time命令

该命令用于测算一个命令(即程序)的执行时间。它的使用非常简单,就像平时输入命令一样,不过在命令的前面加入一个time即可,例如:

  1. time ./process
  2. time ps aux

在程序或命令运行结束后,在最后输出了三个时间,它们分别是:

user:用户CPU时间,命令执行完成花费的用户CPU时间,即命令在用户态中执行时间总和;

system:系统CPU时间,命令执行完成花费的系统CPU时间,即命令在核心态中执行时间总和;

real:实际时间,从command命令行开始执行到运行终止的消逝时间;

注:用户CPU时间和系统CPU时间之和为CPU时间,即命令占用CPU执行的时间总和。实际时间要大于CPU时间,因为Linux是多任务操作系统,往往在执行一条命令时,系统还要处理其它任务。另一个需要注意的问题是即使每次执行相同命令,但所花费的时间也是不一样,其花费时间是与系统运行相关的。

grep, sed 与 awk 相当有用 !

gerp 查找, sed 编辑, awk 根据内容分析并处理.

awk(关键字:分析&处理) 一行一行的分析处理 awk '条件类型1{动作1}条件类型2{动作2}' filename, awk 也可以读取来自前一个指令的 standard
input

相对于sed常常用于一整行处理, awk则比较倾向于一行当中分成数个"字段"(区域)来处理, 默认的分隔符是空格键或tab键

例如:

last -n 5 | awk '{print $1 "\t" $3}' 这里大括号内$1"\t"$3 之间不加空格也可以, 不过最好还是加上个空格, 另外注意"\t"是有双引号的, 因为本身这些内容都在单引号内

$0 代表整行 $1代表第一个区域, 依此类推

awk的处理流程是:

1. 读第一行, 将第一行资料填入变量 $0, $1... 等变量中

2. 依据条件限制, 执行动作

3. 接下来执行下一行

所以, AWK一次处理是一行, 而一次中处理的最小单位是一个区域

另外还有3个变量, NF: 每一行处理的字段数, NR 目前处理到第几行 FS 目前的分隔符

逻辑判断 > < >= <= ==
!== , 赋值直接使用=

cat /etc/passwd | awk '{FS=":"} $3<10 {print $1 "\t"
$3}' 首先定义分隔符为:, 然后判断, 注意看, 判断没有写在{}中, 然后执行动作, FS=":"这是一个动作, 赋值动作, 不是一个判断, 所以不写在{}中

BEGIN END , 给程序员一个初始化和收尾的工作, BEGIN之后列出的操作在{}内将在awk开始扫描输入之前执行, 而END{}内的操作, 将在扫描完输入文件后执行.

awk '/test/ {print NR}' abc 将带有test的行的行号打印出来, 注意//之间可以使用正则表达式

awk {}内, 可以使用 if else ,for(i=0;i<10;i++), i=1 while(i<NF)

可见, awk的很多用法都等同于C语言, 比如"\t" 分隔符, print的格式, if, while, for 等等

awk 是相当复杂的工具, 真正使用时, 再补充吧. (有关工具的picture)

sed(关键字: 编辑) 以行为单位的文本编辑工具 sed可以直接修改档案, 不过一般不推荐这么做, 可以分析 standard
input

基本工作方式: sed [-nef] '[动作]' [输入文本]

-n : 安静模式, 一般sed用法中, 来自stdin的数据一般会被列出到屏幕上, 如果使用-n参数后, 只有经过sed处理的那一行被列出来.

-e : 多重编辑, 比如你同时又想删除某行, 又想改变其他行, 那么可以用 sed -e '1,5d' -e 's/abc/xxx/g' filename

-f : 首先将 sed的动作写在一个档案内, 然后通过 sed -f
scriptfile 就可以直接执行 scriptfile
内的sed动作 (没有实验成功, 不推荐使用)

-i : 直接编辑, 这回就是真的改变文件中的内容了, 别的都只是改变显示. (不推荐使用)

动作:

a 新增, a 后面可以接字符串, 而这个字符串会在新的一行出现. (下一行)

c 取代, c 后面的字符串, 这些字符串可以取代 n1,n2之间的行

d 删除, 后面不接任何东西

i 插入, 后面的字符串, 会在上一行出现

p 打印, 将选择的资料列出, 通常和 sed -n 一起运作 sed -n '3p' 只打印第3行

s 取代, 类似vi中的取代,
1,20s/old/new/g

[line-address]q 退出, 匹配到某行退出, 提高效率

[line-address]r 匹配到的行读取某文件 例如: sed '1r qqq' abc , 注意, 写入的文本是写在了第1行的后边, 也就是第2行

[line-address]w file, 匹配到的行写入某文件  例如: sed -n
'/m/w qqq' abc , 从abc中读取带m的行写到qqq文件中, 注意, 这个写入带有覆盖性.

举例:

sed '1d' abc 删除 abc 档案里的第一行, 注意, 这时会显示除了第一行之外的所有行, 因为第一行已经被删除了(实际文件并没有被删除,而只是显示的时候被删除了)

sed -n '1d' abc 什么内容也不显示, 因为经过sed处理的行, 是个删除操作, 所以不现实.

sed '2,$d' abc 删除abc中从第二行到最后一行所有的内容, 注意, $符号正则表达式中表示行末尾, 但是这里并没有说那行末尾, 就会指最后一行末尾, ^开头, 如果没有指定哪行开头, 那么就是第一行开头

sed '$d' abc 只删除了最后一行, 因为并没有指定是那行末尾, 就认为是最后一行末尾

sed '/test/d' abc 文件中所有带 test 的行, 全部删除

sed '/test/a RRRRRRR' abc 将 RRRRRRR 追加到所有的带 test 行的下一行 也有可能通过行 sed '1,5c RRRRRRR' abc

sed '/test/c RRRRRRR' abc 将 RRRRRRR 替换所有带 test 的行, 当然, 这里也可以是通过行来进行替换, 比如 sed '1,5c RRRRRRR' abc

grep(关键字: 截取) 文本搜集工具, 结合正则表达式非常强大

主要参数 []

-c : 只输出匹配的行

-I : 不区分大小写

-h : 查询多文件时不显示文件名

-l : 查询多文件时, 只输出包含匹配字符的文件名

-n : 显示匹配的行号及行

-v : 显示不包含匹配文本的所有行(我经常用除去grep本身)

基本工作方式: grep 要匹配的内容 文件名, 例如:

grep 'test' d* 显示所有以d开头的文件中包含test的行

grep 'test' aa bb cc 显示在 aa bb cc
文件中包含test的行

grep '[a-z]\{5}\' aa 显示所有包含字符串至少有5个连续小写字母的串

三个命令的运用形式

grep  ‘字符’  文件

sed    ‘命令’  文件

awk   ‘条件{命令}’ 
文件

单引号内就是正则表达式的用法

Linux命令(二)的更多相关文章

  1. 笔记常用Linux命令(二) 进程和端口

    查看系统进程 ps:用于报告当前系统的进程状态 a:显示所有终端机下执行的程序 ps -ef/ps aux: 这两个命令都是查看当前系统正在运行进程,两者的区别是展示格式不同. 如果想要查看特定的进程 ...

  2. Linux命令(二十三) 磁盘管理命令(一) df,du,tune2fs

    一. 查看磁盘占用空间情况 df df 命令用于查看硬盘空间的使用情况,还可以查看硬盘分区的类型或 inode 节点的使用情况等. df 命令常用参数如下: -a 显示所有文件系统的磁盘使用情况,包括 ...

  3. Linux命令(二十四) 磁盘管理命令(二) mkfs,mount

    一.格式化文件系统 mkfs 当完成硬盘分区以后要进行硬盘的格式化,mkfs系列对应的命令用于将硬盘格式化为指定格式的文件系统.mkfs 本身并不执行建立文件系统的工作,而是去调用相关的程序来执行.例 ...

  4. Linux命令(二十五) 磁盘管理命令(三) fdisk

    一.fdisk命令介绍 fdisk 为Linux系统下的分区管理工具,类型windows下的 分区助手等工具软件.分过区装过操作系统的人都知道硬盘分区是必要和重要的.fdisk 的帮助如下所示: [r ...

  5. Linux命令(二十七) 用户组管理命令

    Linux提供了一系列的命令管理用户组.用户组就是具有相同特征的用户集合.每个用户都有一个用户组,系统能对一个用户组中所有用户进行集中管理,通过把相同属性的用户定义到同一用户组,并赋予该用户自一定的操 ...

  6. Linux命令(二十六) 用户管理命令

    一.添加用户 useradd useradd 命令用于创建新用户,格式为useradd [选项] 用户名. 可以使用 useradd 命令创建用户帐户,使用该命令创建账户时,默认的用户目录在 /hom ...

  7. linux命令二

    4. df -h 查看磁盘使用情况    cpu:        user,system,idle,iowait    mem:        total,used,free,cached,buffe ...

  8. 29个你必须知道的Linux命令

    虽然Linux发行版支持各种各样的饿GUI(graphical user interfaces),但在某些情况下,Linux的命令行接口(bash)仍然是简单快速的.Bash和 Linux Shell ...

  9. Linux命令博客目录

    Linux 目录结构 Linux命令(一) pwd ,cd Linux命令(二) 复制文件 cp Linux命令(三) 移动文件 mv Linux命令(四)删除文件 rm Linux终端常用快捷键 L ...

  10. 《sed的流艺术之四》-linux命令五分钟系列之二十四

    本原创文章属于<Linux大棚>博客,博客地址为http://roclinux.cn.文章作者为rocrocket. 为了防止某些网站的恶性转载,特在每篇文章前加入此信息,还望读者体谅. ...

随机推荐

  1. 二、grep文本搜索工具

    grep命令作为Unix中用于文本搜索的神奇工具,能够接受正则表达式,生成各种格式的输出.除此外,它还有大量有趣的选项. # 搜索包含特定模式的文本行: [root@centos8 ~]#grep p ...

  2. HashSet的存储原理

    HashSet的底层用哈希散列表来存储对象(默认长度为16的数组),假如: Set set=new HashSet(); set.add(obj); 内部存储过程为:定义h=obj.hashCode, ...

  3. Docker(40)- docker 实战三之安装 ES+Kibana

    背景 参考了狂神老师的 Docker 教程,非常棒! https://www.bilibili.com/video/BV1og4y1q7M4?p=16 es 前言 es 暴露的端口很多 es 十分耗内 ...

  4. throws声明异常中断式处理异常

    1.throws 编译期异常,一直往上抛最后是JVM处理(打印并中断程序) 2.声明多个或者直接声明父类

  5. SpringMVC-初见

    目录 什么是SpringMVC? DispatcherServlet 第一个MVC程序 配置版 Maven可能存在资源过滤的问题 注解版 RestFul和控制器 实现Controller接口 使用注解 ...

  6. php升级版本后的影响5.5->7.1

    微信开发中之前常用到$GLOBALS['HTTP_RAW_POST_DATA'] ,但升级后这个参数不见了,导致了一系列错误, 可以用 file_get_contents('php://input') ...

  7. Spring Cloud Gateway 没有链路信息,我 TM 人傻了(上)

    本系列是 我TM人傻了 系列第五期[捂脸],往期精彩回顾: 升级到Spring 5.3.x之后,GC次数急剧增加,我TM人傻了 这个大表走索引字段查询的 SQL 怎么就成全扫描了,我TM人傻了 获取异 ...

  8. php 的一些问题

    ------------------------------------------------------------------------------ * 绝对路径转化为相对路径 <?ph ...

  9. layui 添加复选框checkbox后,无法正确显示及点击的方法

    layui 添加复选框checkbox后,无法正确显示方式,这个是由于html里的样式添加 layui-form后,没有加载 form插件 ,具体如下: <body style="ba ...

  10. 鸿蒙内核源码分析(VFS篇) | 文件系统和谐共处的基础 | 百篇博客分析OpenHarmony源码 | v68.01

    子曰:"质胜文则野,文胜质则史.文质彬彬,然后君子." <论语>:雍也篇 百篇博客系列篇.本篇为: v68.xx 鸿蒙内核源码分析(VFS篇) | 文件系统和谐共处的基 ...