使用 MySql 遇到的问题
1. Entity Framework Core 连接 MySql
连接数据库出现以下错误:
System.InvalidOperationException: An exception has been raised that is likely due to a transient failure. Consider enabling transient error resiliency by adding 'EnableRetryOnFailure()' to the 'UseMySql' call.
版本问题,使用自动检测版本方法
var connectionString = configuration.GetConnectionString(connectStr); services.AddDbContext<T>(options => { options.UseMySql(connectionString, ServerVersion.AutoDetect(connectionString)); });
2. 认证问题
MySql 8.0 默认使用 caching_sha2_password 插件认证,解决方法:
. https://mysqlconnector.net/troubleshooting/retrieval-public-key/#:~:text=To%20retrieve%20the%20server%E2%80%99s%20public%20key%2C%20connect%20securely,to%20the%20connection%20string%3B%20this%20is%20potentially%20insecure.
. 修改认证
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'Your New Password'; FLUSH PRIVILEGES;
4. 无法远程连接
可能的原因:
- 设置对应用户的 Host 为 %
- MySql 配置中注释掉 bind-address = 127.0.0.1
重启 MySql 服务
自律 平静 思考 实践
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
2022-03-12 ASP.NET Core 简单集成签发 JWT (JSON Web Tokens)