- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章MySQL数据库修复方法(MyISAM/InnoDB)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
在网上找了篇MySQL的技术文章,感觉不错,把它翻译过来共享下。 原文作者:Mike Peters 我整理了7条修复MySQL数据库的方法,当简单的重启对数据库不起作用,或者有表崩溃时。 简单的MySQL重启: /usr/local/mysql/bin/mysqladmin -uUSERNAME -pPASSWORD shutdown /usr/local/mysql/bin/mysqld_safe & 1、MyISAM表崩溃 MySQL数据库允许不同的表使用不同的存储引擎。它用来存储与检索数据。较流行的存储引擎是MyISAM与InnoDB。 MyISAM表最终“将”崩溃。这是个不争的事实。 幸运的是,在多数情况下,MyISAM表崩溃很容易修复。 修复单一表,连接你的数据库执行: repair TABLENAME 修复所有的表,执行: /usr/local/mysql/bin/mysqlcheck --all-databases -uUSERNAME -pPASSWORD -r 多数情况,只有当你浏览日志文件时,才知道MyISAM表崩溃了。 我强烈建议在你的/etc/my.cnf配置文件中添加此行。一旦表崩溃它将进行自动修复。 [mysqld] myisam-recover=backup,force 如果这个也不管用,还有其他的方法可以试试。 2、多实例MySQL 当你重启MySQL后,进程马上死掉,这很常见。 查看日志文件,它会告诉你,另一个MySQL实例可能正在运行。 停止所有MySQL实例: /usr/local/mysql/bin/mysqladmin -uUSERNAME -pPASSWORD shutdown killall mysql killall mysqld 现在重启数据库,将只有一个实例在运行。 3、改变InnoDB日志设置 一旦MySQL数据库有在运行InnoDB引擎,你就一定不能修改/etc/my.cnf文件中如下几行: datadir = /usr/local/mysql/data innodb_data_home_dir = /usr/local/mysql/data innodb_data_file_path = ibdata1:10M:autoextend innodb_log_group_home_dir = /usr/local/mysql/data innodb_log_files_in_group = 2 innodb_log_file_size = 5242880 InnoDB日志文件大小一旦确定就不能修改。如果改变了,数据库将不能启动。 4、MySQL host表丢失 有见过几次这样的情况。可能是一些异想不到的MyISAM bug。 轻松将其修复如下: /usr/local/bin/mysql_install_db 5、不正常的MyISAM自动增长(auto_increment) 如果MyISAM表自增计数变得紊乱,你就不能再插入新的纪录。 通常你可以告诉自增计数器它现在工作不正常,通过将最后一条纪录的自增字段设为-1。 解决问题-找到最后一条自增记录的有效值(执行如下命令) SELECT max(id) from tablename 然后更新此表的自增计数器,如下: ALTER TABLE tablename AUTO_INCREMENT = id+1 6、太多连接数 数据库变得相当繁忙,因为连接数比它能处理的多。而且现在你都不能连接上你的数据库。 首先,停止数据库: /usr/local/mysql/bin/mysqladmin -uUSERNAME -pPASSWORD shutdown 如果上条命令不管用,可以试试 "killall mysql" 和 "killall mysqld" 当数据库停止后,编辑/etc/my.cnf文件,增加连接数。不要痴狂的增加这个数字,否则你会把你的整台机器搞崩。 在一台专用数据库机器上,我们通常用: max_connections = 200 wait_timeout = 100 试着重启数据库看看是否有帮助。 如果你被查询弄的措手不及,需要连接数据库进行表修改操作,那么在/etc/my.cnf文件中设置一个不同的端口号,开启数据库,进行修改操作。然后将端口修改回来(master-port = 3306)再重启。 7、InnoDB表崩溃 InnoDB表是我最钟爱的。事物缓存,可靠,不像MyISAM,InnoDB支持对同一表的并发写。 InnoDB的内部恢复机制也相当不错。如果数据库崩溃,InnoDB将尝试进行修复,通过从最后一个时间戳开始运行日志文件。大多数情况都会成功,整个过程是透明的。 不过,如果InnoDB自行修复失败,那么“整个”数据库将不能启动。MySQL将会发出一个错误信息并退出,你的整个库将处于离线状态。你可以不断尝试重启数据库,但是如果修复进程失败,数据库将拒绝启动。 这就是为什么需要运行master/master当使用InnoDB时——当一个master宕掉时,还有一台冗余master做后备。 在继续操作前,先浏览下MySQL的日志文件,确定数据库不是因为InnoDB表的崩溃而崩溃。 有一种方法是更新InnoDB的日志文件计数器以跳过引起崩溃的查询,但是经验告诉我们这不是个好方法。这种情况下,将造成数据的不一致性而且会经常使主从复制中断。 一旦因InnoDB崩溃造成数据库无法启动,你就应该按如下五个步骤处理问题: 第一:添加此行到/etc/my.cnf文件中: [mysqld] innodb_force_recovery = 4 第二:重启MySQL。你的数据库现在将启动,但是在innodb_force_recovery参数作用下,所有的插入与更新操作将被忽略。 第三:导出所有的表(Dump all tables) 第四:关闭数据库,删除所有的数据文件。运行mysql_install_db 创建默认MySQL表。 第五:从/etc/my.cnf文件中去掉innodb_force_recovery参数,重启数据库。(库现在应该能正常启动) 第六:从备份文件中恢复所有数据。 续: 最近遇到了个让人棘手的任务——修复一个失败的InnoDB数据库。这个数据库因崩溃而无法启动。 第一步将InnoDB在force-recovery模式下开启,此时InnoDB虽开启了但是将忽略所有更新(UPDATEs)与插入(INSERTs)操作。 在/etc/my.cnf文件中添加此行: innodb_force_recovery = 2 现在重启数据库: /usr/local/bin/mysqld_safe & (注意:如果MySQL没有启动,继续增加 innodb_force_recovery 的数值直到将参数值设为8( innodb_force_recovery =) 将所有数据保存到临时文件alldb.sql(下个命令需要花一定时间): mysqldump --force --compress --triggers --routines --create-options -uUSERNAME -pPASSWORD --all-databases > /usr/alldb.sql 再次关闭数据库: mysqladmin -uUSERNAME -pPASSWORD shutdown 删除数据库目录。(注意:我的数据目录在/usr/local/var下。你的设置有可能不同,确保删除的是正确的文件夹。) rm -fdr /usr/local/var 重建数据库文件夹,安装MySQL基础表 mkdir /usr/local/var chown -R mysql:mysql /usr/local/var /usr/local/bin/mysql_install_db chown -R mysql:mysql /usr/local/var 从/etc/my.cnf文件中删除innodb_force_recovery ,重启数据库: /usr/local/bin/mysqld_safe & 导入所有备份文件(下一命令需要花一段时间): mysql -uroot --compress < /usr/alldb.sql 最后,刷新MySQL的权限(因为我们也更新了MySQL的表) /usr/local/bin/mysqladmin -uroot flush-privileges 注意:为了得到最好的结果,添加port=8819(或任何其他随机端口)到/etc/my.cnf文件中在重启MySQL之前,然后将--port=8819添加到mysqldump命令中。这种方法避免了MySQL数据库过于系繁忙当修复进程正在进行时.
最后此篇关于MySQL数据库修复方法(MyISAM/InnoDB)的文章就讲到这里了,如果你想了解更多关于MySQL数据库修复方法(MyISAM/InnoDB)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我将一个 div 设置为 100% 宽度,当以 1024 分辨率查看页面时,宽度应从 100% 变为 1000px,我让它与@media 查询一起正常工作,并且在 FF、safari chrome 上
希望有人能帮助我,我已经被困了几天了。 将我的 Domino 服务器更新到 9.01 Fix 3 后,我在 javascript 控制台上不断收到错误消息: TypeError: this.edito
我们正在使用一个基于RMI的java应用程序。当我们运行应用程序时,即使应用程序处于理想阶段,内存使用量仍然不断增加。我们主要使用Vector和散列图数据结构。如何最大限度地减少java内存使用/修复
概述 Internet Download Manager (IDM)是最流行的 Windows 下载管理器。如果你平时工作中使用过IDM,您会惊叹 IDM 下载文件的速度有多快。IDM
当我打开 brave 浏览器时,会打开一个窗口(如下所示)。它并没有真正干扰浏览器的处理。但令人担忧的是为什么这种情况一直发生...... Error On Opening Brave Browser
这是我今天在求职面试中被问到的一个问题: 看下面的代码: int n=20; for (int i =0; i
我不小心删除了/opt/local/bin/perl5.8.9 ,这似乎是 macports 编译的 perl 的主要二进制文件。 现在我有很多取决于 perl5 的端口,但不想卸载并重新安装所有端口
>>>flip fix (0 :: Int) (\a b -> putStrLn "abc") Output: "abc" 这是使用翻转修复的简化版本。 我在一些 YouTube 视频中看到了这种使用
这个问题已经有答案了: How can I fix 'android.os.NetworkOnMainThreadException'? (64 个回答) 已关闭 3 年前。 我在 Android 应
def main(): cash = float(input("How much money: ")) coins = 0 def changeCounter(n): whil
前一周我遇到了类似的问题,查询需要永远运行。在编写此查询时,我尝试应用从其他查询中学到的一些知识,但执行起来需要很长时间。 运行查询的两个单独部分时,每个部分需要 2 分钟才能完成,这是可以接受的,但
下午,我的 CSS 有问题。第三个下拉菜单放错了,我没有解决办法。 这是我想要的: 之前: http://i53.tinypic.com/2qu85z8.png 之后: http://i51.tiny
更新方法: override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingS
我知道这是一个很多人都遇到过的问题,但我不熟悉 Less 并且是 Bootstrap 的新手,我正在寻找一种全 CSS 解决方案来防止我的导航栏折叠到 768 像素以下:
在我的布局中,我创建了以下 jsfiddle 托管的可调整大小的粘性页脚。但是,在调整大小时它与内容重叠。有没有办法让它在所有浏览器上都能响应? http://jsfiddle.net/9aLc0mg
我想要实现的目标 racer-offset 是为了让用户可以设置图像可以以 px 为单位移动多远。偏移量管理偏移量。 Speed-racer 告诉我们图像在滚动过程中移动的速度。我的问题是它不会停止。
我有一个简单的自动换行函数,它接受一个长字符串作为输入,然后将该字符串分成更小的字符串,并将它们添加到一个数组中,以便稍后输出。现在最后一两个字没有输出。这是主要问题。但是,我还想改进功能。我知道这有
我试图在使用每个 slider 之前禁用“下一步”按钮,我不确定为什么在单击不再是 class="not-clicked"的同一个 slider 时取消禁用该按钮. JSFiddle: (这里看起来有
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 8 年前。 如何让程序输出所有信息? IT
On this page ,在“生活”下有一个带有自动生成的子菜单的菜单。子菜单存在一些问题(它会闪烁并改变大小——如果你滚动它就会看到)。我需要以某种方式覆盖它当前正在读取的 css 并使其统一。
我是一名优秀的程序员,十分优秀!