wiki/HowtoDebian/MigrationJessieStretch.md

380 lines
14 KiB
Markdown
Raw Normal View History

2017-07-19 01:45:54 +02:00
---
categories: web
2017-09-12 14:18:42 +02:00
title: Howto Migration Jessie vers Stretch
2017-07-19 01:45:54 +02:00
...
Release Notes amd64 : <http://www.debian.org/releases/stretch/amd64/release-notes/>
2017-07-19 08:30:03 +02:00
## Actions préalables
Sauvegardons localement certaines ressources en cas de problème dans `/home/backup/jessie` :
2017-07-19 08:30:03 +02:00
~~~
# cat before-upgrade.sh
#!/bin/bash
set -x
cd /etc
git add .
git commit -am "Commit balai avant upgrade en Stretch"
mkdir -p /home/backup/jessie/
cd /home/backup/jessie
cp -r /etc ./
mkdir -p var/lib/apt
cp -r /var/lib/dpkg ./var/lib/
cp -r /var/lib/apt/extended_states ./var/lib/apt/
dpkg --get-selections "*" > ./current_packages.txt
uptime > uptime.txt
ps auwx > ps.out
pstree -pan > pstree.out
ss -tanpul > listen.out
2020-02-06 16:33:11 +01:00
netstat -laputen > netstat.out
{ /sbin/iptables -L -n -v; /sbin/iptables -t filter -L -n -v; } > iptables.txt
2017-07-19 08:30:03 +02:00
~~~
## Mise à jour du système
2020-02-06 16:08:55 +01:00
Éditer les dépôts pour remplacer _jessie_ par _stretch_. Nous avons ici par exemple:
2017-07-19 01:45:54 +02:00
~~~
# cat /etc/apt/sources.list
deb http://mirror.evolix.org/debian stretch main
deb http://mirror.evolix.org/debian/ stretch-updates main
deb http://security.debian.org/debian-security stretch/updates main
# cat /etc/apt/sources.list.d/evolix_public.list
deb http://pub.evolix.net/ stretch/
~~~
2020-08-11 18:08:50 +02:00
S'ils sont présent, **désactiver les backports** car plus nécessaire sinon s'ils doivent vraiment être conservés, à mettre dans _/etc/apt/preferences.d/0-backports-defaults_ et s'assurer d'un pinning correct.
2020-07-29 09:11:18 +02:00
> **Note** : Si apt ne vous propose pas de mise à jour, c'est probablement due à un pinning qui désactive la release stretch.
2020-02-06 16:08:55 +01:00
S'il y a ce dépôt, faire:
~~~
# cat /etc/apt/sources.list.d/levert.list
deb http://hwraid.le-vert.net/debian stretch main
~~~
2020-02-06 16:08:55 +01:00
Importons la clé GPG du dépôt pub.evolix.net ( blocage possible avec le firewall/proxy ) :
2017-07-19 01:45:54 +02:00
~~~
2017-09-12 19:44:24 +02:00
# apt-key adv --keyserver keyserver.ubuntu.com --recv 44975278B8612B5D
2017-07-19 01:45:54 +02:00
~~~
2020-02-06 16:08:55 +01:00
> Si ça ne marche pas alors :
2017-09-12 19:44:24 +02:00
>
> ~~~
> # wget -O- "http://keyserver.ubuntu.com/pks/lookup?op=get&search=0x44975278B8612B5D" | apt-key add -
> ~~~
2017-07-19 01:45:54 +02:00
2020-02-06 16:08:55 +01:00
Puis mettre à jour le cache APT:
2017-07-19 01:45:54 +02:00
~~~
# apt update
~~~
2017-05-18 16:52:36 +02:00
2017-07-19 08:11:15 +02:00
Commencer par télécharger l'ensemble des paquets qui devront être installés (afin de limiter le temps effectif d'installation).
~~~
# apt dist-upgrade --download-only
~~~
Avant de poursuivre, essayons de voir si le service gérant les unités fonctionnent et peuvent être mis à jour.
Tout d'abord on vérifie l'état de systemd :
2020-08-11 18:08:50 +02:00
~~~
# systemctl status
# systemctl --failed
# ps -p 1 www
2020-08-11 18:08:50 +02:00
~~~
Si le process n'est pas dans un état normal, il est conseillé de redémarrer le système avant de poursuivre.
Vérifions également que les commandes `insserv` ne se bloquent pas avec le service `mailgraph` que l'on install partout :
~~~
# insserv mailgraph
~~~
2020-08-11 18:08:50 +02:00
Il faut vérifier que le process ne se bloque pas avec `ps auwwwx |grep insserv`. Si c'est le cas, il est conseillé de redémarrer le système avant de poursuivre.
2020-08-11 18:08:50 +02:00
Appliquer les mises à jour triviales :
2017-07-19 08:11:15 +02:00
~~~
# apt upgrade
~~~
2020-08-11 18:08:50 +02:00
Attention, s'il y a Mysql/MariaDB, il faut créer l'override de l'unité systemd **avant** :
~~~
# mkdir -p /etc/systemd/system/mariadb.service.d/
2019-10-02 11:26:23 +02:00
# wget "https://gitea.evolix.org/evolix/ansible-roles/raw/branch/stable/mysql/templates/mariadb.systemd.j2" -O /etc/systemd/system/mariadb.service.d/evolinux.conf
# systemctl daemon-reload
~~~
Il faut également stopper les instances Mysql/MariaDB supplémentaires car non gérées lors de l'upgrade (et cela va casser avec *There is a MySQL server running, but we failed in our attempts to stop it*) :
~~~
# mysqld_multi stop
~~~
2019-01-03 14:01:24 +01:00
Ensuite, appliquer les mises à jour non triviales (nécessitant des changements de paquets dépendants, des suppressions…) afin d'avoir un œil plus précis sur ce qui sera fait, avant de valider :
2017-07-19 08:11:15 +02:00
~~~
# apt dist-upgrade
~~~
2019-01-03 14:01:24 +01:00
Puis lancer le nettoyage des vieux packages en lisant attentivement la liste… en cas de doute, réinstaller le paquet !
2017-08-23 09:29:02 +02:00
2019-01-03 14:01:24 +01:00
~~~
# apt remove
# apt install acl php7.0-soap php-soap php-net-url php-net-dime php-http-request etc.
~~~
Enfin, il faut redémarrer sur le nouveau noyau Linux installé :
~~~
# reboot
~~~
## APT
APT utilise maintenant l'utilisateur *_apt* pour certaines de ses fonctionnalités (ex. téléchargement des paquets), les dossiers `/etc/apt/` et `/var/cache/apt/` doivent donc être en *755* :
2017-08-23 09:29:02 +02:00
~~~
2019-01-03 14:01:24 +01:00
# chmod 755 /etc/apt /var/cache/apt
2017-08-23 09:29:02 +02:00
~~~
2019-01-03 14:01:24 +01:00
Les fichiers `/etc/apt/apt.conf.d/10evolix` et `/etc/apt/apt.conf.d/80evolinux` ont été concaténés en un seul fichier `/etc/apt/apt.conf.d/z-evolinux.conf` :
2018-08-17 13:34:16 +02:00
~~~
# cat /etc/apt/apt.conf.d/10evolix /etc/apt/apt.conf.d/80evolinux >/etc/apt/apt.conf.d/z-evolinux.conf
# rm /etc/apt/apt.conf.d/10evolix /etc/apt/apt.conf.d/80evolinux
2020-02-06 17:28:52 +01:00
# cat /etc/apt/apt.conf.d/z-evolinux.conf
APT::Install-Recommends "0";
APT::Install-Suggests "0";
DPkg {
Pre-Invoke {
"mount -oremount,exec /tmp && mount -oremount,rw /usr || true";
};
Post-Invoke {
"mount -oremount /tmp && mount -oremount /usr || exit 0";
};
}
2018-08-17 13:34:16 +02:00
~~~
2020-02-06 17:41:07 +01:00
`apt-listchanges` et `aptitude`ne sont plus utilisés, ils doivent être désinstallé.
2017-09-12 17:29:25 +02:00
2019-11-05 20:41:04 +01:00
## PHP
2020-01-06 12:28:48 +01:00
Il faut forcer le passage à PHP 7.0 :
2017-09-12 17:29:25 +02:00
~~~
2020-10-14 04:24:03 +02:00
# apt remove libapache2-mod-php5 php5-common && a2enmod php7.0 && /etc/init.d/apache2 restart
2017-09-12 17:29:25 +02:00
~~~
2020-01-06 12:28:48 +01:00
Puis nettoyer les anciens paquets php5-* et réinstaller les paquets PHP 7.0 correspondants.
Il faut également reprendre les directives de configuration de PHP 5.6 et les reporter en PHP 7.0 : memory_limit, max_*, etc.
2019-11-05 20:41:04 +01:00
## Apache
La configuration spécifique d'Apache est maintenant faite dans les 2 fichiers _/etc/apache2/conf-available/z-evolinux-defaults.conf_ et _/etc/apache2/conf-available/zzz-evolinux-custom.conf_. Les fichiers de configuration standards tel que _apache.conf_ doivent donc être ceux de l'_upstream_ et les modifications éventuelles ajoutées dans _/etc/apache2/conf-available/zzz-evolinux-custom.conf_.
2018-08-17 13:20:10 +02:00
### mod_proxy_wstunnel
Le comportement du module **mod_proxy_wstunnel** semble avoir changé, avant il supportait une sorte de compatibilité HTTP/WS,
2018-08-17 13:21:34 +02:00
désormais il renverra une erreur `AH01144: No protocol handler was valid for the URL /foo/bar. If you are using a DSO version of mod_proxy, make sure the proxy submodules are included in the configuration using LoadModule.`si on lui parle en HTTP, cf <https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=880195>
2018-08-17 13:20:10 +02:00
Le contournement est d'adapter la réponse en fonction des types de requêtes, du genre :
~~~
RewriteCond %{REQUEST_URI} ^/socket.io [NC]
RewriteCond %{QUERY_STRING} transport=websocket [NC]
RewriteRule /(.*) ws://127.0.0.1:8080/$1 [P,L]
RewriteCond %{REQUEST_URI} ^/socket.io [NC]
RewriteRule /(.*) http://127.0.0.1:8080/$1 [P,L]
RewriteCond %{REQUEST_URI} ^/foo/bar [NC]
RewriteRule /(.*) http://127.0.0.1:8080/$1 [P,L]
RewriteRule /(.*) ws://127.0.0.1:8080/$1 [P,L]
~~~
2017-09-12 17:31:59 +02:00
## PHPMyAdmin
Il faut rajouter /usr/share/php/php-php-gettext a la directive open_basedir de /etc/phpmyadmin/apache.conf.
2017-08-23 14:09:44 +02:00
## Xorg
2017-05-18 16:52:36 +02:00
2017-07-19 08:48:50 +02:00
`startx` ou `startxfce4` donne : `parse_vt_settings /dev/tty0 (permission denied)`
2017-05-18 16:52:36 +02:00
2017-07-19 08:48:50 +02:00
Un contournement : `startxfce4 -- :1 vt1`
2017-05-18 16:52:36 +02:00
## Vim
2017-07-19 08:43:15 +02:00
par défaut, si pas de `~/.vimrc` Vim charge plein de features moisies (mouse, etc.)
2017-05-18 16:52:36 +02:00
décommenter dans `/etc/vim/vimrc` : `let g:skip_defaults_vim = 1`
## log2mail
La configuration de `log2mail` est maintenant répartie dans plusieurs fichier dépendamment des services surveillés : _/etc/log2mail/config/mysql.conf_, _/etc/log2mail/config/apache_ et _/etc/log2mail/config/squid.conf_
`log2mail` est lancé par une unité systemd et non plus par un script sysV init, à mettre dans _/etc/systemd/system/log2mail.service_.
## sudo
L'attribution des droits sudo des utilisateurs admin se fait à travers le groupe _evolinux-sudo_ (à créer). Le fichier _/etc/sudoers.d/evolinux_ est à mettre à jour en conséquence.
Les utilisateurs admin sont aussi à ajouter au groupe _adm_.
## MySQL/MariaDB
MariaDB est la version utilisée par défaut au lieu de Oracle MySQL qui n'est plus du tout inclus (il est possible d'avoir Oracle MySQL 5.7 via un repository extérieur mais on déconseille sauf si complètement bloquant).
La migration va conserver un fichier `/etc/mysql/my.cnf.migrated` (`/etc/mysql/my.cnf` est un lien symbolique vers `/etc/alternatives/my.cnf` lui-même un lien symbolique vers `/etc/mysql/my.cnf.migrated`).
ATTENTION : `/etc/mysql/mariadb.conf.d/*` n'est pas pris en compte avec cette ancienne configuration ! Il ne faut pas déplacer les fichiers de configuration et les laisser dans `/etc/mysql/mariadb.conf.d/*`?
2017-11-08 10:33:53 +01:00
Et attention, les fichiers de configuration doivent être en 644, donc il est conseillé de faire :
~~~
# chmod 644 /etc/mysql/conf.d/*.cnf
~~~
Il faut avoir un override de l'unité systemd :
~~~
# mkdir -p /etc/systemd/system/mariadb.service.d/
# wget "https://forge.evolix.org/projects/ansible-roles/repository/revisions/stable/raw/mysql/templates/mariadb.systemd.j2" -O /etc/systemd/system/mariadb.service.d/evolinux.conf
# systemctl daemon-reload
~~~
2017-11-08 10:33:36 +01:00
> **Note** : C'est très important, notamment si vous avez un paramétrage qui utilise un chemin dans /home.
Attention, le moteur FEDERATED n'est plus activé par défaut (l'option `federated` dans la configuration doit ainsi être retiré).
Si on veut l'activer, voir <https://wiki.evolix.org/HowtoMySQL/Troubleshooting#storage-engine-federated>
La directive *log_slow_queries* n'est désormais plus du tout supportée : il faut utiliser obligatoirement *slow_query_log_file*.
Après la mise à jour, bien penser regarder les logs MySQL, il est parfois nécessaire de faire manuellement un `mysql_upgrade` si c'est indiqué dans les logs.
2018-11-02 11:23:19 +01:00
### Instances MySQL/MariaDB
Si vous utilisez des instances, il est désormais obligatoire d'avoir une directive *log_error* du type :
~~~
log_error = /var/log/mysqld1/error.log
~~~
## PHP
La configuration spécifique doit être faite dans les 2 fichiers de configuration _/etc/php/7.0/cli/conf.d/z-evolinux-defaults.ini_ et _/etc/php/7.0/cli/conf.d/zzz-evolinux-custom.ini_.
Pour récupérer les anciennes configurations des pool FPM, il suffit simplement de les copier et de redémarrer le service `php7.0-fpm`.
~~~
# cp /etc/php5/fpm/pool.d/* /etc/php/7.0/fpm/pool.d/
~~~
2018-10-10 16:16:25 +02:00
Les modules PHP ne sont pas automatiquement mis a jour car les noms ne sont plus les mêmes (ex. php5-gd => php-gd).
Il faut donc installer les nouveaux modules a la main : `apt install php-gd`.
## Squid
La configuration est éclatée dans plusieurs fichier de configuration : _/etc/squid/evolinux-defaults.conf_, _/etc/squid/evolinux-defaults.conf_, _/etc/squid/evolinux-acl.conf_, _/etc/squid/evolinux-httpaccess.conf_ et _/etc/squid/evolinux-custom.conf_. La liste blanche des sites se trouve dans _/etc/squid/evolinux-whitelist-defaults.conf_ et _/etc/squid/evolinux-whitelist-custom.conf_.
Il faut mettre à jour le fichier _/etc/default/squid_ pour que la directive _CONFIG_ pointe sur _/etc/squid/evolinux-defaults.conf_.
Le fichier _squid.conf_ n'est plus utilisé du tout.
## OpenDKIM
Le fichier `/etc/default/opendkim` n'est désormais plus pris en compte
puisqu'OpenDKIM a son unité systemd. Les éventuelles directives présentent dans
ce fichier, et notamment la socket, doivent se retrouver dans
`/etc/opendkim.conf` :
Par exemple, `SOCKET="inet:8889@127.0.0.1"` dans le fichier _default_ devient
`Socket inet:8889@[127.0.0.1]` dans le fichier de conf.
Pour les autres options, voir `opendkim.conf(5)`.
L'option `PidFile` doit obligatoirement être présente dans la conf (ce n'est
pas le cas par défaut), car l'unité systemd telle que fournie par Debian
s'attend à ce que le fichier `/var/run/opendkim/opendkim.pid` soit présent.
Autrement un `systemctl start opendkim` (ou équivalent sysV init) reste bloqué
et finit par générer un timeout, bien que le process soit bien lancé :
```
PidFile /var/run/opendkim/opendkim.pid
```
2017-12-07 21:28:11 +01:00
## Xchat -> hexchat
Xchat2 est remplacé par hexchat.
2017-12-07 21:39:37 +01:00
Pour conserver la configuration, **avant** de lancer hexchat, faire quelques manipulations du type :
2017-12-07 21:28:11 +01:00
~~~
$ cp -pr .xchat2/ .config/hexchat/
$ mv .config/hexchat/xchat.conf .config/hexchat/hexchat.conf
$ mv .config/hexchat/xchat2logs .config/hexchat/logs
~~~
## Evoadmin-web
Pour mettre à jour vers la nouvelle version d'evoadmin-web, il faut se mettre sur la branche master et faire un git pull, avec l'utilisateur evoadmin:
~~~
$ su - evoadmin
evoadmin@hostname:~$ git checkout master
evoadmin@hostname:~$ git pull
~~~
Ensuite il faut ajouter un utilisateur, en éditant le fichier */home/evoadmin/www/conf/config.local.php*, avec la configuration suivante :
~~~
$localconf['logins']['foo'] = 'd5d3c723fb82cb0078f399888af7820d02e52751bb64597a8c20ebaba8ba4303';
~~~
Il faut généré un sha256 pour le mot de passe avec la commande suivante :
~~~
$ echo -n password |sha256sum
~~~
2019-01-11 10:02:57 +01:00
## Evoadmin-mail
2020-07-06 17:39:53 +02:00
Si evoadmin-mail n'as pas été mis à jour pendant la migration de Wheezy vers Jessie => [https://wiki.evolix.org/HowtoDebian/MigrationWheezyJessie]()
2019-01-11 10:02:57 +01:00
## Fail2Ban
On passe de Fail2Ban 0.8 à 0.9, et il y a un certain nombre de changements :
- la jail _ssh_ est renommée en _sshd_ : **attention, cela peut avoir des conséquences importantes, il faut adapter sa configuration spécifique qui utilise cette jail !**
- pour cette jail concernant SSH, elle définissant `maxretry = 6`, ce n'est plus le cas donc cela change et revient au paramètre par défaut, à savoir `maxretry = 5` en Debian 9
- le paramètre par défaut `maxretry = 3` passe à `maxretry = 5`
## mytop
Installer le paquet *libconfig-inifiles-perl* pour éviter l'erreur :
~~~
Can't locate Config/IniFiles.pm in @INC (you may need to install the Config::IniFiles module) (@INC contains: /etc/perl /usr/local/lib/x86_64-linux-gnu/perl/5.24.1 /usr/local/share/perl/5.24.1 /usr/lib/x86_64-linux-gnu/perl5/5.24 /usr/share/perl5 /usr/lib/x86_64-linux-gnu/perl/5.24 /usr/share/perl/5.24 /usr/local/lib/site_perl /usr/lib/x86_64-linux-gnu/perl-base) at /usr/bin/mytop line 18.
BEGIN failed--compilation aborted at /usr/bin/mytop line 18.
~~~
2020-08-11 17:47:13 +02:00
## lsb_release
Celui-ci est utilisé par quelques programmes (dont des modules LSB) qui ont besoin de connaitre la version source d'une distribution. Aujourd'hui, on utilise dans la majorité des cas le fichier /etc/debian_version a la place de /etc/lsb-release qui peut être supprimé.