debian(wheezy)安装mysql的时候报错There's not enough space in /var/lib/mysql/

新机器,安装#apt-get install mysql-server提示需要安装mysql-server-5.5 等其它几个。 于是跟上。 到了安装的时候提示错误。

Setting up mysql-common (5.5.33+dfsg-0+wheezy1) ...
(Reading database ... 180252 files and directories currently installed.)
Unpacking mysql-server-5.5 (from .../mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb) ...
ERROR: There's not enough space in /var/lib/mysql/
dpkg: error processing /var/cache/apt/archives/mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb (--unpack):
 subprocess new pre-installation script returned error exit status 1
Selecting previously unselected package mysql-server.
Unpacking mysql-server (from .../mysql-server_5.5.33+dfsg-0+wheezy1_all.deb) ...
Errors were encountered while processing:
 /var/cache/apt/archives/mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb
E: Sub-process /usr/bin/dpkg returned an error code (1)


这里我们分析下问题。apt-get install 调用的dpkg, 然后dpkg  去调的

/var/cache/apt/archives/mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb
 把apt的cache的这个文件复制出来

#cp /var/cache/apt/archives/mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb /home/bak

然后我们去看看打包的文件里面是怎么判断的。执行下面的shell,我们把这个包解压出来。

#cd /home/bak && make tmp
#mkdir tmp
#dpkg-deb -x mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb tmp
#dpkg-deb --control mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb.deb tmp/DEBIAN

然后

#cd tmp/DEBIAN

找到了一个预安装文件叫preinst,用编辑器打开。在149行找到这句话

# checking disc space
if LC_ALL=C BLOCKSIZE= df --portability $DATADIR/. | tail -n 1 | awk '{ exit ($4>1000) }'; then
  echo "ERROR: There's not enough space in $4 and $DATADIR/" 1>&2
  db_stop
  exit 1
fi

这里是个判断,就是刚才我们安装的时候报的错

ERROR: There's not enough space in /var/lib/mysql/
现在我们把这个提取出来稍加修改在终端运行一下

#df --portability $DATADIR/. | tail -n 1 | awk '{ print $4 }'
显示是空, 所以进来提示, 空间不足。

我们继续把这个preinst改下,或者是修改下判断 比如从$5来判断 或者直接反起来, 把$4>1000 改成$4<1000

然后重新打包 

#dpkg -b tmpmysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb

接下来复制回去mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb

#cp mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb/var/cache/apt/archives/mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb

#yes

继续重新安装发现通过了安装。没有再提示空间不足。

但是问题的根源不在mysql的预安装文件上, 而是在我们自身的系统环境上。

通过排查,发现系统已经安装了一些会影响系统命令输出的程序。

找到你的.bashrc 看看是不是装了一些终端显色的软件。比如cw 它会影响到这个的输出。注释掉这个再运行下刚才修改的语句,就可以看见区别了。

会显示几百万甚至几千万,在preinst这里就会跳过而不报错了。


比如cw 终端显色,正是这个软件导致了系统命令的输出出现了错行。所以,只需要暂时注销掉在.bashrc里面的cw就可以了



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值