新问题:我可以在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。