- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我编写了一个系统,可以自动在 Microsoft Azure 上部署 VM,在上面安装 Sql Server,然后针对新安装的服务器执行 .sql
脚本以初始化环境。周五,这一切都按预期进行。今天,我遇到了这个错误。
我的代码具有以下相关导入:
import(
"database/sql"
_ "github.com/denisenkom/go-mssqldb"
)
并使用以下代码在安装后实际连接到数据库(为简洁起见删除了错误处理):
// variables
connectionString := "sqlserver://MasterUser:MasterPassword@xx.xx.xx.xxx:1433"
dbName := "mssql"
dbFile := "mssql.sql"
// open database / get metadata sorted
db, err := sql.Open(dbname, connectionString)
defer db.Close()
//Check to see if the connection is successful.
err = db.Ping() // <--------
// file input
fileBytes, err := ioutil.ReadFile("../sql/" + dbsql)
fileReader := bytes.NewReader(fileBytes)
// parse line-by-line
scanner := bufio.NewScanner(fileReader)
lineNo := 0
for scanner.Scan() {
toExec := scanner.Text()
lineNo += 1
_, err = db.Exec(toExec) // <--------
}
错误发生在 db.Ping()
和每个 db.Exec()
上。在这些情况下,与 err
关联的消息是
TLS Handshake failed: Cannot read handshake packet: EOF
至于服务器本身,我使用以下脚本通过 SSH 安装它:
# install mssql server
sudo wget -qO- https://packages.microsoft.com/keys/microsoft.asc | sudo apt-key add -
sudo add-apt-repository "$(wget -qO- https://packages.microsoft.com/config/ubuntu/16.04/mssql-server-2017.list)"
curl https://packages.microsoft.com/config/ubuntu/16.04/prod.list | sudo tee /etc/apt/sources.list.d/msprod.list
sudo apt-get -y update
sudo apt-get -y install mssql-server
# configure MSSQL
sudo /opt/mssql/bin/mssql-conf setup
# install local tools
sudo ACCEPT_EULA=y apt-get -y install mssql-tools
# do basic initialization in advance of .sql script
/opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P ${MasterPassword} -Q "CREATE LOGIN ${MasterUser} WITH PASSWORD = '${MasterPassword}';"
/opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P ${MasterPassword} -Q "CREATE USER ${MasterUser} FOR LOGIN ${MasterUser};"
/opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P ${MasterPassword} -Q "ALTER SERVER ROLE sysadmin ADD MEMBER ${MasterUser};"
否则这似乎工作正常 - 我通过 SSH 手动连接到实例没有问题,并且该脚本退出时没有错误。我不确定它有多相关。
我尝试自己通过 SSH 连接到服务器并在本地打开一个 sql server 控制台,这导致了以下错误消息:
$ /opt/mssql-tools/bin/sqlcmd -S localhost -U SA -P *********
Sqlcmd: Error: Microsoft ODBC Driver 17 for SQL Server : TCP Provider: Error code 0x2746.
Sqlcmd: Error: Microsoft ODBC Driver 17 for SQL Server : Client unable to establish connection.
这可能是相关的,但我不知道如何。
这是什么原因造成的,我该如何解决?错误是在我的代码中,在我创建的充当服务器的 VM 上,还是介于两者之间?我该如何最好地解决问题?
最佳答案
我最终在没有找出根本原因的情况下解决了这个问题。当我尝试通过 SSH 连接到 VM 并在本地访问数据库时,我遇到了以下错误:
Sqlcmd: Error: Microsoft ODBC Driver 17 for SQL Server : TCP Provider: Error code 0x2746.
Sqlcmd: Error: Microsoft ODBC Driver 17 for SQL Server : Client unable to establish connection.
跟进这些让我找到了 this GitHub issue ,它解决了我的问题。它看起来是一个版本控制问题 - 在我的安装脚本中,我替换了
sudo apt-get -y install mssql-server
与
sudo apt-get -y install mssql-server=14.0.3192.2-2
然后问题就解决了。
关于sql-server - Golang 连接到 SQL Server 错误 - "TLS Handshake failed: Cannot read handshake packet: EOF",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57363561/
我正在开发一个 voip 调用应用程序。我需要做的是在接到来电时将 Activity 带到前台。我在应用程序中使用 Twilio,并在收到推送消息时开始调用。 问题是我试图在接到任何电话时显示 Act
我是一名优秀的程序员,十分优秀!