linux下存储数据,mysql无疑是个很不错的选择。mysql的默认存储路径为/var/lib/mysql。以前数据库一直不是很大,总共十个G左右的大小,放在默认路径毫无压力。但是今天,因为新导入一个数据库,光是导入数据就是30+G,瞬间就悲剧了,因为我并没有为/目录准备足够的硬盘分区空间。所以,修改配置,迁移数据库存储路径到合适的地方成了最省力的选择。
停止mysql服务,准备数据
因为这是运行到一半修改的,所以有一些历史遗留数据。应当先停止数据库服务,我使用的Fedora 19 , 命令可以如下
# service mysqld stop
然后妥妥的把数据从默认位置 /var/lib/mysql下的内容到目标位置 -- 比如我的,/home/mysql
修改配置文件
my.cnf
首先需要修改配置文件/etc/my.cnf。其中有datadir和socket之类字样。意义不言自明,就是修改它们的路径啦。当然,这个my.cnf可能出现在其他地方,如果是新的用户,甚至可能找不到,但没有关系,
ls /usr/share/mysql/
可以看到一些mysql-XXX-cnf , 可以从其中选择一些作为模板,修改一下,丢/etc下即可。
get_mysql_option
除了cnf外,还需要修改一个get_mysql_option的设置,真是受不了。。。
网上大多是以前版本,称应该修改"/etc/rc.d/init.d/mysqld"这个文件 -- 实际上对于fedora 19而言,这个脚本并不存在。 查看错误信息,可以看到错误提示如下:
[root@f-argcv etc]# systemctl status mysqld.service mysqld.service - MariaDB database server Loaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled) Active: failed (Result: exit-code) since Wed 2013-10-23 19:38:22 HKT; 8s ago Process: 4936 ExecStartPost=/usr/libexec/mysqld-wait-ready $MAINPID (code=exited, status=1/FAILURE) Process: 4935 ExecStart=/usr/bin/mysqld_safe --basedir=/usr (code=exited, status=0/SUCCESS) Process: 4913 ExecStartPre=/usr/libexec/mysqld-prepare-db-dir %n (code=exited, status=0/SUCCESS) Oct 23 19:38:20 f-argcv systemd[1]: Starting MariaDB database server... Oct 23 19:38:21 f-argcv mysqld_safe[4935]: 131023 19:38:21 mysqld_safe Logging to '/var/log/mysqld.log'. Oct 23 19:38:21 f-argcv mysqld_safe[4935]: 131023 19:38:21 mysqld_safe Starting mysqld daemon with databases from /home/mysql/data Oct 23 19:38:21 f-argcv mysqld_safe[4935]: 131023 19:38:21 mysqld_safe mysqld from pid file /var/run/mysqld/mysqld.pid ended Oct 23 19:38:22 f-argcv systemd[1]: mysqld.service: control process exited, code=exited status=1 Oct 23 19:38:22 f-argcv systemd[1]: Failed to start MariaDB database server. Oct 23 19:38:22 f-argcv systemd[1]: Unit mysqld.service entered failed state.
出现问题的源头似乎是/usr/libexec/mysqld-wait-ready 。 检查修改basedir等参数,然后开跑即可。。。
其他方法
孔夫子说,道不行,乘桴浮于海。 对我们也一样,实在不行,还有最后的办法:备份数据,卸载,重新安装 -- 有yum在这其实也很方便。 然后配置好文件,尤其是修改/usr/bin/mysql_install_db,其中的ldata参数
mysql_install_db
即可
后记
后来,我重装了机器,给var单独配了个可扩展的分区。个人觉得,这才是最让人舒服的设置。
11 Comments
Leniy · October 31, 2013 at 20:19
评论不能回复
yu · October 31, 2013 at 20:26
可以回复,只是看起来比较怪而已 — 我在尝试调整中。。。
海涛 · October 26, 2013 at 10:36
回复报错,,,什么情况。。。
yu · October 26, 2013 at 11:09
额…刚换主题,估计还没有调好…
Leniy · October 25, 2013 at 14:53
手机版的相关文章显示的不好
Leniy · October 25, 2013 at 09:36
你终于换主题了,但是这个主题还是怪怪的
yu · October 25, 2013 at 12:07
agree
感觉好大啊。。。。
因为之前在主题里面做了好多调整,换个主题好多东西就白费了。。
yu · October 25, 2013 at 13:18
其实我还是比较喜欢这个
你可以收到回复提示的邮件么?
Leniy · October 25, 2013 at 14:52
还是今天这个主题大气。评论部分有些不好看,建议修修。
邮件回复收到了,建议安装Leniy Tweaks插件,常用的功能都集成在里面了
yu · October 25, 2013 at 15:09
“今天”这个是指哪个?我最后弄的这个白色的么?
之前那个主要是看得有点压抑。。。
评论这个已经修改过好几下了。。。
我试试你那个tweak。。。
yu · October 31, 2013 at 19:40
又换了个主题,然后按照自己的习惯修改了一些地方 @_@发现我的前台水的什么一样的,你看这个主题哪里比较不和谐的难看的,基本是我动过手的地方了。。。