- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个非常大的表,包含大约 1M 条记录。由于性能不佳,我优化了查询并需要更改索引。
我使用ALTER
更改了它,现在我真的不确定这在InnoDB中是如何工作的。我需要重启MySQL服务器吗?如果我需要重新启动MySQL服务器,如何保持表之间的数据完整性(这样我就不会错过内存中但未写入数据库的数据)?
我Google了一下,发现在MySQL重启的情况下,我需要使用全局变量innodb_fast_shutdown
——设置它会做什么,如果不设置会怎么样?不是很清楚。
我是 MySQL 领域的 InnoDB 新手。非常感谢任何帮助。
最佳答案
So changed it using
ALTER
, now i am really not sure about how this works in innodb?
您是说您使用 ALTER TABLE ... ADD INDEX ...
(或 ADD KEY
)添加了索引 - 它们是询问确切的索引的两种方式同样的事情)大概?
一旦 ALTER TABLE
完成执行并且 mysql>
提示符返回,则无需执行任何其他操作。此时,表就有了新的索引,并且索引已完全填充。
大功告成,无需重新启动服务器。
既然你提到了这一点,我也会尽力帮助你澄清对 innodb_fast_shutdown
以及 InnoDB 中内存/磁盘划分的误解。
当 MySQL 服务器启动时,InnoDB 会向操作系统一次性请求一 block 大小为 innodb_buffer_pool_size
的内存块,在本例中是来 self 的一台测试服务器的 MySQL 错误日志:
130829 11:27:30 InnoDB: Initializing buffer pool, size = 4.0G
这是 InnoDB 在内存中存储表和索引数据的地方,当该池足够大以容纳所有数据和索引时,性能最佳。读取行时,首先将表空间文件中的页面读入缓冲池,然后从那里提取数据。如果发生更改,更改将写入缓冲池中表数据和索引的内存副本,并最终刷新到磁盘。池中的页面要么是“干净的”——这意味着它们与磁盘上的页面相同,因为它们自加载以来就没有被更改过,或者如果发生更改,则更改已经写入磁盘——要么是“脏的”这意味着它们与磁盘上的内容不匹配。
但是,InnoDB
是 ACID -兼容——如果它只将更改写入内存,并且这些更改没有在内存中的更改发生之前立即保存在某处,那么这不可能是真的...而那个“某处”就是 redo log - 在磁盘上 - 立即存储要在内存中进行的更改,其格式允许此操作比实时更新实际表空间文件本身快得多。
反过来,innodb_fast_shutdown
变量决定 MySQL 是在关闭之前还是在启动备份之后完成写入重做日志的所有内容。无论哪种方式,它都可以正常工作,但如果您需要更快地关闭服务器,那么无论您做了什么更改,让它稍后恢复所有内容都会更快且完全安全。
重要的是,我不知道您读过什么,但在日常操作中,您永远不需要弄乱 innodb_fast_shutdown
的值,除非您正在关闭以准备升级您的系统MySQL 服务器的版本(主要是安全预防措施)。磁盘上的数据始终与内存中的数据一致,因为表空间文件已经与数据的内存表示形式一致,或者> 因为对表空间文件的挂起更改被安全地存储在重做日志中,当服务器重新上线时,它们将被正确处理。
在 ALTER TABLE
的情况下,在 ALTER
之前表的任何待处理内容都已被处理,因为 InnoDB 通常会重建整个表以响应此命令,因此唯一可能的“待处理”更改是 ALTER
之后发生的 DML。
关于MySQL InnoDB 引擎重启,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19749930/
我有一个 UWP 应用程序(在 Windows/Microsoft Store 中发布),我正在进行新的更新,我在我的应用程序中使用了 Template10,它具有深色和浅色主题,并且在 Window
我是 spring batch 的新手,有一些关于暂停/恢复的问题。看了spring batch的文档,好像没有内置的pause或者resume功能。但是,我从主站点找到了这个用例: http://d
我正在编写一个网络服务并有以下观察结果:即使我只是将一个文本文件添加到存储 web 服务引用的所有 dll 的目录 (bin),appdomain 也会刷新。 这会导致存储在字典(在其中一个 dll
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 6 年前。 Improve this qu
Hadoop 1.0.3 工作 36 小时后说: INFO mapred.JobClient: map 42% reduce 0% mapred.JobClient: Job Failed
我使用 AVAssetWriter 将视频录制到文件中。所以我为此创建了类。 link to gist 然后在项目的某处我推送记录并开始录制视频。 func start() { assetWriter
我想要一个在后台运行的 python 脚本(无限循环)。 def main(): # inizialize and start threads [...] try:
我在重新启动 Activity 时感到困惑。我有两个功能可以很好地完成同一任务。请指导我哪个最好,为什么? public void restart() { Intent
重启sidekiq的正确方法是什么。它似乎在我启动它时缓存了我的 worker 代码,所以每次我对我的 worker 进行更改时我都需要重新启动它。我正在使用 Ctrl/C 执行此操作,但该过程需要很
我在我的 Android 模拟器上安装了新字体。说明说我必须重新启动设备。我尝试使用“关机”按钮,但它只显示“正在关机”并且什么也不做。即使我去 adb shell 并运行“重启”它也会挂起。 任何想
启动操作 ? 1
关闭 service nginx stop systemctl stop nginx 启动 service nginx start systemctl start n
正在学习Linux中。。。一边学一边记录着。。所有观点只是个人观点 Linux有个文件 /etc/inittab 复制代码 代码如下:
如果我运行 systemctl restart kubelet它会影响其他正在运行的节点吗?它会停止集群吗?你能预见任何影响吗? 任何帮助,将不胜感激! 最佳答案 在回答之前,小声明:重启不是由于对
嗯,问题是我有一个在 MATE 上完美运行的 Abyssus Razer,但是 在 Debian、Elementary、OpenSUSE 和其他平台上,默认 设置 super 慢。 我用 解决了这个问
我在 Ubuntu 16.04 上安装了 NGINX 并编辑了我的配置。 当我想用 sudo service nginx restart 重新启动时我得到错误: Job for nginx.servi
我已经在我的 Ubuntu 上安装了 Gearman Job Server(又名 Gearmand)1.0.6: Distributor ID: Ubuntu Description: Ubun
我有一个 WiX Burn使用 ManagedBootstrapperApplicationHost 的自定义安装程序。安装必备 Microsoft Windows Installer 之一后4.5
我已经使用 brew install mosquitto 在我的 mac 上安装了蚊子代理. 通常我不会给出任何命令来启动 mosquitto 服务器。当我打开我的 mac 时它会自动启动。 我已经使
我有一个带有 2 个容器的 pod test-1495806908-xn5jn。我想重新启动其中一个名为 container-test 的项目。是否可以重新启动 Pod 中的单个容器以及如何重新启动?
我是一名优秀的程序员,十分优秀!