视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
通过Shell脚本格式化tnsnames.ora内容案例一则
2020-11-09 07:50:40 责编:小采
文档


在配置参数的过程中,首先需要查看tnsnames.ora中的内容,如果需要配置的tns串已经在文件中存在,则直接将相关参数指向某个tns串

最近总结了下工作过程中的工作量,发现为开发人员配置参数占据了较大的一块,于是便想通过shell脚本简化工作流程操作及减少工作量。

在配置参数的过程中,首先需要查看tnsnames.ora中的内容,如果需要配置的tns串已经在文件中存在,则直接将相关参数指向某个tns串即可。如果不存在,则涉及在tnsnames.ora中添加tns串,再设置相关参数。
在现在的工作中,我们确定通过cat查看tnsnames.ora,接着结合管道和grep来确认tns串是否存在,但这样通常过于繁琐,我们想简单写个shell脚本,以后只需要将tnsnames.ora作为参数传入,即可输出相关结果及提示相应的操作。

在编写脚本过程中,首先面临的一个问题就是tnsnames.ora中tns串的格式不一致:有的tns在同一行,有的tns串分好几行,这样的话,我们需要对文件格式进行格式化。为了便于后续的操作,我们决定将所有的tns串都整理成一行。
格式化脚本主要内容如下:
sed '/^$/d' $1 | sed 's/ //g' | sed ':a;N;$!ba;s/\=\n/\=/g' | sed ':a;N;$!ba;s/\n(/(/g' | sed ':a;N;$!ba;s/\n)/)/g' > tnsnames.result
脚本的主要思路为:
1.首先将tnsnames.ora里的空行和空格去除。
2.将以 ( 和 ) 开头的行,整理到一行
3.将处理后的结果重定向到一个文件中,,保存下来。

对于sed ':a;N;!ba;s/\n(/(/g' 命令的解释:
:a创建一个标记。
N 追加当前行和下一行到模式空间中
ba如果处于最后一行前,跳转到之前的标记处
$!ba($!意思是不在最后一行做后面的操作,最后一行,特殊处理。)

对于查找到tns串是否存在后的操作,由于较简单,略过。

本文永久更新链接地址:

下载本文
显示全文
专题