fabric-ca-server连接到Azure mysql:不支持此身份验证插件

时间:2019-08-07 21:38:21

标签: mysql azure hyperledger-fabric hyperledger-fabric-ca

我很困惑为什么我无法使用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

我尝试了以下版本,结果相同

  • 1.4.0
  • 1.4.1
  • 1.4.2

具有以下参数:

  • <无>
  • ?parseTime = true
  • ?parseTime = true&allowNativePasswords = true

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

有人有没有遇到过这个问题,或者知道发生了什么事?

1 个答案:

答案 0 :(得分:1)

不幸的是,看来我们仍在使用非常旧的mysql驱动程序版本,它根本不支持身份验证插件。我假设您的示例代码提取了较新版本的驱动程序。