免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 6371 | 回复: 10

[文本处理] 查服务脚本几个问题请教 [复制链接]

论坛徽章:
1
巨蟹座
日期:2013-10-12 09:53:21
发表于 2013-08-02 16:14 |显示全部楼层
本帖最后由 taosicai 于 2013-08-02 16:17 编辑

目的:查informix数据库的服务
过程
echo  "下面紧临这行注意大小写"
env  |  grep INFORMIX
echo  "在结果中找:INFORMIXSQLHOSTS=/informix/etc/sqlhosts.inf"
cat  /informix/etc/sqlhosts.inf
echo  "在结果中找以tcp结尾的行(多数是这个协议),例:onsoctcp   serverName   servicesName"
cat /etc/services  |  grep  servicesName

脚本
su - informix <<EOF
env | grep INFORMIX
fileName=`env | awk '/INFORMIXSQLHOSTS/{print substr($0,18 )}'`
#ServerName=`env | awk '/INFORMIXSERVER/{print substr($0,16)}'`
echo "*********************************"
echo "# cat" $fileName
cat $fileName
fileInfo=`cat $fileName | awk '/onsoctcp/{print $NF}'`
echo $fileInfo
echo "*********************************"
for Info in $fileInfo
do
  echo "# cat /etc/services | grep" $Info
  cat /etc/services | grep $Info
  echo "*********************************"
done
EOF

论坛徽章:
1
巨蟹座
日期:2013-10-12 09:53:21
发表于 2013-08-02 16:15 |显示全部楼层
问题
1、fileName变量获取时,如果想使用=定位,如何写awk的substr和index?
2、fileInfo变量获取时,如果协议可能有onsoctcp、olsoctcp、drsoctcp、secoctcp这四种情况该怎么办?
3、如果启用注释的serverName变量,fileInfo=`cat $fileName | awk '/$serverName/{print $NF}'` 怎样才对?
4、脚本除第一行和最后一行外的内容,我在red hat上测试过了,我在informix用户下用export写环境,退出后就无效了。我该怎么办?所以暂时没在root下测试。

论坛徽章:
30
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3719周年集字徽章-19
日期:2019-08-27 13:31:2619周年集字徽章-CU
日期:2019-09-08 23:26:25
发表于 2013-08-02 16:36 |显示全部楼层
1
  1. fileName=`env | awk -F= '/INFORMIXSQLHOSTS/{print $2}'`
复制代码

论坛徽章:
30
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3719周年集字徽章-19
日期:2019-08-27 13:31:2619周年集字徽章-CU
日期:2019-09-08 23:26:25
发表于 2013-08-02 16:42 |显示全部楼层
2
  1. fileInfo=`cat $fileName | awk '/octcp/{print $NF}'`
复制代码

论坛徽章:
1
巨蟹座
日期:2013-10-12 09:53:21
发表于 2013-08-05 09:53 |显示全部楼层
Shell_HAT 发表于 2013-08-02 16:36
1


学习了,这个用法真好。

论坛徽章:
1
巨蟹座
日期:2013-10-12 09:53:21
发表于 2013-08-05 10:21 |显示全部楼层
回复 4# Shell_HAT


    这种方法确实能解决问题,高手这样回答,说明awk没有grep -E这样的参数。我明白了。

论坛徽章:
1
巨蟹座
日期:2013-10-12 09:53:21
发表于 2013-08-05 12:34 |显示全部楼层
问题3自问自答
3、如果启用注释的serverName变量,fileInfo=`cat $fileName | awk '/$serverName/{print $NF}'` 怎样才对?

fileInfo=`cat $fileName | awk '/'$serverName'/{print $NF}'`

论坛徽章:
1
巨蟹座
日期:2013-10-12 09:53:21
发表于 2013-08-05 12:37 |显示全部楼层
问题4自问自答
4、脚本除第一行和最后一行外的内容,我在red hat上测试过了,我在informix用户下用export写环境,退出后就无效了。我该怎么办?所以暂时没在root下测试。

su - informix
vi .bash_profile
export INFORMIXDIR=/opt/ibm/informix
保存
source .bash_profile

论坛徽章:
1
巨蟹座
日期:2013-10-12 09:53:21
发表于 2013-08-05 12:37 |显示全部楼层
本帖最后由 taosicai 于 2013-08-05 12:38 编辑

结贴。
再次感谢老朋友:Shell_HAT !!!

论坛徽章:
30
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3719周年集字徽章-19
日期:2019-08-27 13:31:2619周年集字徽章-CU
日期:2019-09-08 23:26:25
发表于 2013-08-05 12:55 |显示全部楼层
回复 6# taosicai


awk里面的语法是这样的:
  1. awk '/onsoctcp/||/lsoctcp/'
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会

【架构革新 高效可控】2020年12月21日-23日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP