Por que os upgrades do apache2 removem e não reinstalam o libapache2-mod-php5?

1

Observamos repetidamente que quando uma atualização apache2 chega e é instalada, o pacote libapache2-mod-php5 é removido e não é reinstalado posteriormente.

Devemos reinstalar o libapache2-mod-php5 manualmente para restaurar a funcionalidade do nosso servidor web.

Por favor, veja o seguinte githubist, é uma seção contígua do dpkg.log do nosso servidor mostrando a atualização de 14 de novembro de 2011 para apache2: link
inclui

2011-11-14 11:22:18 remove libapache2-mod-php5 5.3.2-1ubuntu4.10 5.3.2-1ubuntu4.10

Este é um problema conhecido? Outras pessoas também veem isso? Não consegui encontrar nenhum relatório de bugs da barra de lançamento.

Detalhes da plataforma:

$ lsb_release -ds
Ubuntu 10.04.3 LTS
$ uname -srvm
Linux 2.6.38-12-virtual #51~lucid1-Ubuntu SMP Thu Sep 29 20:27:50 UTC 2011 x86_64
$ dpkg -l | awk  '/ii.*apache/ {print $2 " " $3 }'
apache2 2.2.14-5ubuntu8.7
apache2-mpm-prefork 2.2.14-5ubuntu8.7
apache2-utils 2.2.14-5ubuntu8.7
apache2.2-bin 2.2.14-5ubuntu8.7
apache2.2-common 2.2.14-5ubuntu8.7
libapache2-mod-authnz-external 3.2.4-2+squeeze1build0.10.04.1
libapache2-mod-php5 5.3.2-1ubuntu4.10

Obrigado

Em um nível alto, o processo de atualização se parece com:

package package_name do
        action :upgrade
        case node[:platform]
        when 'centos', 'redhat', 'scientific'
                options '--disableplugin=fastestmirror'
        when 'ubuntu'
                options '-o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold"'
        end
end

Mas em um nível mais baixo

        def install_package(name, version)
          run_command_with_systems_locale(
            :command => "apt-get -q -y#{expand_options(@new_resource.options)} install #{name}=#{version}",
            :environment => {
              "DEBIAN_FRONTEND" => "noninteractive"
            }
          )
        end

        def upgrade_package(name, version)
          install_package(name, version)
        end

Então, o Chef está usando "instalar" para fazer "atualização".

Esse tipo de pergunta muda para "como o apt-get safe-upgrade" se lembra de reinstalar o libapache-mod-php5?

A sequência exata de pacotes que acionaram isso foi:

apache2
apache2-mpm-prefork
apache2-mpm-worker
apache2-utils
apache2.2-bin
apache2.2-common

Mas o código está tentando executar verificações para garantir que os pacotes nessa lista já estejam instalados antes de tentar "atualizá-los".

case node[:platform]
when 'debian', 'centos', 'fedora', 'redhat', 'scientific', 'ubuntu'
        # first primitive way is to define the updates in the recipe
        # data bags will be used later
        %w/
               apache2
               apache2-mpm-prefork
               apache2-mpm-worker
               apache2-utils
               apache2.2-bin
               apache2.2-common
        /.each{ |package_name|
                Chef::Log.debug("is #{package_name} among local packages available for changes?")
                next unless node[:packages][:changes].keys.include?(package_name)

                Chef::Log.debug("is #{package_name} available for upgrade?")
                next unless node[:packages][:changes][package_name][:action] == 'upgrade'

                package package_name do
                        action :upgrade
                        case node[:platform]
                        when 'centos', 'redhat', 'scientific'
                                options '--disableplugin=fastestmirror'
                        when 'ubuntu'
                                options '-o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold"'
                        end
                end

                tag('upgraded')
        }

        # after upgrading everything, run yum cache updater
        if tagged?('upgraded')
                # Remove old orphaned dependencies and kernel images and kernel headers etc.
                # Remove cached deb files.
                case node[:platform]
                when 'ubuntu'
                        execute 'apt-get -y autoremove'
                        execute 'apt-get clean'
                # Re-check what updates are available soon.
                when 'centos', 'fedora', 'redhat', 'scientific'
                        node[:packages][:last_time_we_looked_at_yum] = 0
                end
                untag('upgraded')
        end
end

Mas está claro que falha porque o dpkg.log tem

2011-11-14 11:22:25 install apache2-mpm-worker  2.2.14-5ubuntu8.7

em um sistema que atualmente não possui apache2-mpm-worker. Vou ter que discutir isso com o autor, obrigado novamente.

    
por nutznboltz 15.11.2011 / 22:28

1 resposta

1

Provavelmente você está executando a versão mpm-worker do apache2, que não gosta de libapache2-mod-php5.

dpkg -l | grep apache2-mpm

Você pode querer usar o apache2-mpm-prefork, o que funciona melhor com o mod_php5

    
por delimiter 15.11.2011 / 23:42