美文网首页
mysql大数据迁移,简单步骤

mysql大数据迁移,简单步骤

作者: abs1004 | 来源:发表于2017-07-21 14:11 被阅读0次

    M级别数据迁移
    一、修改php.ini文件。
    cmd+shift+g 输入 /etc/php.ini 找到php.ini
    找到php.ini搜索这3个地方
    1、查找post_max_size,指通过表单POST给PHP的所能接收的最大值,包括表单里的所有值,默认为8M,看你自己需要进行改变。
    2、查找File Uploads,首先确认file_uploads = on ;是否允许通过HTTP上传文件的开关,默认为ON即是开。 upload_tmp_dir ;
    查找upload_max_filesize ;即允许上传文件大小的最大值。默认为2M。
    3、如果要上传>8M的文件,那么只设置上述四项还不定一定可以。最好对下面的参数也进行设置:
    查找max_execution_time = 600 ;每个PHP页面运行的最大时间值(秒),默认30秒。
    max_input_time = 600 ;每个PHP页面接收数据所需的最大时间,默认60秒 。
    memory_limit = 8M ;每个PHP页面所吃掉的最大内存,默认8M。
    4.重启mysql :
    sudo /Library/StartupItems/MySQLCOM/MySQLCOM restart
    sudo apachectl restart
    然后重新登录phpmyadmin就可以了

    二、修改c:/phpmyadmin/import.php文件。
    用写字板打开import.php文件:
    1、查找$memory_limit,默认为$memory_limit = 2 * 1024 * 1024;自己修改。
    2、下边三四行的位置有同样的语句,自己修改。

    -------------------------------------------------
    G级别数据迁移
    最近有个需求,要把机器a上的一个数据库迁移到机器b上,这个数据库的数据有100多个G。所以,果断抛弃用mysqldump的方法来迁移。这时候想到的就是直接复制文件来做迁移。
    于是我按照网上的说法,步骤如下:
    一、把机器b的MySQL停掉。
    二、把机器a上要迁移的库的整个目录复制到机器b的mysql data目录下。
    三、修改目录权限为700,修改文件权限为660,并修改他们的所属用户和所属组为mysql。
    四、再启动机器b的mysql。
    操作完成后,我进入机器b的mysql,此时,执行show databases可以看到要迁移的数据库。然后执行use databasename,再执行show tables,也可以看到所有的表。但是问题来了,我执行select * from table limit 10,这时候却报错了,提示表不存在。
    所以,我们大致可以指定mysql的工作机制,show databases和show tables时,mysql其实是去目录下扫描,但执行select这些操作的时候,mysql优化器会去information_schema.TABLES 这个表里面获取信息。由于我们是直接复制文件过去,所以,这个表里面是没有信息的,所以就会提示表不存在。
    知道了这点之后,我修改了上述步骤:
    一、在机器b上,创建需要的database
    二、在该database建好所有的表。
    三、把机器b的mysql停掉。
    四、到机器b上,刚才建的那个数据库的目录下,把所有的(.ibd)文件删除掉。
    五、把机器a上,对应数据库目录下所有的(.ibd)文件复制到机器b上,修改文件的权限。
    六、启动机器b的mysql。
    这时候再连接上b的mysql,就可以看到所有的数据了。

    相关文章

      网友评论

          本文标题:mysql大数据迁移,简单步骤

          本文链接:https://www.haomeiwen.com/subject/jchekxtx.html