AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1450027
Accepted
Danila Vershinin
Danila Vershinin
Asked: 2019-06-19 02:41:04 +0800 CST2019-06-19 02:41:04 +0800 CST 2019-06-19 02:41:04 +0800 CST

Como exatamente um sistema pode quebrar atualizando o glibc?

  • 772

Suponha que eu tenha um programa que depende de uma versão glibc mais recente que não está disponível no sistema por meio de pacotes. E dá:

version `GLIBC_2.xxx' not found

Uma solução é compilar o binário com glibc estaticamente.

A outra solução que é descartada por muitas pessoas como "não segura" é colocar mais recente libc.so.6em vez da fornecida pelo sistema operacional.

Como exatamente essa segunda solução não é segura ou uma má ideia, desde que libc.so.6inclua endpoints ABI anteriores?

Por exemplo, se eu executar strings /usr/lib/libc.so.6 | grep --perl-regexp "^GLIBC_", posso ver muitas dessas versões da ABI como:

...
GLIBC_2.10
GLIBC_2.11
GLIBC_2.12
GLIBC_2.13
GLIBC_2.14
GLIBC_2.15
GLIBC_2.16
GLIBC_2.17
...

Portanto, se estou substituindo por um mais recente libc.so.6com versões glibc ABI adicionais dentro dele, como ele quebra aplicativos mais antigos ou leva o sistema à quebra?

Ou não...? :)

centos redhat-enterprise-linux
  • 2 2 respostas
  • 1908 Views

2 respostas

  • Voted
  1. Best Answer
    harrymc
    2019-06-21T04:56:14+08:002019-06-21T04:56:14+08:00

    Em geral, os binários que foram compilados para uma versão glibc mais antiga funcionarão bem em um sistema com uma glibc mais recente, pois a glibc é compatível com versões anteriores e lida automaticamente com alterações em sua interface binária de aplicativo (ABI) . Ele consegue essa magia usando o versionamento de símbolos, onde basicamente a cada símbolo é anexada uma tag especificando sua versão glibc.

    No caso de mudanças semânticas nas chamadas de funções, a glibc incluirá duas versões, uma para a semântica antiga e outra para a nova semântica, de modo que cada função é marcada com sua versão. O vinculador considerará ambas as versões como duas funções distintas.

    Esse mecanismo sofisticado é necessário, pois a glibc não é um arquivo, mas consiste em várias partes (mais de 200 bibliotecas compartilhadas).

    A compatibilidade com versões anteriores da glibc está sob rastreamento constante. Você pode consultar o relatório do Laboratório ABI para revisão de alterações API/ABI para glibc . O relatório é gerado pelas ferramentas abi-compliance-checker e abi-tracker .

    Para sua pergunta:

    Portanto, se estou substituindo por um libc.so.6 mais recente com versões glibc ABI adicionais dentro dele, como ele quebra aplicativos mais antigos ou leva o sistema à quebra? Ou não...?

    A compatibilidade com Glibc não é infalível, mas acredito que você terá que voltar aos produtos compilados em versões bastante antigas do Linux para quebrá-la. Eu também diria que os produtos podem quebrar não apenas por causa do glibc quando executados em versões do Linux diferentes de onde foram compilados.

    Portanto, a melhor resposta que posso dar é:
    "Não é para quebrar nada e há uma excelente chance de que não quebre".

    Para mais informações, veja:

    • A biblioteca GNU C com interface versionada
    • Notas do verificador de conformidade ABI
    • Política e Diretrizes da ABI
    • 7
  2. somebody
    2019-06-24T01:19:32+08:002019-06-24T01:19:32+08:00

    A resposta direta à sua pergunta é que, se você usar a versão mais recente (não necessariamente suportada). Você não tem garantia de que uma função não foi removida ou alterada de forma que seus outros aplicativos (mais antigos) sejam capazes de lidar com essas alterações. Na verdade, eles não serão capazes de lidar com sua nova versão, se sua nova versão não fornecer "correções" para suportar as chamadas funções "legadas" que foram removidas ou alteradas de forma incompatível .

    Portanto, se você espera sucesso em seu empreendimento, precisará examinar a Changelog(s)versão Glibc "suportada" a seguir. Para determinar com segurança o que mudou . :)

    • 0

relate perguntas

  • Eclipse Oxygen 3a java.lang.NoClassDefFoundError

  • Onde definir a variável PGOPTS no CentOS 7

  • Sintaxe correta em um script para anexar a .bashrc para root

  • Como fazer login no Centos 7 usando RDP do Win10

  • Como alterar permanentemente Ctrl + C para Ctrl + K no CentOS 7?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    Serviço do Windows 10 chamado AarSvc_70f961. O que é e como posso desativá-lo?

    • 2 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Marko Smith

    ssl.SSLCertVerificationError: falha na verificação do certificado [SSL: CERTIFICATE_VERIFY_FAILED]: não foi possível obter o certificado do emissor local (_ssl.c:1056)

    • 4 respostas
  • Marko Smith

    Como posso saber em qual unidade o Windows está instalado?

    • 6 respostas
  • Martin Hope
    Albin Como faço para ativar o WindowsXP agora que o suporte acabou? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch O Windows 10 exclui muitos arquivos minúsculos muito lentamente. Algo pode ser feito para agilizar? 2019-09-23 06:05:43 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    Inter Sys Como Ctrl+C e Ctrl+V funcionam? 2019-05-15 02:51:21 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve