Linux系统中如何用shell脚步判断是否telnet成功。 10
例如:如下脚本是用ping地址是否通畅来执行sql脚本,我想把ping换成telnet目标地址端口请问该怎么写呢。请大虾指点小弟刚学!#!/bin/bashR_IP=`p...
例如:如下脚本是用ping地址是否通畅来执行sql脚本,我想把ping 换成telnet 目标地址 端口 请问该怎么写呢。请大虾指点小弟刚学!
#!/bin/bash
R_IP=`ping 192.168.10.10 -c4 | awk '/^4/{print $4}'`
if [ $R_IP -le 1 ]
then
su - oracle -c "/oracle/app/oracle/product/10.2.0/db_1/bin/sqlplus @/oracle/app/oracle/product/10.2.0/db_1/sqlscript/test.sql;"
fi 展开
#!/bin/bash
R_IP=`ping 192.168.10.10 -c4 | awk '/^4/{print $4}'`
if [ $R_IP -le 1 ]
then
su - oracle -c "/oracle/app/oracle/product/10.2.0/db_1/bin/sqlplus @/oracle/app/oracle/product/10.2.0/db_1/sqlscript/test.sql;"
fi 展开
4个回答
展开全部
telnet是交互式的,不适合放在脚本里,除非你熟悉expect命令,expect+telnet组合比较复杂。建议你使用nc命令。
nc -v -z ip port
成功的话,显示下面类似输出提示。
Connection to xxx.xxx.xxx.xxx yyyy port [tcp/****] succeeded!
注:nc某些linux版本不是默认安装的,甚至没有安装包,可以找到通用的安装包。
nc -v -z ip port
成功的话,显示下面类似输出提示。
Connection to xxx.xxx.xxx.xxx yyyy port [tcp/****] succeeded!
注:nc某些linux版本不是默认安装的,甚至没有安装包,可以找到通用的安装包。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#!/bin/bash
nport=`echo ""|telnet 192.168.10.10 1521 2>/dev/null|grep "\^]"|wc -l`
if [ $nport -eq 1 ];then
su - oracle -c "/oracle/app/oracle/product/10.2.0/db_1/bin/sqlplus @/oracle/app/oracle/product/10.2.0/db_1/sqlscript/test.sql;"
fi
说明:如果直接用 telnet 192.168.10.10 1521,返回值$?,不管ip和端口通还是不通返回都是1,所以不能用$?的返回值来判断。如果telnet端口通的话会返回'^]'这样的字符,只要判断一下有没有返回这个字符就可以判断IP的端口通没通。
nport=`echo ""|telnet 192.168.10.10 1521 2>/dev/null|grep "\^]"|wc -l`
if [ $nport -eq 1 ];then
su - oracle -c "/oracle/app/oracle/product/10.2.0/db_1/bin/sqlplus @/oracle/app/oracle/product/10.2.0/db_1/sqlscript/test.sql;"
fi
说明:如果直接用 telnet 192.168.10.10 1521,返回值$?,不管ip和端口通还是不通返回都是1,所以不能用$?的返回值来判断。如果telnet端口通的话会返回'^]'这样的字符,只要判断一下有没有返回这个字符就可以判断IP的端口通没通。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#!/bin/bash
/bin/bash telnet 192.168.10.10 1521
status=$?
if [ $status == 1 ]
then
su - oracle -c "/oracle/app/oracle/product/10.2.0/db_1/bin/sqlplus @/oracle/app/oracle/product/10.2.0/db_1/sqlscript/test.sql;"
判断telnet命令是否执行成功,如返回值是1就执行 以下的sql
不过我不明白 返回值是1是执行不成功 返回0是成功,你应该返回值是0确认oracle数据库端口1521存活 再执行sql啊 如果oracle挂了 你还执行做什么?
/bin/bash telnet 192.168.10.10 1521
status=$?
if [ $status == 1 ]
then
su - oracle -c "/oracle/app/oracle/product/10.2.0/db_1/bin/sqlplus @/oracle/app/oracle/product/10.2.0/db_1/sqlscript/test.sql;"
判断telnet命令是否执行成功,如返回值是1就执行 以下的sql
不过我不明白 返回值是1是执行不成功 返回0是成功,你应该返回值是0确认oracle数据库端口1521存活 再执行sql啊 如果oracle挂了 你还执行做什么?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询