今天我更新了openssl(由于最近的心脏漏洞),突然间mysql的表现很奇怪.我最近能够修改表格,但现在当我尝试添加列时,我得到:
ERROR 1005 (HY000): Can't create table '#sql-34f_872b' (errno: 13)
Run Code Online (Sandbox Code Playgroud)
并试图做到show tables结果:
ERROR 1018 (HY000): Can't read dir of './<db>/' (errno: 13)
Run Code Online (Sandbox Code Playgroud)
在openssl升级期间,有一个提示询问是否升级到mysql.它问我是否要保留当前的/etc/my.cnf,或者我是否想要更换新的 - 我选择保留.
通常这将是一个权限问题,我已经尝试并测试了mysql的权限datadir(使用类似问题的答案).
其他一些奇怪的事情:
我觉得openssl升级太过于巧合而忽略了,而且我并不热衷于重新启动mysqld而不知道服务器肯定会重新启动(因为这里有一个未知的问题).
有任何想法吗?
回复评论和问题:
产量ls -ltrFa:
remy@ip-10-168-9-52:~$ ls -ltrFa /vol/mysql/
total 49367084
-rwxr-xr-x 1 mysql mysql 0 Feb 11 2013 debian-5.5.flag*
drwxr-xr-x 2 mysql mysql 4096 Feb 11 2013 test/
drwxr-xr-x 2 mysql mysql 4096 Feb 11 2013 performance_schema/
drwxr-xr-x 2 mysql mysql 4096 Feb 11 2013 mysql/
-rwxr-xr-x 1 mysql mysql 6 Feb 11 2013 mysql_upgrade_info*
-rwxr-xr-x 1 mysql mysql 25 Feb 12 2013 slave-relay-bin.index*
-rwxr-xr-x 1 mysql mysql 126 Feb 12 2013 slave-relay-bin.000001*
drwxr-xr-x 6 mysql mysql 4096 Oct 14 14:35 ./
drwxr-xr-x 2 mysql mysql 4096 Apr 3 15:50 jsbin/
drwxrwxrwx 5 root root 4096 Apr 9 16:07 ../
-rwxr-xr-x 1 mysql mysql 50417631232 Apr 9 17:24 ibdata1*
-rwxr-xr-x 1 mysql mysql 67108864 Apr 9 17:24 ib_logfile0*
-rwxr-xr-x 1 mysql mysql 67108864 Apr 9 17:25 ib_logfile1*
Run Code Online (Sandbox Code Playgroud)
产量ps aux | grep mysql:
mysql 847 1.4 83.9 16342212 14681964 ? Ssl 2013 3646:34 /usr/sbin/mysqld
remy 4038 0.0 0.0 101816 2824 pts/0 S+ 16:58 0:00 mysql -uroot -px xxxxx jsbin
Run Code Online (Sandbox Code Playgroud)
请注意,我也尝试使用运行mysql sudo -u mysql mysql -uroot -pxxx jsbin,它会导致同样的问题.
这是apt-get upgrade openssl显示mysql包含在更新中的日志:https://gist.github.com/remy/10291829
服务器是ubuntu-precise-12.04-amd64(安装都是通过apt-get而不是手动编译).
mysql的版本:
$ mysqld --version
mysqld Ver 5.5.29-0ubuntu0.12.04.1 for debian-linux-gnu on x86_64 ((Ubuntu))
$ mysql --version
mysql Ver 14.14 Distrib 5.5.35, for debian-linux-gnu (x86_64) using readline 6.2
Run Code Online (Sandbox Code Playgroud)
小智 5
以下对我有用:
rm /var/lib/mysql/ib_logfile*
/etc/init.d/mysql restart
Run Code Online (Sandbox Code Playgroud)
事实证明,它apt-get upgrade openssl实际上升级了它之后的所有其他内容 - 以及 openssl。所以不知何故 MySQL 陷入了那个更新。
偶然(实际上是 AWS 备份)机器重新启动,所有问题都消失了。
我很确定这是因为 MySQL 的一些库已经更新,但是加载到内存中的服务器在某种程度上不兼容。
我通常不会建议随机重新启动来解决这些问题,但在这种特殊情况下,它完成了工作。
| 归档时间: |
|
| 查看次数: |
12837 次 |
| 最近记录: |