web-dev-qa-db-fra.com

erreur apt-get: "SysV: introuvable"

Sur un système Ubuntu 14.04, nous avions installé elasticsearch 2.3.4.

Le système a été mis à niveau vers 16.04

Un apt-get update & upgrade a essayé de passer à elasticsearch 2.4.4.

Mais, nous obtenons maintenant cette erreur:

Preparing to unpack .../elasticsearch_2.4.4_all.deb ...
/var/lib/dpkg/tmp.ci/preinst: 43: /etc/default/elasticsearch: SysV: not found
dpkg: error processing archive /var/cache/apt/archives/elasticsearch_2.4.4_all.deb (--unpack):
 subprocess new pre-installation script returned error exit status 127
/var/lib/dpkg/tmp.ci/postrm: 43: /etc/default/elasticsearch: SysV: not found
dpkg: error while cleaning up:
 subprocess new post-removal script returned error exit status 127
...
Errors were encountered while processing:
 /var/cache/apt/archives/elasticsearch_2.4.4_all.deb
E: Sub-process /usr/bin/dpkg returned an error code (1)

J'ai essayé:

  • apt-get install -f

    dpkg: error processing package elasticsearch (--configure):
     package elasticsearch is not ready for configuration
     cannot configure (current status 'half-installed')
    Processing triggers for libc-bin (2.23-0ubuntu5) ...
    Errors were encountered while processing:
     elasticsearch
    E: Sub-process /usr/bin/dpkg returned an error code (1)
    
  • dpkg --configure -a

    no output
    
  • apt-get install --reinstall elasticsearch

    Preparing to unpack .../elasticsearch_2.4.4_all.deb ...
    /var/lib/dpkg/tmp.ci/preinst: 43: /etc/default/elasticsearch: SysV: not found
    dpkg: error processing archive /var/cache/apt/archives/elasticsearch_2.4.4_all.deb (--unpack):
     subprocess new pre-installation script returned error exit status 127
    /var/lib/dpkg/tmp.ci/postrm: 43: /etc/default/elasticsearch: SysV: not found
    dpkg: error while cleaning up:
     subprocess new post-removal script returned error exit status 127
    Errors were encountered while processing:
     /var/cache/apt/archives/elasticsearch_2.4.4_all.deb
    E: Sub-process /usr/bin/dpkg returned an error code (1)
    
  • dpkg --remove --force-remove-reinstreq elasticsearch

    dpkg: warning: overriding problem because --force enabled:
    dpkg: warning: package is in a very bad inconsistent state; you should
     reinstall it before attempting a removal
    (Reading database ... 157552 files and directories currently installed.)
    Removing elasticsearch (2.3.4) ...
    /var/lib/dpkg/info/elasticsearch.postrm: 43: /etc/default/elasticsearch: SysV: not found
    dpkg: error processing package elasticsearch (--remove):
     subprocess installed post-removal script returned error exit status 127
    Errors were encountered while processing:
     elasticsearch
    
  • dpkg --remove --force-all elasticsearch

    elasticsearch
    dpkg: warning: overriding problem because --force enabled:
    dpkg: warning: package is in a very bad inconsistent state; you should
     reinstall it before attempting a removal
    (Reading database ... 157552 files and directories currently installed.)
    Removing elasticsearch (2.3.4) ...
    /var/lib/dpkg/info/elasticsearch.postrm: 43: /etc/default/elasticsearch: SysV: not found
    dpkg: error processing package elasticsearch (--remove):
     subprocess installed post-removal script returned error exit status 127
    Errors were encountered while processing:
     elasticsearch
    
  • dpkg --purge elasticsearch

    dpkg: error processing package elasticsearch (--purge):
     package is in a very bad inconsistent state; you should
     reinstall it before attempting a removal
    Errors were encountered while processing:
     elasticsearch
    

J'ai même essayé de revenir de systemd à upstart-sysv, mais après un redémarrage, rien n'a changé.

Toutes les idées seront les bienvenues.

2
eugenevd

Dans/etc/default/elasticsearch, il y a une section

SysV init.d
# When executing the init script, this user will be used to run the elasticsearch service.
# The default value is 'elasticsearch' and is declared in the init.d file.
# Note that this setting is only used by the init script. If changed, make sure that
# the configured user can read and write into the data, work, plugins and log directories.
# For systemd service, the user is usually configured in file /usr/lib  /systemd/system/elasticsearch.service
ES_USER=elasticsearch
ES_GROUP=elasticsearch

J'ai commenté toute la section.

L'installation a alors pu se poursuivre.

En fait, cela m'a incité à poser la question "Installer la version du mainteneur du package/Conserver la version du système", qui dans le diff a montré que l'intention de l'installation est de commenter cette section de toute façon.

1
eugenevd