2016-09-22 15 views
0

SSH経由でリモートSQLデータベースに接続しています。 Linuxのコマンドライン(ssh-add my_private_key.keyを使用してからssh [email protected]を使用)からSSH接続をセットアップすると、接続に1秒未満しかかかりません。しかし、もし私がsshtunnel(以下のスクリプトで)を使ってPythonから実行すると、約70秒かかります。私は、Pythonを使用することはオーバーヘッドのビットかもしれないが、それほど多くはないことを認めます!特に、コマンドラインから接続したの後にPythonスクリプトを実行すると、非常に高速です。速くするためにスクリプトに追加する必要があるのは何ですか?PythonからのSSHトンネルの接続が遅すぎる

Pythonスクリプト:

import pymysql, shlex, shutil, subprocess 
import logging 
import sshtunnel 
from sshtunnel import SSHTunnelForwarder 
import iot_config as cfg 

def OpenRemoteDB(): 
    global remotecur, remotedb 
    sshtunnel.DEFAULT_LOGLEVEL = logging.DEBUG 
    with SSHTunnelForwarder(
      (cfg.sshconn['host'], cfg.sshconn['port']), 
      ssh_username = cfg.sshconn['user'], 
      ssh_private_key = cfg.sshconn['private_key_loc'], 
      ssh_private_key_password = cfg.sshconn['private_key_passwd'], 
      remote_bind_address = ('127.0.0.1', 3306)) as server: 
     print("OK") 

# Main program starts here 
OpenRemoteDB() 

Pythonの出力:

2016-09-20 12:34:15,272 | WARNING | Could not read SSH configuration file: ~/.ssh/config 
2016-09-20 12:34:15,305 | INFO | 0 keys loaded from agent 
2016-09-20 12:34:15,332 | DEBUG | Private key file (/etc/ssh/my_private_key.key, <class 'paramiko.rsakey.RSAKey'>) successfully loaded 
2016-09-20 12:34:15,364 | INFO | Connecting to gateway: mysite.co.uk:22 as user 'user' 
2016-09-20 12:34:15,389 | DEBUG | Concurrent connections allowed: True 
2016-09-20 12:34:15,409 | DEBUG | Trying to log in with key: b'XXX' 
2016-09-20 12:35:26,610 | INFO | Opening tunnel: 0.0.0.0:34504 <> 127.0.0.1:3306 

答えて

0

いやはや!この質問を投稿した後、私はsshtunnelが最新のものであることを確認することをお勧めします。そうではありませんでした。だから、私は0.0.8.1から最新バージョン(0.1.0)に更新して、私の問題は解決しました!

関連する問題