Je veux configurer une nouvelle machine virtuelle avec certains packages spécifiés (nom et version), fournis.
Par exemple apache2 dans la version 2.2.20-1ubuntu1
avec toutes les dépendances. Même s'il existe une nouvelle version de ce package sur les serveurs, celui-ci doit être installé.
La solution doit fonctionner / évoluer avec plusieurs (n) "configurations". Une autre machine virtuelle peut avoir besoin d'une ancienne version d'apache2.
Je connais actuellement certaines possibilités qui installent les packages exacts, mais ne les adaptent pas bien:
- Copier tout requis
*.deb
à chaque machine virtuelle manuellement et entrez: dpkg -i
... -> Peut fonctionner, mais il est très sujet aux erreurs. (Scripts manuels, etc.)
- Créez et utilisez un nouveau référentiel Ubuntu pour chaque configuration. -> Ne fonctionne pas parce que j'aurais besoin de n dépôts.
- Configurez la machine une fois et copiez la VM / créez un instantané. -> Ne fonctionne pas car je devrais stocker n VM.
Mon problème peut être qualifié de gestion des correctifs, mais je ne souhaite pas mettre à jour mes packages avec la version actuelle. Mon objectif est d'installer d'anciens paquets.
Vous pouvez utiliser apt-get
installer une version spécifique du paquet aussi longtemps qu’elle se trouve dans une archive connue par apt. Du apt-get
page de manuel:
Une version spécifique d'un package peut être sélectionnée pour l'installation en suivant le nom du package avec une égale et la version du package à sélectionner. Cela entraînera la localisation et la sélection de cette version pour l'installation. Alternativement, une distribution spécifique peut être sélectionnée en suivant le nom du paquet avec une barre oblique et la version de la distribution ou le nom de l’archive (stable, gelé, instable).
Par exemple, vous pouvez faire:
sudo apt-get install apache2=2.2.20-1ubuntu1
Notez que vous devrez peut-être faire vous-même une résolution de dépendance dans ce cas, mais s'il y a des problèmes, apt-get vous dira ce qui les cause. Sur mon système 11.10, je devrais faire ce qui suit pour que cela fonctionne:
sudo apt-get install apache2=2.2.20-1ubuntu1 \
apache2.2-common=2.2.20-1ubuntu1 \
apache2.2-bin=2.2.20-1ubuntu1 \
apache2-mpm-worker=2.2.20-1ubuntu1
Pour vérifier quelles versions sont disponibles, vous pouvez vérifier via:
sudo apt-cache madison ^apache2
Si ça ne marche pas, pensez à courir sudo apt-get update
avant de mettre à jour la liste des paquets.
Ensuite, copiez la version ou utilisez la syntaxe suivante:
sudo apt-get install apache2=2.2\*
Pour vérifier la version que vous avez installée, exécutez:
dpkg -l 'apache2*' | grep ^i
Je vais développer les réponses précédentes avec d'autres commandes de version pratiques dans le apt
famille. Pour voir quelles versions sont disponibles, exécutez apt-cache policy
:
# apt-cache policy apache2
apache2:
Installed: (none)
Candidate: 2.4.7-1ubuntu4.5
Version table:
2.4.10-1ubuntu1.1~ubuntu14.04.1 0
100 http://us.archive.ubuntu.com/ubuntu/ trusty-backports/main amd64 Packages
2.4.7-1ubuntu4.5 0
500 http://security.ubuntu.com/ubuntu/ trusty-security/main amd64 Packages
2.4.7-1ubuntu4 0
500 http://us.archive.ubuntu.com/ubuntu/ trusty/main amd64 Packages
Ensuite, comme mentionné ailleurs, installez une version spécifique avec apt-get
:
# apt-get install apache2=2.4.7-1ubuntu4.5
...
Vous pouvez maintenant voir quelle version vous avez installée en cours d'exécution apt-cache policy
encore:
# apt-cache policy apache2
apache2:
Installed: 2.4.7-1ubuntu4.5
Candidate: 2.4.7-1ubuntu4.5
Version table:
2.4.10-1ubuntu1.1~ubuntu14.04.1 0
100 http://us.archive.ubuntu.com/ubuntu/ trusty-backports/main amd64 Packages
*** 2.4.7-1ubuntu4.5 0
500 http://security.ubuntu.com/ubuntu/ trusty-security/main amd64 Packages
100 /var/lib/dpkg/status
2.4.7-1ubuntu4 0
500 http://us.archive.ubuntu.com/ubuntu/ trusty/main amd64 Packages
Si vous ne voulez pas que des versions plus récentes soient installées sur les mises à jour, épinglez le package avec apt-mark
:
# apt-mark hold apache2
apache2 set on hold.
Disons qu'une nouvelle version d'apache2 est ajoutée à l'index du package et que votre machine est synchronisée avec apt-get update
. Vous verrez ceci quand vous courrez la prochaine fois apt-get upgrade
:
# apt-get upgrade
Reading package lists... Done
Building dependency tree
Reading state information... Done
Calculating upgrade... Done
The following packages have been kept back:
apache2
0 upgraded, 0 newly installed, 0 to remove and 1 not upgraded.
En pratique, ce n'est pas possible car les anciennes versions ne sont pas conservées dans l'archive, donc à moins d'avoir une copie de l'ancienne version qui se trouve quelque part, vous ne pouvez pas l'installer. Vous devriez vous demander pourquoi vous souhaitez installer une ancienne version en premier lieu. Sur une version stable, la principale raison pour laquelle une nouvelle version est publiée est de corriger une vulnérabilité de sécurité, et vous ne voulez pas utiliser un serveur vulnérable, n'est-ce pas?