来自Google CloudSQL的糟糕HTTP响应



我正在尝试使用go-sql-driver使用Google Cloud SQL。我被困在这里,我不知道这里出了什么问题。这个错误对我来说是完全未知的。

package hello
import (
  "fmt"
  "net/http"
  "database/sql"
  _ "github.com/go-sql-driver/mysql"
)
func init() {
  http.HandleFunc("/", handler)
}
func handler(w http.ResponseWriter, r *http.Request) {
  const dbUserName = "userName"
  const dbPassword = "password"
  const dbIP = "123.123.231.123"
  db, err := sql.Open("mysql",  dbUserName+":"+dbPassword+"@"+dbIP+":3306/user")

  if err != nil {
    panic(err.Error()) 
  }

  // Query the name 
  rows, err := db.Query("SELECT * FROM user")
  if err != nil {
    panic(err.Error()) 
  }
  fmt.Println(rows)
  defer db.Close()
}

错误:

 the runtime process gave a bad HTTP response: ''
 2015/04/12 09:23:36 http: panic serving 127.0.0.1:50091: Default addr  for network '173.194.106.126:3306' unknown
 goroutine 6 [running]:
 net/http.func·011()
 /private/var/folders/00/0v42r000h01000cxqpysvccm003chb/T/appengine/go_appengine/goroot/src/net/http/server.go:1130 +0xbb
 main37089.handler(0x5ad1e0, 0xc208044280, 0xc2080331e0)

任何想法。查看go-sql驱动程序源的源代码,也许我应该设置一个默认地址?

我认为

您的错误与SQL驱动程序无关。如果您阅读消息,它是由 http 包服务器代码引起的,而不是与您的 SQL 连接/读取/写入等相关的任何内容。查看您的代码并将其与基本示例进行比较,我相当确定您的错误是由于 main 中缺少这一行; http.ListenAndServe(":8080", nil)

基本上,将您的主要更改为

func main() {
    http.HandleFunc("/", handler)
    http.ListenAndServe(":8080", nil)
}

这个错误可能会消失。免責聲明;这并不意味着你的程序会神奇地工作,只是没有它它就永远无法工作。

相关内容

  • 没有找到相关文章

最新更新