新问题:我在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运行时。如果我部署它我似乎有同样的问题 - 结果页面是空白而不是显示该文本,但日志错误消息是相同的。
答案 0 :(得分:6)
更新的库位于: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")
}
使用本地数据库通常是最佳选择,因为连接到实时数据库可能非常危险。例如,很容易意外地对生产数据库运行测试并丢弃所有内容。
尽管如此,Google还提供了在此处连接到CloudSQL的说明:https://cloud.google.com/sql/docs/introduction。第三方工具的说明也适用于Go。
答案 1 :(得分:1)
我不认为cloudsql可以做任何事情吗?无论什么lol
,源代码看起来都会返回该错误https://code.google.com/p/appengine-go/source/browse/appengine/cloudsql/cloudsql.go
// Dial connects to the named Cloud SQL instance.
func Dial(instance string) (net.Conn, error) {
return connect(instance)
}
https://code.google.com/p/appengine-go/source/browse/appengine/cloudsql/cloudsql_dev.go
func connect(instance string) (net.Conn, error) {
return nil, errors.New("cloudsql: not supported in dev yet")
}