Я пытаюсь установить HHVM на свой CentOS 6.6, но эта проблема с множеством библиотек не позволяет мне.
При беге yum upgrade
, Я получаю такой результат.
root@invictus [~]# yum upgrade
Loaded plugins: fastestmirror
Setting up Upgrade Process
Loading mirror speeds from cached hostfile
* aso: repo-uscentral.asonoc.com
* base: centos.mirror.lstn.net
* epel: fedora-epel.mirror.lstn.net
* extras: repos.dfw.quadranet.com
* rpmforge: mirror.nexcess.net
* updates: repos.dfw.quadranet.com
Resolving Dependencies
--> Running transaction check
---> Package cpp.x86_64 0:4.4.7-11.el6 will be updated
---> Package cpp.x86_64 0:4.8.2-8.el6 will be an update
--> Processing Dependency: libmpc.so.2()(64bit) for package: cpp-4.8.2-8.el6.x86_64
---> Package curl.x86_64 0:7.19.7-40.el6_6.3 will be updated
---> Package curl.x86_64 0:7.29.0-4.el6 will be an update
---> Package gcc.x86_64 0:4.4.7-11.el6 will be updated
---> Package gcc.x86_64 0:4.8.2-8.el6 will be an update
---> Package gcc-c++.x86_64 0:4.4.7-11.el6 will be updated
---> Package gcc-c++.x86_64 0:4.8.2-8.el6 will be an update
---> Package gmp.x86_64 0:4.3.1-7.el6_2.2 will be updated
---> Package gmp.x86_64 1:4.3.2-4.el6 will be an update
---> Package libcurl.x86_64 0:7.19.7-40.el6_6.3 will be updated
---> Package libcurl.x86_64 0:7.29.0-4.el6 will be an update
---> Package libevent.x86_64 0:1.4.13-4.el6 will be updated
---> Package libevent.x86_64 0:1.4.14b-2.hphp.el6 will be an update
---> Package libgcc.x86_64 0:4.4.7-11.el6 will be updated
---> Package libgcc.x86_64 0:4.8.2-8.el6 will be an update
---> Package libgomp.x86_64 0:4.4.7-11.el6 will be updated
---> Package libgomp.x86_64 0:4.8.2-8.el6 will be an update
---> Package libstdc++.x86_64 0:4.4.7-11.el6 will be updated
---> Package libstdc++.x86_64 0:4.8.2-8.el6 will be an update
---> Package libstdc++-devel.x86_64 0:4.4.7-11.el6 will be updated
---> Package libstdc++-devel.x86_64 0:4.8.2-8.el6 will be an update
---> Package libtool.x86_64 0:2.2.6-15.5.el6 will be updated
---> Package libtool.x86_64 0:2.4.2-21.el6 will be an update
---> Package libtool-ltdl.x86_64 0:2.2.6-15.5.el6 will be updated
---> Package libtool-ltdl.x86_64 0:2.4.2-21.el6 will be an update
---> Package libtool-ltdl-devel.x86_64 0:2.2.6-15.5.el6 will be updated
---> Package libtool-ltdl-devel.x86_64 0:2.4.2-21.el6 will be an update
---> Package mpfr.x86_64 0:2.4.1-6.el6 will be updated
---> Package mpfr.x86_64 0:2.4.2-1.el6 will be an update
--> Running transaction check
---> Package libmpc.x86_64 0:0.8.3-0.3.svn855.el6 will be installed
--> Finished Dependency Resolution
Error: Multilib version problems found. This often means that the root
cause is something else and multilib version checking is just
pointing out that there is a problem. Eg.:
1. You have an upgrade for libgcc which is missing some
dependency that another package requires. Yum is trying to
solve this by installing an older version of libgcc of the
different architecture. If you exclude the bad architecture
yum will tell you what the root cause is (which package
requires what). You can try redoing the upgrade with
--exclude libgcc.otherarch ... this should give you an error
message showing the root cause of the problem.
2. You have multiple architectures of libgcc installed, but
yum can only see an upgrade for one of those arcitectures.
If you don't want/need both architectures anymore then you
can remove the one with the missing update and everything
will work.
3. You have duplicate versions of libgcc installed already.
You can use "yum check" to get yum show these errors.
...you can also use --setopt=protected_multilib=false to remove
this checking, however this is almost never the correct thing to
do as something else is very likely to go wrong (often causing
much more problems).
Protected multilib versions: libgcc-4.8.2-8.el6.x86_64 != libgcc-4.4.7-11.el6.i686
root@invictus [~]#
При беге yum check
root@invictus [~]# yum check
Loaded plugins: fastestmirror
python-libs-2.6.6-52.el6.x86_64 has missing requires of libffi.so.5()(64bit)
Error: check all
root@invictus [~]#
Проблема в том, что там является нет libgcc.x86_64 0:4.8.2-8.el6
пакет в RHEL6 / CentOS6. Текущая версия для EL6 - 4.4.7-11, это та версия, которую вы сейчас установили.
Перед вами стоит задача выяснить, почему yum вообще нашла такой пакет.
Во-первых, полностью очистите кеш yum. Возможно, кто-то создал такой пакет случайно, и он был извлечен позже, но в вашей системе все еще есть относящиеся к нему метаданные.
yum clean all
Во-вторых, выясните, где ням думает такой пакет исходит. Бегать:
yum list all libgcc
В чистой системе CentOS 6.6 вы должны получить следующий результат:
Installed Packages
libgcc.x86_64 4.4.7-11.el6 @base
Available Packages
libgcc.i686 4.4.7-11.el6 base
Если вы получите что-то еще, репозиторий будет идентифицирован, и вы сможете отключить это репо, связаться с его сопровождающим, подозревать вредоносную активность и т. Д.
Если вы получите идентичный результат, вы сможете продолжить обновление системы.
У меня возникла аналогичная проблема, когда я обновлял свою систему CentOS 7. Основная проблема заключается в том, что в процессе обновления возникают некоторые зависимости, которые противоречат версии, установленной на локальном компьютере. Чтобы иметь возможность обновить машину, необходимо удалить старую версию пакетов, которые конфликтуют, т.е.
rpm -e --justdb --nodeps libgcc-4.4.7-11.el6.i686
Иногда это также может быть проблема с пакетами 32 против 64, которые можно решить, например Вот
У меня похожая проблема. Когда я пытаюсь обновить centos7, я получаю результат:
Multilib version problems found. This often means that the root
cause is something else and multilib version checking is just
pointing out that there is a problem. Eg.:
1. You have an upgrade for device-mapper-libs which is missing some
dependency that another package requires. Yum is trying to
solve this by installing an older version of device-mapper-libs of the
different architecture. If you exclude the bad architecture
yum will tell you what the root cause is (which package
requires what). You can try redoing the upgrade with
--exclude device-mapper-libs.otherarch ... this should give you an error
message showing the root cause of the problem.
2. You have multiple architectures of device-mapper-libs installed, but
yum can only see an upgrade for one of those architectures.
If you don't want/need both architectures anymore then you
can remove the one with the missing update and everything
will work.
3. You have duplicate versions of device-mapper-libs installed already.
You can use "yum check" to get yum show these errors.
...you can also use --setopt=protected_multilib=false to remove
this checking, however this is almost never the correct thing to
do as something else is very likely to go wrong (often causing
much more problems).
Chronione wersje multilib: 7:device-mapper-libs-1.02.135-1.el7_3.2.x86_64 != 7:device-mapper-libs-1.02.135-1.el7_3.1.i686
В моем случае у меня проблема с device-mapper-libs
. На первом этапе проверьте повторяющиеся пакеты:
yum list --showduplicates device-mapper-libs-1.02.135-1.el7_3.1
Wczytane wtyczki: fastestmirror, langpacks Loading mirror speeds from
cached hostfile * base: centos1.hti.pl * epel: ftp.icm.edu.pl *
extras: centos1.hti.pl * nux-dextop: li.nux.ro * updates:
ftp.icm.edu.pl * webtatic: uk.repo.webtatic.com Zainstalowane pakiety
device-mapper-libs.i686
7:1.02.135-1.el7_3.1
@updates device-mapper-libs.x86_64
7:1.02.135-1.el7_3.1
@updates Dostępne pakiety device-mapper-libs.i686
7:1.02.135-1.el7_3.1
updates device-mapper-libs.x86_64
Затем удалите недопустимый пакет:
yum erase device-mapper-libs.i686
А теперь выполните update / upgrade. Это сработало.