利⽤shell连接服务器#应⽤连接timesten 数据库
host = Linux(ip, 'user', 'pwd')  # 传⼊Ip,⽤户名,密码
cdsql = host.send('ttisql smscc')  # 发送⼀个查看ip的命令
selInfo = host.send('select count(0) info;') #发送命令
host.close() #主机关闭
# 定义⼀个类,表⽰⼀台远端linux主机
class Linux(object):
sql连接不上服务器
# 通过IP, ⽤户名,密码,超时时间初始化⼀个远程Linux主机
def __init__(self, ip, username, password, timeout=30):
self.ip = ip
self.username = username
self.password = password
self.timeout = timeout
# transport和chanel
self.t = ''
self.chan = ''
# 链接失败的重试次数
<_times = 3
# 调⽤该⽅法连接远程主机
def connect(self):
while True:
# 连接过程中可能会抛出异常,⽐如⽹络不通、链接超时
try:
self.t = paramiko.Transport(sock=(self.ip, 22))
self.chan = pen_session()
self.chan.settimeout(self.timeout)
_pty()
self.chan.invoke_shell()
# 如果没有抛出异常说明连接成功,直接返回
print(u'连接%s成功' % self.ip)
# 接收到的⽹络数据解码为str
print(v(65535).decode('utf-8'))
return
# 这⾥不对可能的异常如, socket.timeout细化,直接⼀⽹打尽
except Exception as e1:
_times != 0:
print(u'连接%s失败,进⾏重试' % self.ip)
<_times -= 1
else:
print(u'重试3次失败,结束程序')
exit(1)
# 断开连接
def close(self):
self.chan.close()
# 发送要执⾏的命令
def send(self, cmd):
cmd += '\r'
# 通过命令执⾏提⽰符来判断命令是否执⾏完成
p = repile('root@scdel-02:.*?#')
result = ''
# 发送要执⾏的命令
self.chan.send(cmd)
# 回显很长的命令可能执⾏较久,通过循环分批次取回回显,执⾏成功返回true,失败返回false
while True:
time.sleep(0.5)
ret = v(65535)
ret = ret.decode('utf-8')
result += ret
return result

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。