草庐IT

mysql - 当 MySQL 没有剩余空间时该怎么办?

coder 2023-10-19 原文

出于好奇,假设您有一个巨大的 MySQL 数据库,里面装满了用户信息,现在已经满了。您将如何在同一台服务器和另一台具有更多存储空间的服务器上运行相同的 MySQL 数据库?

最佳答案

如果问题只是存储空间问题,那么最简单的解决方案是将数据库转移到另一个容量更大的系统。

另一种解决方案可能是在同一系统中添加一个磁盘,并且

  • (InnoDB) extend the tablespace到这个驱动器(InnoDB 甚至允许存储 each table in a separate file)
  • (MyIsam) 将一些 *.MYD 和/或 *.MYI 文件移动到此驱动器

  • 上述文件可以移动到不同的硬盘驱动器(它们可能需要从它们的原始位置进行符号链接(symbolic link))。

    但是,真正可广泛扩展的解决方案是数据库集群,例如 MySQL cluster .

    您可能还想关注 this question ,其中这个问题目前正在真实环境中得到解决。

    [编辑] 详细说明:

    以下信息仅在 Linux 服务器上有效。在 Windows 下可能是可能的,但我不知道。无论如何,在大规模环境中在 Windows 上运行 MySQL 数据库可能不是一个好主意。

    这三个选项依赖于相同的原则:
  • 将另一个磁盘装入文件系统
  • 将一些现有的 MySQL 数据文件移动到这个新硬盘,即到新目录,和/或指示 MySQL 在这个新目录中创建新数据文件
  • 如果需要,创建一个指向新位置的符号链接(symbolic link),以欺骗 MySQL 认为文件没有移动

  • 1. Extend the InnoDB tablespace

    InnoDB 引擎允许将表空间分布在许多文件中。要调整的配置选项(在 my.cnf 中)是 innodb_data_file_path .例子:
    innodb_data_file_path=/mnt/hard_disk1/ibdata:50G;/mnt/hard_disk2/ibdata:200G;
    

    ... 指示 MySQL 创建 /mnt/hard_disk1/ibdata1 , 50GB 文件,以及 /mnt/hard_disk2/ibdata2 中的 200GB 文件.

    我个人不喜欢这个功能,因为 MySQL 在第一个文件已满之前不会使用第二个文件,这不允许微调。好的一面是您只需要编辑配置文件并重新启动服务器。而已。

    2.店铺each InnoDb table in a separate file

    innodb_file_per_table 顾名思义,选项指示 MySQL 为每个新表创建一个单独的文件。 “新表”意味着更改设置后不会影响现有表。为了避免这种情况,可以转储、删除和重新创建要从共享表空间“提取”的表。

    这些文件是 [datadir]/[database]/[table].ibd , 其中 [datadir] datadir 定义选项,和 [database]是数据库的名称,[table]是表名。
    这些文件可以像 MyISAM 表一样移动(参见下一个选项)。

    3. 移动 MyISAM 文件

    对于每个 MyISAM 表,MySQL 创建三个名为 [datadir]/[database]/[table].[type] 的文件。 , 其中 [datadir] datadir 定义选项,[database]是数据库的名称,[table]是表名。
    [type]将是 frm对于表描述(结构),MYD对于数据,MYI对于索引。

    现在,关于选项 2. 和 3.,您会注意到所有文件大致位于同一目录中,或者至少共享一个父目录。要将它们实际存储在新硬盘上,有两种选择。

    1) 移动整个数据库:
  • 停止服务器
  • 重命名 database目录到您喜欢的另一个名称,例如 backup
  • 将硬盘挂载为 datadir /databse
  • 移动 backup 的内容进入 datadir /databse
  • 重启服务器

  • MySQL 恢复正常,好像什么也没发生过一样。

    2) 移动单个表:
  • 随心所欲挂载新磁盘
  • 停止服务器
  • 将每个文件单独移动到新硬盘
  • 在其原始位置创建一个符号链接(symbolic link),与原始文件同名
  • 重启服务器

  • MySQL 在幸福的无知中恢复。

    关于mysql - 当 MySQL 没有剩余空间时该怎么办?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11069422/

    有关mysql - 当 MySQL 没有剩余空间时该怎么办?的更多相关文章

    1. ruby - 难道Lua没有和Ruby的method_missing相媲美的东西吗? - 2

      我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/

    2. ruby-on-rails - rails 目前在重启后没有安装 - 2

      我有一个奇怪的问题:我在rvm上安装了ruby​​onrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(

    3. ruby - 在没有 sass 引擎的情况下使用 sass 颜色函数 - 2

      我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re

    4. ruby - Ruby 中的隐式返回值是怎么回事? - 2

      所以我开始关注ruby​​,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出

    5. ruby - 怎么来的(a_method || :other) returns :other only when assigning to a var called a_method? - 2

      给定以下方法:defsome_method:valueend以下语句按我的预期工作:some_method||:other#=>:valuex=some_method||:other#=>:value但是下面语句的行为让我感到困惑:some_method=some_method||:other#=>:other它按预期创建了一个名为some_method的局部变量,随后对some_method的调用返回该局部变量的值。但为什么它分配:other而不是:value呢?我知道这可能不是一件明智的事情,并且可以看出它可能有多么模棱两可,但我认为应该在考虑作业之前评估作业的右侧...我已经在R

    6. ruby-on-rails - 我该怎么办 :remote location validation with CarrierWave? - 2

      我在我的Rails3示例应用程序上使用CarrierWave。我想验证远程位置上传,因此当用户提交无效URL(空白或非图像)时,我不会收到标准错误异常:CarrierWave::DownloadErrorinImageController#createtryingtodownloadafilewhichisnotservedoverHTTP这是我的模型:classPaintingtrue,:length=>{:minimum=>5,:maximum=>100}validates:image,:presence=>trueend这是我的Controller:classPaintingsC

    7. 没有类的 Ruby 方法? - 2

      大家好!我想知道Ruby中未使用语法ClassName.method_name调用的方法是如何工作的。我头脑中的一些是puts、print、gets、chomp。可以在不使用点运算符的情况下调用这些方法。为什么是这样?他们来自哪里?我怎样才能看到这些方法的完整列表? 最佳答案 Kernel中的所有方法都可用于Object类的所有对象或从Object派生的任何类。您可以使用Kernel.instance_methods列出它们。 关于没有类的Ruby方法?,我们在StackOverflow

    8. ruby-on-rails - Rails 3,嵌套资源,没有路由匹配 [PUT] - 2

      我真的为这个而疯狂。我一直在搜索答案并尝试我找到的所有内容,包括相关问题和stackoverflow上的答案,但仍然无法正常工作。我正在使用嵌套资源,但无法使表单正常工作。我总是遇到错误,例如没有路线匹配[PUT]"/galleries/1/photos"表格在这里:/galleries/1/photos/1/edit路线.rbresources:galleriesdoresources:photosendresources:galleriesresources:photos照片Controller.rbdefnew@gallery=Gallery.find(params[:galle

    9. ruby-on-rails - 有没有办法为 CarrierWave/Fog 设置上传进度指示器? - 2

      我在Rails应用程序中使用CarrierWave/Fog将视频上传到AmazonS3。有没有办法判断上传的进度,让我可以显示上传进度如何? 最佳答案 CarrierWave和Fog本身没有这种功能;你需要一个前端uploader来显示进度。当我不得不解决这个问题时,我使用了jQueryfileupload因为我的堆栈中已经有jQuery。甚至还有apostonCarrierWaveintegration因此您只需按照那里的说明操作即可获得适用于您的应用的进度条。 关于ruby-on-r

    10. ruby - 没有类方法获取 Ruby 类名 - 2

      如何在Ruby中获取BasicObject实例的类名?例如,假设我有这个:classMyObjectSystem我怎样才能使这段代码成功?编辑:我发现Object的实例方法class被定义为returnrb_class_real(CLASS_OF(obj));。有什么方法可以从Ruby中使用它? 最佳答案 我花了一些时间研究irb并想出了这个:classBasicObjectdefclassklass=class这将为任何从BasicObject继承的对象提供一个#class您可以调用的方法。编辑评论中要求的进一步解释:假设你有对象

    随机推荐