質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.44%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

2回答

523閲覧

AWSのECサーバを踏み台にして、pythonを使ってRDSにSSHでアクセスしたい

yamamotoyamada

総合スコア11

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2023/04/27 08:00

pythonのsshtunnelを使用して、ECサーバ経由でRDS上にあるmysqlのDBからデータをselectしたいのですが、mysqlにログイン出来ません。
teratarmからsshでECサーバにログインし、コマンドラインでRDS上のmysqlDBにアクセスすることは出来ています。

with SSHTunnelForwarder( ("EC2インスタンスのパブリックIPアドレス",22), ssh_username="ec2-user", ssh_pkey="秘密鍵のフルパス", remote_bind_address=("RDSのエンドポイント",3306) ) as server: dbname = mysql.connector.connect( host="RDSのエンドポイント", db="データベースの名前", user="mysqlのログインユーザ名", password="mysqlのログインパスワード" ) conn = dbname.cursor()

_mysql_connector.MySQLInterfaceError: Can't connect to MySQL server on~というエラーが出てきます。

よろしくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

なにか参考にしたものはあるのでしょうか?

PythonのSSH Tunnelは使ったことがないですが、ひとまず踏み台を経由してローカルのポートをRDSのポートに繋ぐところまでは良さそうに見えます。

問題なのはMySQLへ接続しに行くところです。
そこでRDSのエンドポイントを指定してしまったら、せっかくローカルのポートをRDSのポートに転送しているのに、そこを見ずにRDSに直接つなぎに行ってしまうため意味がありません。
そうではなく、SSH TunnelでRDSにつないだローカルのポートに対して接続してください。
具体的にはmysql.connector.connectのところのhostをRDSのエンドポイントではなくlocalhostまたは127.0.0.1にすると恐らくうまくいくでしょう。

以下ではこの質問でやろうとしていることと同じことをやろうとしているので参考にしてみてください。
sshtunnel を使って踏み台サーバー経由でDB接続

投稿2023/04/27 11:47

yu_1985

総合スコア7506

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

完全なる解決。あなたが神か。

投稿2023/05/01 02:31

yamamotoyamada

総合スコア11

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.44%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問