python 通過(guò)SSHTunnelForwarder隧道連接redis的方法
背景:我司Redis服務(wù)器使用的亞馬遜服務(wù),本地需要通過(guò)跳板機(jī),然后才有權(quán)限訪(fǎng)問(wèn)Redis服務(wù)。
連接原理:使用SSHTunnelForwarder模塊,通過(guò)本地22端口ssh到跳板機(jī),然后本地開(kāi)啟一個(gè)轉(zhuǎn)發(fā)端口給跳板機(jī)遠(yuǎn)程Redis服務(wù)使用。
兩種思路:
1、通過(guò)SSHTunnelForwarder,paramiko模塊,先ssh到跳板機(jī),然后在跳板機(jī)上(或者內(nèi)部服務(wù)器上),獲取到權(quán)限,然后遠(yuǎn)程Redis。
2、使用SSHTunnelForwarder模塊,通過(guò)本地22端口ssh到跳板機(jī),然后本地開(kāi)啟一個(gè)轉(zhuǎn)發(fā)端口給跳板機(jī)遠(yuǎn)程Redis服務(wù)使用。
思路一:
private_key_path = '/Users/xxx/.ssh/id_rsa' rsaKey = paramiko.RSAKey.from_private_key_file(private_key_path) ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.connect(跳板機(jī)或者內(nèi)網(wǎng)服務(wù)器IP或者域名, 22, username, rsaKey) stdin, stdout, stderr = ssh.exec_command('redis-cli -h {} -p {} -n {} {}'.format(host, port, db, script)) result = stdout.read(), stderr.read() for out in result: # 需要通過(guò)循環(huán)拿到stdout,否則為空值 if out: return out
類(lèi)似:
import paramiko from sshtunnel import SSHTunnelForwarder with SSHTunnelForwarder( (REMOTE_SERVER_IP, 443), ssh_username="", ssh_pkey="/var/ssh/rsa_key", ssh_private_key_password="secret", remote_bind_address=(PRIVATE_SERVER_IP, 22), local_bind_address=('0.0.0.0', 10022) ) as tunnel: client = paramiko.SSHClient() client.load_system_host_keys() client.set_missing_host_key_policy(paramiko.AutoAddPolicy()) client.connect('127.0.0.1', 10022) # do some operations with client session client.close() print('FINISH!')
方法二:
# 使用SSHTunnelForwarder隧道,通過(guò)跳板機(jī)鏈接Redis with SSHTunnelForwarder( ('xxx.xxx.xx.xx', 22), # 跳板機(jī) ssh_username=username, ssh_pkey="/Users/xxx/.ssh/id_rsa", remote_bind_address=('xx.xx.xx.xxx', 6379), # 遠(yuǎn)程的Redis服務(wù)器 local_bind_address=('0.0.0.0', 10022) # 開(kāi)啟本地轉(zhuǎn)發(fā)端口 ) as server: server.start() # 開(kāi)啟隧道 print(server.local_bind_port) # 本地通過(guò)local_bind_port端口轉(zhuǎn)發(fā),利用跳板機(jī),鏈接Redis服務(wù) cls.red = redis.Redis(host='127.0.0.1', port=server.local_bind_port, db=db, decode_responses=True) server.close() # 關(guān)閉隧道
Advice:
一般跳板機(jī)是個(gè)干凈的機(jī)器,公司內(nèi)網(wǎng)服務(wù)器大部分不會(huì)給權(quán)限或者有redis-client客戶(hù)端,因此推薦使用方法2。
SSHTunnelForwarder使用:https://pypi.python.org/pypi/sshtunnel/
以上這篇python 通過(guò)SSHTunnelForwarder隧道連接redis的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python中的Joblib庫(kù)使用學(xué)習(xí)總結(jié)
這篇文章主要介紹了Python中的Joblib庫(kù)使用學(xué)習(xí)總結(jié),Joblib是一組在Python中提供輕量級(jí)流水線(xiàn)的工具,Joblib已被優(yōu)化得很快速,很健壯了,特別是在大數(shù)據(jù)上,并對(duì)numpy數(shù)組進(jìn)行了特定的優(yōu)化,需要的朋友可以參考下2023-08-08python實(shí)現(xiàn)批量監(jiān)控網(wǎng)站
本文給大家分享的是一個(gè)非常實(shí)用的,python實(shí)現(xiàn)多網(wǎng)站的可用性監(jiān)控的腳本,并附上核心點(diǎn)解釋?zhuān)邢嗤枨蟮男』锇榭梢詤⒖枷?/div> 2016-09-09淺談python多進(jìn)程共享變量Value的使用tips
今天小編就為大家分享一篇淺談python多進(jìn)程共享變量Value的使用tips,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-07-07python神經(jīng)網(wǎng)絡(luò)MobileNetV3?large模型的復(fù)現(xiàn)詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)MobileNetV3?large模型的復(fù)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05Python基于隨機(jī)采樣一至性實(shí)現(xiàn)擬合橢圓
這篇文章主要為大家詳細(xì)介紹了Python如何基于隨機(jī)采樣一至性實(shí)現(xiàn)擬合橢圓,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的可以了解一下2022-11-11python 使用Tensorflow訓(xùn)練BP神經(jīng)網(wǎng)絡(luò)實(shí)現(xiàn)鳶尾花分類(lèi)
這篇文章主要介紹了python 使用Tensorflow訓(xùn)練BP神經(jīng)網(wǎng)絡(luò)實(shí)現(xiàn)鳶尾花分類(lèi),幫助大家更好的利用python進(jìn)行深度學(xué)習(xí),感興趣的朋友可以了解下2021-05-05最新評(píng)論