1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Go+GAE+外部MySQLで躓いたはなし

Last updated at Posted at 2018-11-28

GAE上でGOを動かして、そこから外部のMySQLに接続するのに躓いたのでメモをしておきます。
どうやら、GAEからはSocketAPIなるものを使わないと外部には接続できないようです。
ローカルで動作しましたが、GAEにアップするとヌルポがでるので、最初はわかりませんでした。
解決コードはあっさりしてます。
importは省いています。

サンプル

sample.go(抜粋)
dsn :=  con.User + ":" + con.Password + "@external(" + con.Address + ":" + strconv.Itoa(con.Port) + ")/" + con.Name
dial := func(addr string) (net.Conn, error) {
  return socket.Dial(appengine.NewContext(r), "tcp", addr)
}
mysql.RegisterDial("external", dial)
db, err := sql.Open("mysql",dsn)

externalという名前のDialを作成し、mysqlに登録するだけです。
DSNではいつもは、@tcpとなるところが登録名@externalになるだけです。

Go+GAEではvendor関係とかつまづきまくっていますが、総じてGo言語の生産性と実行速度は十分に満足がいくものです。

###追加
Go1.11でなんとかなるかもしれないので、今度試してみます
https://github.com/gcpug/nouhau/tree/feature/id/76/app-engine/note/gaego19-migration-gaego111

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?