我很困惑为什么我无法使用azure的MySql数据库启动fabric-ca-server,我不断得到this authentication plugin is not supported
在简单的go脚本中使用完全相同的连接字符串即可:
db, err := sql.Open("mysql", sqlConnString)
if err != nil {
return "", err
}
defer db.Close()
rows, err := db.Query(sqlString)
if err != nil {
return "", err
}
columns, err := rows.Columns()
...
但是通过以下方式启动fabric-ca-server
:fabric-ca-server start --db.datasource="user@server:pw@tcp(server.mysql.database.azure.com:3306)/fabricca?parseTime=true&allowNativePasswords=true" --db.type=mysql -b admin:admin
导致错误:
2019/08/07 23:39:35 [DEBUG] Initializing DB
2019/08/07 23:39:35 [DEBUG] Initializing 'mysql' database at '****:****@tcp(server.mysql.database.azure.com:3306)/fabricca?parseTime=true'
2019/08/07 23:39:35 [DEBUG] Using MySQL database, connecting to database...
2019/08/07 23:39:35 [DEBUG] Database Name: fabricca
2019/08/07 23:39:35 [DEBUG] Connecting to MySQL server, using connection string: ****:****@tcp(server.mysql.database.azure.com:3306)/?parseTime=true
2019/08/07 23:39:35 [ERROR] Error occurred initializing database: Failed to connect to MySQL database: this authentication plugin is not supported
我尝试了以下版本,结果相同
具有以下参数:
mysql服务器的版本是5.7
我尝试过先创建数据库,然后在没有现有数据库的情况下开始
我曾尝试与一个管理员用户(该用户具有所选数据库的所有授权)
我尝试用不同的密码插件创建用户(在Azure 5.7上默认为mysql_native_password)
但是错误不断出现。 连接字符串似乎没有任何问题,因为我可以在其他go脚本中使用它而没有任何问题。
尝试使用tls和不使用tls。我可以看到的唯一区别是:https://github.com/hyperledger/fabric-ca/blob/477f5a2e8200232a50a3751976f6fa3d3f9062c9/lib/server/db/mysql/mysql.go#L66
有人有没有遇到过这个问题,或者知道发生了什么事?
答案 0 :(得分:1)
不幸的是,看来我们仍在使用非常旧的mysql驱动程序版本,它根本不支持身份验证插件。我假设您的示例代码提取了较新版本的驱动程序。