位置: 编程技术 - 正文

MySQL使用的常见问题解决与应用技巧汇总(mysql使用技巧)

编辑:rootadmin

推荐整理分享MySQL使用的常见问题解决与应用技巧汇总(mysql使用技巧),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql主要用途,mysql的使用场景,mysql中常用的语句,mysql 常用,mysql 常用,mysql中常用的语句,mysql的基本使用,mysql中常用的语句,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

在MySQL日常开发或者是维护中,有一些问题或是故障往往是难以避免的,如丢失密码、表损坏。在此总结一下常见的问题,以备今后所需。

一、 忘记 MySQL 的 root 密码

1. 登录到数据库所在的服务器,手工 kill 掉 mysql 进程。

(1) 登录到数据库所在的服务器,手工 kill 掉 MySQL 进程:

其中,mysql.pid 指的是 MySQL 数据目录下的 pid 文件,它记录了 MySQL 服务的进程号。

(2) 使用 --skip-grant-tables 选项重启 MySQL 服务:

--skip-grant-tables 选项意思是启动 MySQL 服务时跳过权限表认证。启动后,连接到 MySQL 的 root 将不需要口令。

(3) 用空密码的 root 用户连接到 mysql ,并且更改 root 口令:

由于使用了 --skip-grant-tables 选项启动,使用 “set password” 命令更改密码失败,直接更新 user 表的 authentication_string(测试版本为5.7.,有的版本密码字段是 ‘password') 字段后,更改密码成功。刷新权限表,使权限认证重新生效。重新用 root 登录时,就可以使用刚刚修改后的口令了。

二、如何处理 myisam 存储引擎的表损坏

有的时候可能会遇到 myisam 表损坏的情况。一张损坏的表的症状通常是查询意外中断,并且能看到下述错误:

'table_name.frm' 被锁定不能更改 不能找到文件 'tbl_name.MYYI' (errcode:nnn) 文件意外结束 记录文件被毁坏 从表处理器得到错误 nnn。

通常有以下两种解决方法:

1. 使用 myisamchk 工具

使用 MySQL 自带的 myisamchk 工具进行修复:

其中 -r 参数的含义是 recover,上面的方法几乎能解决所有问题,如果不行,则使用命令:

其中 -o 参数的含义是 --safe-recover,可以进行更安全的修复。

2. 使用 sql 命令

使用 MySQL 的 check table 和 repair table 命令一起进行修复,check table 用来检查表是否有损坏;repair table 用来对坏表进行修复。

三、 数据目录磁盘空间不足的问题

系统上线后,随着数据量的不断增加,会发现数据目录下的可用空间越来越小,从而给应用造成了安全隐患。

1. 对于 myisam 存储引擎的表

对于 myisam 存储引擎的表,在建表时可以用如下选项分别制定数据目录和索引目录存储到不同的磁盘空间,而默认会同时放在数据目录下:

如果表已经创建,只能先停机或者将表锁定,防止表的更改,然后将表的数据文件和索引文件 mv 到磁盘充足的分区上,然后在原文件处创建符号链接即可。

MySQL使用的常见问题解决与应用技巧汇总(mysql使用技巧)

2. 对于 innodb 存储引擎的表

因为数据文件和索引文件是存放在一起的,所以无法将它们分离。当磁盘空间出现不足时,可以增加一个新的数据文件,这个文件放在充足空间的磁盘上。

具体实现方法是在参数 innodb_data_file_path 中增加此文件,路径写为新磁盘的绝对路径。

例如,如果 /home 下空间不足,希望在 /home1 下新增加一个可自动扩充数据的文件,那么参数可以这么写:

参数修改后,必须重启数据库才可以生效。

四、DNS反向解析的问题 (5.0 以后的版本默认跳过域名逆向解析)

在客户端执行 show processlist 命令,有时会出现很多进程,类似于:

这些进程会累计的越来越多,并且不会消失,应用无法正常相应,导致系统瘫痪。

MySQL 在默认情况下对于远程连接过来的 IP 地址会进行域名的逆向解析,如果系统的 hosts 文件中没有与之对应的域名,MySQL 就会将此连接认为是无效用户,所以下进程中出现 unauthenticated user 并导致进程阻塞。

解决的方法很简单,在启动时加上 --skip-name-resolve 选项,则 MySQL 就可以跳过域名解析过程,避免上述问题。

五、mysql.sock 丢失后如何连接数据库

在 MySQL 服务器本机上连接数据库时,经常会出现 mysql.sock 不存在,导致无法连接的问题。这是因为如果指定 localhost 作为一个主机名,则 mysqladmin 默认使用 Unix 套接字文件连接,而不是 tcp/ip。而这个套接字文件(一般命名为 mysql.sock)经常会因为各种原因而被删除。通过 --protocol=TCP|SOCKET|PIPE|MEMORY 选项,用户可以显式地指定连接协议,下面演示使用了 Unix 套接字失败后使用 tcp 协议连接成功的例子。

1. Unix 套接字连接:

2. tcp 连接

六、MyISAM表过大,无法访问问题

首先我们可以通过myisamchk命令来查看MyISAM表的情况。如下图,我查看admin表

datefile length代表当前文件大小 keyfile length代表索引文件大小 max datefile length 最大文件大小 max keyfile length 最大索引大小

可以通过如下命令来进行扩展数据文件大小

七、数据目录磁盘空间不足的问题

针对MyISAM存储引擎

可以将数据目录和索引目录存储到不同的磁盘空间。

针对InnoDB存储引擎

对于InnoDB存储引擎的表,因为数据文件和索引文件时存放在一起的。所以无法将他们分离。当磁盘空间出现不足时候,可以增加一个新的数据文件,这个文件放在有充足空间的磁盘上。具体实现是通过InnoDB_data_file_path中增加此文件。

参数修改之后,需要重启服务器,才可以生效。

八、同一台主机上安装多个Mysql

除了每个Mysql安装目录不能相同外,还需要的是port和socket不能一样。

mysql.sock就是客户端连接与mysql间通信用的。socket文件,只能本机使用,远程连接要通过tcp/ip了。

总结

标签: mysql使用技巧

本文链接地址:https://www.jiuchutong.com/biancheng/312286.html 转载请保留说明!

上一篇:MySQL中索引与视图的用法与区别详解(mysql各种索引的使用场景)

下一篇:数据库管理中19个MySQL优化方法(数据库管理中负责数据模式定义的数据库语言是)

  • 劳务公司在异地做项目需要提供当地完税证明
  • 本年利润期末有无余额
  • 小规模纳税人缴纳增值税怎么算
  • 跨年的预收账款怎么记账
  • 企业购进材料入什么账户
  • 个人捐款合法吗
  • 个税两种申报方式哪种好
  • 财务担保费计入什么科目
  • 会计凭证前面放什么
  • 房地产开发企业预收款预缴增值税
  • 母公司投资子公司现金流量表抵消
  • 工伤一次性医疗补助金由谁支付
  • 现金股利和股票股利的区别
  • 工伤抚恤金算遗产吗
  • 公司进项销项税差异较大
  • 无运输工具承运业务按何税目缴纳增值税
  • 油罐车运输费用怎么算
  • 马克龙成就
  • 赠送样品需要交税吗
  • 代扣代缴的社保需要计提吗
  • 建筑业进项税额转出
  • 大学期末 知乎
  • 碎片化对应什么
  • 如何安装电脑系统win7电路连接
  • 如何突出显示一行中的最小值
  • 如何使用定向流量
  • 企业网银证书费用收费标准
  • Win10待机唤醒后白屏怎么办
  • PHP:imagesavealpha()的用法_GD库图像处理函数
  • 税法的构成要素中,()是税法最基本的要素
  • 材料委托加工
  • 长期挂账的在建工程如何处理
  • 世界上最早的计算机是
  • 备用金会涨额度吗
  • 堪察加半岛上的汉族人
  • 住宿费电子发票没有章
  • 小迪安全2021
  • umount -l命令
  • 利用php将图片转为文字
  • 增值税报税后多久缴纳期限
  • wordpress图片模板
  • 实发工资总额怎么算
  • 在建工程的前期工程
  • 上传附件不成功怎么回事
  • ajax 教程
  • 厂区道路折旧年限最新规定
  • 进项认证以后如何处理
  • 企业的纳税申报数据来源于
  • 农产品收购发票使用范围
  • 教育费附加和地方教育费附加都要交吗
  • 个体工商户财务怎么做账
  • 办理契税所需要的证件
  • 保证金计算器
  • 库存商品盘盈怎么做账
  • 未确认收入的会计分录
  • 购进材料无发票会计分录
  • 小规模纳税人租赁发票税率是多少
  • 营业外收入的账户结构
  • 车辆购置税是怎么计算的
  • 商业医疗保险的缺点
  • 什么是长期股权投资
  • 存货周转率 高
  • 非营利医疗机构是什么单位
  • select语句中的select*说明
  • AppleMobileDeviceService.exe是什么进程?AppleMobileDeviceService.exe是病毒吗?
  • 更新最新版win11,任务栏不见了
  • win7硬盘设置在哪里设置
  • centos 安装教程
  • win8系统升级到win10东西还在吗
  • win10鼠标指针在文本区很小
  • OS X 10.12.6 beta 1如何更新 OS X 10.12.6 beta 1如何升级
  • win8 蓝牙
  • win8系统笔记本忘记开机密码怎么办
  • centos安装命令yum
  • excel2016默认字体
  • unity游戏之羊刀与Pendragon复盘:DotA做对了什么
  • 只用html和css
  • async/await与promise(nodejs中的异步操作问题)
  • jquery怎么写轮播图
  • 咨询服务类公司的账务处理
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设