新问题:我可以在Google上找到的所有内容都表明CloudSQL连接器应该可以正常工作,但源代码本身除外(并且导入SDK的cloudsql无法正常工作)。如果存在此更新的库,是否可以在某些地方找到它?

---编辑:我的回答是:看来问题出在CloudSQL本身,而不是驱动程序或类似的东西。

我正在尝试从Google App Engine Go程序访问CloudSQL。
我已经使用Go 1.2.1和Go 1.4.2尝试了go-sql-driver/mysql和ziutek/mymysql。我已经尝试了go-sql-driver的go get版本,并直接从Github克隆了它。我已经尝试了App Engine安装程序和存档。

每次我尝试使用应用程序访问数据库时,结果页面都会显示:
cloudsql:开发人员尚不支持

我在这里看到了另一个类似的问题,尝试了这里提到的所有内容,但没有一个起作用。

有问题的代码:

    import (
    _ "github.com/go-sql-driver/mysql"
    _ "appengine/cloudsql"
    "database/sql"
    "net/http"
)

func adminLogin(w http.ResponseWriter, r *http.Request) {
    username := formatter(r.FormValue("username"))
    password := formatter(r.FormValue("password"))
    db, err := sql.Open("mysql",
        "root:password@cloudsql(ws-virtual-classroom:database)/logins") // And all the variations on that string I could think of...
    defer db.Close()
    if err != nil {
        log.Print(err)
    } else {
        rows, err := db.Query("SELECT username FROM admin_logins WHERE username=? AND password=? LIMIT 1", username, password)
        defer rows.Close()
        if err != nil {
            log.Print(err)
        } else {
            var user string
            for rows.Next() {
                err = rows.Scan(&user)
                if err != nil {
                    log.Print(err)
                } else {
                    makeCookie(w, r, user, true, true)
                }
            }
        }
    }
    teachersHome(w, r)
}

结果(提交登录表单后,该结果显示在我的浏览器中):
the runtime process gave a bad HTTP response: ''

2015/05/17 01:53:06 cloudsql: not supported in dev yet
2015/05/17 01:53:06 http: panic serving 127.0.0.1:56970: runtime error: invalid memory address or nil pointer dereference
goroutine 12 [running]:
net/http.func·011()
    /tmp/appengine/go_appengine/goroot/src/net/http/server.go:1130 +0xbb
database/sql.(*Rows).Close(0x0, 0x0, 0x0)
    /tmp/appengine/go_appengine/goroot/src/database/sql/sql.go:1659 +0x31
main57750.adminLogin(0x7f76a72ef5d8, 0xc208045860, 0xc2080c4820)
    main.go:208 +0x25a
net/http.HandlerFunc.ServeHTTP(0x927c78, 0x7f76a72ef5d8, 0xc208045860, 0xc2080c4820)
    /tmp/appengine/go_appengine/goroot/src/net/http/server.go:1265 +0x41
github.com/gorilla/mux.(*Router).ServeHTTP(0xc20800c730, 0x7f76a72ef5d8, 0xc208045860, 0xc2080c4820)
    /home/daniel/go/src/github.com/gorilla/mux/mux.go:98 +0x297
net/http.(*ServeMux).ServeHTTP(0xc20803a6f0, 0x7f76a72ef5d8, 0xc208045860, 0xc2080c4820)
    /tmp/appengine/go_appengine/goroot/src/net/http/server.go:1541 +0x17d
appengine_internal.handleFilteredHTTP(0x7f76a72ef5d8, 0xc208045860, 0xc2080c4820)
    /tmp/appengine/go_appengine/goroot/src/appengine_internal/api_dev.go:98 +0x413
net/http.HandlerFunc.ServeHTTP(0x927248, 0x7f76a72ef5d8, 0xc208045860, 0xc2080c4820)
    /tmp/appengine/go_appengine/goroot/src/net/http/server.go:1265 +0x41
net/http.serverHandler.ServeHTTP(0xc208042540, 0x7f76a72ef5d8, 0xc208045860, 0xc2080c4820)
    /tmp/appengine/go_appengine/goroot/src/net/http/server.go:1703 +0x19a
net/http.(*conn).serve(0xc2080457c0)
    /tmp/appengine/go_appengine/goroot/src/net/http/server.go:1204 +0xb57
created by net/http.(*Server).Serve
    /tmp/appengine/go_appengine/goroot/src/net/http/server.go:1751 +0x35e

这是在通过goapp serve运行它时。如果我部署它,我似乎会遇到同样的问题-结果页面为空白而不是显示该文本,但是日志错误消息是相同的。

最佳答案

更新的库在这里:https://godoc.org/google.golang.org/appengine。它没有CloudSQL。也许您应该只在本地使用常规的mysql连接:

func dialSQL() (*sql.DB, error) {
    if appengine.IsDevAppServer() {
        // or sql.Open("mysql", "user-name:password@ip-address-of-google-cloud-sql-instance/dbname")
        return sql.Open("mysql", "user:password@/dbname")
    }
    return sql.Open("mysql", "cloudsql:my-instance*dbname/user/passwd")
}

通常,使用本地数据库是最佳选择,因为连接到 Activity 数据库可能非常危险。例如,很容易意外地对生产数据库运行测试并删除所有内容。

不过,Google在此处提供了有关连接CloudSQL的说明:https://cloud.google.com/sql/docs/introduction。第三者工具的说明也适用于Go。

10-04 11:19