你好,游客 登录 注册 搜索
背景:
阅读新闻

通过Shell脚本格式化tnsnames.ora内容案例一则

[日期:2015-08-13] 来源:Linux社区  作者:winston_DBA [字体: ]

最近总结了下工作过程中的工作量,发现为开发人员配置参数占据了较大的一块,于是便想通过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串是否存在后的操作,由于较简单,略过。

本文永久更新链接地址http://www.linuxidc.com/Linux/2015-08/121631.htm

linux
相关资讯       tnsnames.ora 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款