Rumah pangkalan data tutorial mysql debian(wheezy)安装mysql的时候报错There's not enough sp

debian(wheezy)安装mysql的时候报错There's not enough sp

Jun 07, 2016 pm 03:40 PM
debian mysql t Pasang Laporkan ralat

新机器,安装#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 installe

新机器,安装#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)
Salin selepas log masuk


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

/var/cache/apt/archives/mysql-server-5.5_5.5.33+dfsg-0+wheezy1_amd64.deb
Salin selepas log masuk
 把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
Salin selepas log masuk

然后

#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
Salin selepas log masuk

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

ERROR: There's not enough space in /var/lib/mysql/
Salin selepas log masuk
现在我们把这个提取出来稍加修改在终端运行一下
#df --portability $DATADIR/. | tail -n 1 | awk '{ print $4 }'
Salin selepas log masuk
显示是空, 所以进来提示, 空间不足。

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

然后重新打包 

#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就可以了



Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Kemahiran pemprosesan struktur data besar PHP Kemahiran pemprosesan struktur data besar PHP May 08, 2024 am 10:24 AM

Kemahiran pemprosesan struktur data besar PHP

Bagaimana untuk mengoptimumkan prestasi pertanyaan MySQL dalam PHP? Bagaimana untuk mengoptimumkan prestasi pertanyaan MySQL dalam PHP? Jun 03, 2024 pm 08:11 PM

Bagaimana untuk mengoptimumkan prestasi pertanyaan MySQL dalam PHP?

Bagaimana untuk menggunakan sandaran dan pemulihan MySQL dalam PHP? Bagaimana untuk menggunakan sandaran dan pemulihan MySQL dalam PHP? Jun 03, 2024 pm 12:19 PM

Bagaimana untuk menggunakan sandaran dan pemulihan MySQL dalam PHP?

Apakah senario aplikasi jenis penghitungan Java dalam pangkalan data? Apakah senario aplikasi jenis penghitungan Java dalam pangkalan data? May 05, 2024 am 09:06 AM

Apakah senario aplikasi jenis penghitungan Java dalam pangkalan data?

Bagaimana untuk memasukkan data ke dalam jadual MySQL menggunakan PHP? Bagaimana untuk memasukkan data ke dalam jadual MySQL menggunakan PHP? Jun 02, 2024 pm 02:26 PM

Bagaimana untuk memasukkan data ke dalam jadual MySQL menggunakan PHP?

Bagaimana untuk membetulkan ralat mysql_native_password tidak dimuatkan pada MySQL 8.4 Bagaimana untuk membetulkan ralat mysql_native_password tidak dimuatkan pada MySQL 8.4 Dec 09, 2024 am 11:42 AM

Bagaimana untuk membetulkan ralat mysql_native_password tidak dimuatkan pada MySQL 8.4

Bagaimana untuk menggunakan prosedur tersimpan MySQL dalam PHP? Bagaimana untuk menggunakan prosedur tersimpan MySQL dalam PHP? Jun 02, 2024 pm 02:13 PM

Bagaimana untuk menggunakan prosedur tersimpan MySQL dalam PHP?

Bagaimana untuk membuat jadual MySQL menggunakan PHP? Bagaimana untuk membuat jadual MySQL menggunakan PHP? Jun 04, 2024 pm 01:57 PM

Bagaimana untuk membuat jadual MySQL menggunakan PHP?

See all articles