[devel] zlib addicts
Alexey Tourbin
at на altlinux.ru
Сб Окт 8 14:08:42 MSD 2005
On Fri, Oct 07, 2005 at 07:29:03PM +0400, Dmitry V. Levin wrote:
> On Mon, Sep 26, 2005 at 05:19:10AM +0400, Alexey Tourbin wrote:
> > Следующие пакеты (предположительно) таскают с собой zlib.
>
> $ grep -w zlibVersion def |grep -wv ^zlib
> erlang /usr/lib/erlang/erts-5.4/bin/beam.shared T zlibVersion
> erlang /usr/lib/erlang/erts-5.4/bin/beam T zlibVersion
> firefox /usr/lib/firefox-1.0.6/install/mozilla-installer-bin T zlibVersion
> firefox /usr/lib/firefox-1.0.6/mozilla-installer-bin T zlibVersion
> j2se1.3-sun /usr/lib/j2se1.3-sun/jre/lib/i386/libzip.so T zlibVersion
> openoffice.org /usr/lib/OpenOffice.org1.1.5/program/libmozz.so T zlibVersion
> R-base /usr/lib/R/bin/libR.so T zlibVersion
> R-base /usr/lib/R/bin/R.bin T zlibVersion
> scorched3d /usr/games/scorched3d T zlibVersion
> vnc-server /usr/bin/Xvnc T zlibVersion
> xmule /usr/bin/xmule T zlibVersion
>
> Просьба развесить баги.
Много чести zlib'у будет. Нужно искать все пакеты, которые таскают с
собой системные библиотеки. В первом приближении можно сделать вот что.
1) Выделить подмножество списка def: символы, которые прдоставляют
системные библиотеки.
$ awk -F'\t' '$2~"^(/usr(/X11R6)?)?/lib(64)?/lib[^/]+[.]so"' def >libdef
$ du -hs libdef def
85M libdef
211M def
$
2) Сделать join (libdef x def) по символам.
$ join -t$'\t' -j 4 -o '1.1 1.2 1.3 2.1 2.2 2.3 0' libdef def |head
libgcj3.3 /usr/lib/libgcj.so.4.0.0 B libgcj3.3 /usr/lib/libgcj.so.4.0.0 B A
libgcj3.3 /usr/lib/libgcj.so.4.0.0 B libgcj3.3-debug /usr/lib/debug/libgcj.so.4.0.0 B A
libgcj3.3 /usr/lib/libgcj.so.4.0.0 B libgcj3.4 /usr/lib/libgcj.so.5.0.0 B A
libgcj3.3 /usr/lib/libgcj.so.4.0.0 B libgcj3.4-debug /usr/lib/debug/libgcj.so.5.0.0 B A
libgcj3.4 /usr/lib/libgcj.so.5.0.0 B libgcj3.3 /usr/lib/libgcj.so.4.0.0 B A
libgcj3.4 /usr/lib/libgcj.so.5.0.0 B libgcj3.3-debug /usr/lib/debug/libgcj.so.4.0.0 B A
libgcj3.4 /usr/lib/libgcj.so.5.0.0 B libgcj3.4 /usr/lib/libgcj.so.5.0.0 B A
libgcj3.4 /usr/lib/libgcj.so.5.0.0 B libgcj3.4-debug /usr/lib/debug/libgcj.so.5.0.0 B A
libfaac /usr/lib/libfaac.so.0.0.0 T libfaac /usr/lib/libfaac.so.0.0.0 T AACQuantize
libfaac /usr/lib/libfaac.so.0.0.0 T libfaac /usr/lib/libfaac.so.0.0.0 T AACQuantizeEnd
$
Это прямое произведение, его даже бесполезно пробовать сохранять на
диске. Для серьезной работы с такими вещами нужны ленивые вычисления,
как минимум что-то вроде SQL views.
3) Из этого списка нужно убрать собственные совпадения, то есть
cовпадения (библиотека == библиотека). Ищем только совпадения
(библиотека == бинарь). Ищем также совпадения по типу сивола (здесь бы
нужно делать join по составному ключу тип+символ, но join(1) этого не
умеет). Это уже можно будет попробовать сохранить на диске.
$ join -t$'\t' -j 4 -o '1.1 1.2 1.3 2.1 2.2 2.3 0' libdef def |
awk -F'\t' '{OFS="\t"}$2!=$5&&$3==$6{print$1,$2,$4,$5,$6,$7}' >product
^C
$ du -hs product
915M product
$
Не удается сохранить на диск.
$ head product
libgcj3.3 /usr/lib/libgcj.so.4.0.0 libgcj3.3-debug /usr/lib/debug/libgcj.so.4.0.0 B A
libgcj3.3 /usr/lib/libgcj.so.4.0.0 libgcj3.4 /usr/lib/libgcj.so.5.0.0 B A
libgcj3.3 /usr/lib/libgcj.so.4.0.0 libgcj3.4-debug /usr/lib/debug/libgcj.so.5.0.0 B A
libgcj3.4 /usr/lib/libgcj.so.5.0.0 libgcj3.3 /usr/lib/libgcj.so.4.0.0 B A
libgcj3.4 /usr/lib/libgcj.so.5.0.0 libgcj3.3-debug /usr/lib/debug/libgcj.so.4.0.0 B A
libgcj3.4 /usr/lib/libgcj.so.5.0.0 libgcj3.4-debug /usr/lib/debug/libgcj.so.5.0.0 B A
libinn /usr/lib/libstorage.so.2.0.0 inn /usr/bin/nnrpd B ACTIVE
libinn /usr/lib/libstorage.so.2.0.0 inn /usr/bin/tdx-util B ACTIVE
libfreewrl /usr/lib/libFreeWRLFunc.so freewrl /usr/lib/perl5/vendor_perl/i386-linux/auto/VRML/VRMLFunc/VRMLFunc.so D AC_LastDuration
libfreewrl /usr/lib/libFreeWRLFunc.so freewrl /usr/lib/perl5/vendor_perl/i386-linux/auto/VRML/VRMLFunc/libFreeWRLFunc.so D AC_LastDuration
$
Ну ясно, что получается. Слева -- системная библиотека, справа --
бинарь (возможно, другая системная библиотека), которая предоставляет
такой же символ.
Нужно понять, что там "забилось".
$ cut -f5,6 product |uniq -c -f1 |sort -n |tail
169 A WX_2.6
182 T ODBCINSTGetProperties
253 A GLIBC_PRIVATE
278 A EXPORTED
327 T Mod_Init
510 A GLIBC_2.0
756 T MD5Final
756 T MD5Init
756 T MD5Update
9487118 A _DYNAMIC
$
3a) Ясно, пробуем ещё раз, исключив символы типа [A].
$ join -t$'\t' -j 4 -o '1.1 1.2 1.3 2.1 2.2 2.3 0' libdef def |
awk -F'\t' '{OFS="\t"}$2!=$5&&$3==$6&&$3!="A"{print$1,$2,$4,$5,$6,$7}' >product
^C
$ du -hs product
515M product
$
Опять забилось.
$ cut -f5,6 product |uniq -c -f1 |sort -n
...
24920 a _DYNAMIC
29465 W _ZNK17QValueListPrivateI7QStringE2atEj
56098 V _ZTI9QMemArrayIcE
56098 V _ZTS9QMemArrayIcE
56208 V _ZTV9QMemArrayIcE
56208 W _ZN9QMemArrayIcE6detachEv
56208 W _ZN9QMemArrayIcED0Ev
56208 W _ZN9QMemArrayIcED1Ev
57237 W _Z4endlR11kndbgstream
61386 W _Z4endlR10kdbgstream
105193 W _ZN7QWidget11setGeometryERK5QRect
107391 W _ZN10QValueListI7QStringE14detachInternalEv
107391 W _ZN17QValueListPrivateI7QStringE6insertE18QValueListIteratorIS0_ERKS0_
109473 W _ZN17QValueListPrivateI7QStringEC1ERKS1_
111298 W _ZN17QValueListPrivateI7QStringEC1Ev
124924 W _ZN7QWidget9setWFlagsEj
124924 W _ZN7QWidget9setWStateEj
139398 W _ZN17QValueListPrivateI7QStringED1Ev
331113 V _ZTI6QGList
331113 V _ZTS6QGList
337244 V _ZTV6QGList
337244 W _ZNK6QGList5countEv
$
3б) Okay, что делать с [VW], я не знаю. Проще всего перестроить список
libdef, оставив только символы [BDT] -- глобальные переменные и функции.
$ awk -F'\t' '$2~"^(/usr(/X11R6)?)?/lib(64)?/lib[^/]+[.]so"&&$3~/[BDT]/' def >libdef
$ du -hs libdef
56M libdef
$ join -t$'\t' -j 4 -o '1.1 1.2 1.3 2.1 2.2 2.3 0' libdef def |
awk -F'\t' '{OFS="\t"}$2!=$5&&$3==$6{print$1,$2,$4,$5,$6,$7}' >product
^C
$ du -hs product
352M product
$
Опять забивается, из-за символов "T _fini" и "T _init".
Самые частые символы нужно удалить из libdef.
3в) Перестраиваем libdef без символов _fini и _init.
$ awk -F'\t' '$2~"^(/usr(/X11R6)?)?/lib(64)?/lib[^/]+[.]so"&&$3~/[BDT]/&&$4!="_fini"&&$4!="_init"' def >libdef
$ join -t$'\t' -j 4 -o '1.1 1.2 1.3 2.1 2.2 2.3 0' libdef def |
awk -F'\t' '{OFS="\t"}$2!=$5&&$3==$6{print$1,$2,$4,$5,$6,$7}' >product
$ du -hs product
113M product
$
Во! Получилось.
$ tail product
libclamav /usr/lib/libclamav.so.1.0.16 zziplib /usr/lib/libzzip-0-64.so.13.0.38 T zzip_seterror
zziplib /usr/lib/libzzip-0-64.so.13.0.38 libclamav /usr/lib/libclamav.so.1.0.16 T zzip_seterror
libclamav /usr/lib/libclamav.so.1.0.16 zziplib /usr/lib/libzzip-0-64.so.13.0.38 T zzip_strerror
zziplib /usr/lib/libzzip-0-64.so.13.0.38 libclamav /usr/lib/libclamav.so.1.0.16 T zzip_strerror
libclamav /usr/lib/libclamav.so.1.0.16 zziplib /usr/lib/libzzip-0-64.so.13.0.38 T zzip_strerror_of
zziplib /usr/lib/libzzip-0-64.so.13.0.38 libclamav /usr/lib/libclamav.so.1.0.16 T zzip_strerror_of
libclamav /usr/lib/libclamav.so.1.0.16 zziplib /usr/lib/libzzip-0-64.so.13.0.38 T zzip_tell
zziplib /usr/lib/libzzip-0-64.so.13.0.38 libclamav /usr/lib/libclamav.so.1.0.16 T zzip_tell
libclamav /usr/lib/libclamav.so.1.0.16 zziplib /usr/lib/libzzip-0-64.so.13.0.38 T zzip_telldir
zziplib /usr/lib/libzzip-0-64.so.13.0.38 libclamav /usr/lib/libclamav.so.1.0.16 T zzip_telldir
$
Из этого видно, что библиотека libclamav, похоже, таскает с собой
библиотеку zziplib (или статически с ней слинкована).
Проверяем, где у нас zlibVersion.
$ grep -w zlibVersion product
zlib /lib/libz.so.1.2.3 R-base /usr/lib/R/bin/R.bin T zlibVersion
zlib /lib/libz.so.1.2.3 R-base /usr/lib/R/bin/libR.so T zlibVersion
zlib /lib/libz.so.1.2.3 erlang /usr/lib/erlang/erts-5.4/bin/beam T zlibVersion
zlib /lib/libz.so.1.2.3 erlang /usr/lib/erlang/erts-5.4/bin/beam.shared T zlibVersion
zlib /lib/libz.so.1.2.3 firefox /usr/lib/firefox-1.0.6/install/mozilla-installer-bin T zlibVersion
zlib /lib/libz.so.1.2.3 firefox /usr/lib/firefox-1.0.6/mozilla-installer-bin T zlibVersion
zlib /lib/libz.so.1.2.3 j2se1.3-sun /usr/lib/j2se1.3-sun/jre/lib/i386/libzip.so T zlibVersion
zlib /lib/libz.so.1.2.3 openoffice.org /usr/lib/OpenOffice.org1.1.4/program/libmozz.so T zlibVersion
zlib /lib/libz.so.1.2.3 scorched3d /usr/games/scorched3d T zlibVersion
zlib /lib/libz.so.1.2.3 vnc-server /usr/bin/Xvnc T zlibVersion
zlib /lib/libz.so.1.2.3 xmule /usr/bin/xmule T zlibVersion
$
Нужно теперь подумать, что делать с этим списком.
Я бы его кому-нибудь продал. Всего ничего, доллар за мегабайт. :)
----------- следущая часть -----------
Было удалено вложение не в текстовом формате...
Имя : отсутствует
Тип : application/pgp-signature
Размер : 189 байтов
Описание: отсутствует
Url : http://lists.altlinux.ru/pipermail/devel/attachments/20051008/9b8a0eba/attachment.bin
Подробная информация о списке рассылки Devel