欢迎使用优快云-markdown编辑器

***grep的详细用用法:
grep [OPTIONS] PATTERN [FILE…]
DESCRIPTION
grep searches the named input FILEs for lines containing a match to the given PATTERN. If no files are specified, or if the file “-” is given, grep searches standard input. By default, grep prints the matching lines.
grep 的常用选项:
-v :对匹配的行进行反匹配,意思就是对选择不符合条件的行。
-o:仅仅显示匹配到的内容

-i : 忽略字符大小写
-n : 为匹配的行加上行号
-E : 使用扩展正则表达式 ,等同于egrep命令
-F : 不使用正则表达式搜索,等同于fgrep命令
-A # : 连同匹配行的下#行一并显示,#代表任意数字
-B # : 连同匹配行的上#行一并显示,#代表任意数字
-C # : 连同匹配行的上下#行一并显示,#代表任意数字
–color=auto : 对匹配的内容以不同的颜色显示(alias grep == ‘grep –color’)
grep正则表达式的基本用法:
.(点号):匹配任意单个字符。
匹配5个字符以上的字符:
[] : 匹配指定集合中的任意单个字符
常用的集合表示方法有:
纯数字:[[:digit:]]或[0-9]
小写字母:[[:lower:]]或[a-z]
大写字母:[[:upper:]]或[A-Z]
大小写字母:[[:alpha:]]或[a-zA-Z]
数字加字母:[[:alnum:]]或[0-9a-zA-Z]
空白字符:[[:space:]]
标点符号:[[:punct:]]
显示包含数字0或2的行:

例2:匹配包含字母r或t的行
[^] : 匹配指定集合外的任意单个字符
例:匹配包含除1-9范围之外的字符的行(截图只包含前半部分)
(2)次数匹配
(3)位置锚定
^ : 行首锚定
例:匹配#字母出现在在行首的行
: 行尾锚定  
例:匹配e字母出现在行尾的行  
^
: 匹配空白行
例:匹配空白的行
\< : 词首锚定
例:精确匹配xy两个字母在一个单词的词首的行
\<> : 匹配单词
例:匹配包含xy这个单词的行
(3)分组
() : 对某字符串进行进行分组匹配
例:匹配xy单启出现0次或1次的行
后向引用:模式中,如果使用()实现了分组,在某行文本的检查中,如果()的模式匹配到了某内容,此内容后面的模式中可以被引用;
对前面的分组进行引用的符号为:\1 , \2 ,\3
模式自左而右,引用第#个左括号以及与其匹配右括号之间的模式匹配到的内容;
后向引用举例:
新建一个文本文件,假设有如下内容:
正则表达式元字符总结:
字符匹配:. ,[] ,[^]
次数匹配:* ,\? ,+ ,{m} ,{m,n}
位置锚定:^ ,\<>\<>()4.egrepegrepgrepEegrep使grepE.[][]?+mm,nm,0,n,>,\<
分组匹配:(),支持后向引用
| : 匹配左侧或右侧符合条件的行,比如a|b,含有a或b的行都匹配;
grep练习题:
(1).显示当前目录下*.c文件中以大写或小写s开头的行;

grep -i ‘^s’ *.c

(2).显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户;

grep -v ‘/sbin/nologin$’ /etc/passwd | cut -d: -f1

(3).显示/etc/passwd文件中其默认shell为/bin/bash的用户
进一步:仅显示上述结果中其ID号最大的用户

grep ‘/bin/bash$’ /etc/passwd | cut -d: -f1 | sort -n -r | head -1

(4).找出/etc/passwd文件中的一位数或两位数;

grep ‘\<[[:digit:]]{1,2}>’ /etc/passwd

(5).显示/boot/grub/grub.conf中至少一个空白字符开头的行

grep ‘^[[:space:]]+.*’ /boot/grub/grub.conf

(6).显示/etc/rc.d/rc.sysinit文件中,以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;

grep ‘^#[[:space:]]+[^[:space:]]+’ /etc/rc.d/rc.sysinit

(7).找出netstat -tan命令执行结果中包含’LISTEN’的行;

netstat -tan | grep ‘LISTEN[[:space:]]*$

(8).添加用户bash,testbash,basher,nologin(SHELL为/sbin/nologin),而找出当前系统上其用户名和默认SHELL相同的用户;

grep ‘(\<[[:alnum:]]+>).*\1$’ /etc/passwd

(9).扩展题:新建一个文本文件,假设有如下内容:
He like his lover.
He love his lover.
He like his liker.
He love his liker.
找出其中最后一个单词是由此前某单词加r构成的行;

grep ‘(\<[[:alpha:]]+>).*\1r’ grep.txt

(10).显示当前系统上root、centos或user1用户的默认shell及用户名;

grep -E ‘^(root|centos|user1>)’ /etc/passwd

(11).找出/etc/rc.d/init.d/functions文件中某单词后面跟一对小括号’()”的行;

grep -o ‘\<[[:alpha:]]+>()’ /etc/rc.d/init.d/functions

(12).使用echo输出一个路径,而使用egrep取出其基名;

echo /etc/rc.d/ | grep -o ‘[^/]+/\?$’ | grep -o ‘[^/]+’*

资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值