一次MySQL启动导致的事故实战记录
16lz
2021-12-09
背景
MySQL 启动时会进行 第一次 初始化数据库, 等待 MySQL 完全启动后, 再进行 第二次 初始化数据库.
第一次 初始化数据库使用 --skip-networking (这个选项表示禁止 MySQL 的 TCP/IP 连接方式) 启动 MySQL 进行初始化,
初始化完成后会关闭 --skip-networking 选项重新启动 MySQL.
第二次 初始化数据库会设置 root 密码.
判断 MySQL 已完全启动的方式
尝试主动连接 MySQL, 连接成功则表明服务已完全启动
mysql -hlocalhost -P3306 -uroot
所以没等 第一次 初始化数据库完成可能就已经进行了 第二次 初始化数据库,
而 第二次 初始化数据库提前于 第一次 初始化数据库设置 root 密码, 导致 第一次 初始化连不上数据库而失败,
最后没有开启 TCP/IP 连接方式, 应用无法连接数据库.
第一次修改
使用 -h127.0.0.1 进行连接数据库
mysql -h127.0.01 -P3306 -uroot
第二次修改
wait-for-it.sh 127.0.0.1:3306 --timeout=300mysql -hlocalhost -P3306 -uroot
然后再使用 localhost 去尝试连接数据库.
原文链接: k8scat.com/posts/wait-…
总结
更多相关文章
- MySQL系列多表连接查询92及99语法示例详解教程
- Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
- MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
- android从服务器下载文件(php+apache+win7+MySql)
- 【有图】android通过jdbc连接mysql(附文件)
- android 通过php 连接 mysql
- android通过php连接mysql数据库!!!!
- 关于Android连接远程数据库(mysql、oracle)
- 图书馆座位管理系统(android,java后台,mysql)