yum quebrado quando interrompo a atualização nss-softokn-freebl-3.36.0-5.el7_5.x86_64

0

Meu sistema é centos7.

[root@centos7 caiyiheng]# uname -a
Linux centos7 3.10.0-229.el7.x86_64 #1 SMP Fri Mar 6 11:36:42 UTC 2015 
x86_64 x86_64 x86_64 GNU/Linux

Meu sistema é executado em uma caixa virtual.

Quando executo o cmd yum -y update e pressiono ctrl+c enquanto o yum está atualizando algo. Depois disso, descobri que não posso mais usar yum ou rpm. quando eu digito yum ou rpm ele aparece como:

[root@centos7 caiyiheng]# yum
error: Failed to initialize NSS library
error: no dbpath has been set
error: cannot open Packages database in /%{_dbpath}
CRITICAL:yum.main:

Error: rpmdb open failed
[root@centos7 caiyiheng]# rpm
error: Failed to initialize NSS library

a maioria dos comandos yum ou rpm não funciona, como yum install , yum clean all even yum --help .

Eu verifico /var/log/yum.log , mostra como:

[root@centos7 caiyiheng]# tail -f /var/log/yum.log
Sep 21 05:53:21 Installed: wget-1.14-15.el7_4.1.x86_64
Sep 21 05:53:21 Installed: lsof-4.87-5.el7.x86_64
Sep 21 05:53:22 Installed: net-tools-2.0-0.22.20131004git.el7.x86_64
Sep 26 17:28:11 Updated: libgcc-4.8.5-28.el7_5.1.x86_64
Sep 26 17:28:12 Installed: 1:grub2-common-2.02-0.65.el7.centos.2.noarch
Sep 26 17:28:13 Installed: 1:grub2-pc-modules-2.02-0.65.el7.centos.2.noarch
Sep 26 17:28:13 Installed: firewalld-filesystem-0.4.4.4-14.el7.noarch
Sep 26 17:28:14 Updated: tzdata-2018e-3.el7.noarch
Sep 26 17:28:14 Updated: ncurses-base-5.9-14.20130511.el7_4.noarch
Sep 26 17:28:15 Updated: nss-softokn-freebl-3.36.0-5.el7_5.x86_64

e eu pesquiso no google por um dia inteiro, encontrei muitas soluções que podem gostar do meu problema, eu tentei, mas nada aconteceu.

como

Eu até baixei o rpm link

e rpm2cpio nss-softokn-freebl-3.36.0-5.el7_5.x86_64.rpm | cpio -idmv e copie ./usr/lib ou lib64 ou ./etc para / usr / lib / usr / lib64 / etc, mas tudo isso não pode resolver o meu problema.

Alguém mencionou que o yum tem um problema com o chroot ( link ), mas ele não corresponde ao meu situação, eu até tentei isso, mas nada aconteceu.

    
por rangercyh 27.09.2018 / 04:26

1 resposta

0

Eu experimentei o mesmo problema. levei horas para encontrar o problema e resolvê-lo. meu caso é interromper o yum update e o último registro yum.log é como você

Oct 22 19:04:36 Updated: 1:grub2-pc-modules-2.02-0.65.el7.centos.2.noarch
Oct 22 19:04:36 Updated: tzdata-2018e-3.el7.noarch
Oct 22 19:04:37 Updated: bash-4.2.46-30.el7.x86_64
Oct 22 19:04:37 Updated: nss-softokn-freebl-3.36.0-5.el7_5.x86_64

Eu procurei e tentei todas as soluções, mas sem sorte como você. então eu li a fonte rpm e encontrei no rpm/rpmio/digest_nss.c

#if HAVE_NSS_INITCONTEXT
    PRUint32 flags = (NSS_INIT_READONLY|NSS_INIT_NOCERTDB|
              NSS_INIT_NOMODDB|NSS_INIT_FORCEOPEN|
              NSS_INIT_NOROOTINIT|NSS_INIT_OPTIMIZESPACE);
    _nss_ctx = NSS_InitContext(NULL, NULL, NULL, NULL, NULL, flags);
    if (_nss_ctx == NULL) {
#else
    if (NSS_NoDB_Init(NULL) != SECSuccess) {
#endif
        rpmlog(RPMLOG_ERR, _("Failed to initialize NSS library\n"));
        rc = -1;
    } else {
        _crypto_initialized = 1;
    }
    sigaction(SIGPIPE, &oact, NULL);
    }

    /* Register one post-fork handler per process */
    if (_new_process) {
    if (pthread_atfork(NULL, NULL, at_forkchild) != 0) {
        rpmlog(RPMLOG_WARNING, _("Failed to register fork handler: %m\n"));
    }
    _new_process = 0;
    }
    return rc;
}

então eu tentei com código como este para verificar

#include <stdio.h>
#include <nss.h>

int main() {
    NSSInitContext * _nss_ctx = NULL;
    printf("hello world!\n");
    PRUint32 flags = (NSS_INIT_READONLY|NSS_INIT_NOCERTDB|
                      NSS_INIT_NOMODDB|NSS_INIT_FORCEOPEN|
                      NSS_INIT_NOROOTINIT|NSS_INIT_OPTIMIZESPACE);
    _nss_ctx = NSS_InitContext(NULL, NULL, NULL, NULL, NULL, flags);
    if(_nss_ctx == NULL){
      printf("Error");
    }else{
      printf("OK");
    }
    return 0;
}

e obteve o NSS_InitContext não referenciado. ~~ então fica claro que a versão da lib não é compatível

wget both nss-3.36.0-7.el7_5.x86_64.rpm e nspr-4.13.1-1.0.el7_3.x86_64.rpm (meu sistema é centos7)

usando rpm2cpio *rpm | cpio -idmv para extrair o arquivo e copiá-lo para / usr

run rpm ainda tem o erro

version 'NSSUTIL_3.31' not found (required by /lib64/libnss3.so)

wget o nss-util-3.36.0-1.el7_5.x86_64.rpm e faça mais rpm2cpio and copy

então tudo fica ok ~ espero que isso possa ajudá-lo

    
por 23.10.2018 / 11:55