Boa maneira de atualizar vários pacotes com tempo de inatividade mínimo do MySQL

Boa maneira de atualizar vários pacotes com tempo de inatividade mínimo do MySQL

Se eu executar o seguinte comando:

apt list --upgradable

então existem vários pacotes que precisam ser atualizados:

Listing... Done
grub-common/bionic-updates 2.02-2ubuntu8.23 amd64 [upgradable from: 2.02-2ubuntu8.21]
grub-pc/bionic-updates 2.02-2ubuntu8.23 amd64 [upgradable from: 2.02-2ubuntu8.21]
grub-pc-bin/bionic-updates 2.02-2ubuntu8.23 amd64 [upgradable from: 2.02-2ubuntu8.21]
grub2-common/bionic-updates 2.02-2ubuntu8.23 amd64 [upgradable from: 2.02-2ubuntu8.21]
initramfs-tools/bionic-updates,bionic-updates 0.130ubuntu3.12 all [upgradable from: 0.130ubuntu3.11]
initramfs-tools-bin/bionic-updates 0.130ubuntu3.12 amd64 [upgradable from: 0.130ubuntu3.11]
initramfs-tools-core/bionic-updates,bionic-updates 0.130ubuntu3.12 all [upgradable from: 0.130ubuntu3.11]
intel-microcode/bionic-updates,bionic-security 3.20210216.0ubuntu0.18.04.1 amd64 [upgradable from: 3.20201110.0ubuntu0.18.04.2]
libmysqlclient20/bionic-updates,bionic-security 5.7.34-0ubuntu0.18.04.1 amd64 [upgradable from: 5.7.33-0ubuntu0.18.04.1]
libnss-systemd/bionic-updates 237-3ubuntu10.47 amd64 [upgradable from: 237-3ubuntu10.46]
libpam-systemd/bionic-updates 237-3ubuntu10.47 amd64 [upgradable from: 237-3ubuntu10.46]
libsystemd0/bionic-updates 237-3ubuntu10.47 amd64 [upgradable from: 237-3ubuntu10.46]
libudev1/bionic-updates 237-3ubuntu10.47 amd64 [upgradable from: 237-3ubuntu10.46]
linux-generic/bionic-updates,bionic-security 4.15.0.143.130 amd64 [upgradable from: 4.15.0.142.129]
linux-headers-generic/bionic-updates,bionic-security 4.15.0.143.130 amd64 [upgradable from: 4.15.0.142.129]
linux-image-generic/bionic-updates,bionic-security 4.15.0.143.130 amd64 [upgradable from: 4.15.0.142.129]
linux-libc-dev/bionic-updates,bionic-security 4.15.0-143.147 amd64 [upgradable from: 4.15.0-142.146]
mysql-client-5.7/bionic-updates,bionic-security 5.7.34-0ubuntu0.18.04.1 amd64 [upgradable from: 5.7.33-0ubuntu0.18.04.1]
mysql-client-core-5.7/bionic-updates,bionic-security 5.7.34-0ubuntu0.18.04.1 amd64 [upgradable from: 5.7.33-0ubuntu0.18.04.1]
mysql-server/bionic-updates,bionic-updates,bionic-security,bionic-security 5.7.34-0ubuntu0.18.04.1 all [upgradable from: 5.7.33-0ubuntu0.18.04.1]
mysql-server-5.7/bionic-updates,bionic-security 5.7.34-0ubuntu0.18.04.1 amd64 [upgradable from: 5.7.33-0ubuntu0.18.04.1]
mysql-server-core-5.7/bionic-updates,bionic-security 5.7.34-0ubuntu0.18.04.1 amd64 [upgradable from: 5.7.33-0ubuntu0.18.04.1]
systemd/bionic-updates 237-3ubuntu10.47 amd64 [upgradable from: 237-3ubuntu10.46]
systemd-sysv/bionic-updates 237-3ubuntu10.47 amd64 [upgradable from: 237-3ubuntu10.46]
ubuntu-advantage-tools/bionic-updates 27.0.2~18.04.1 all [upgradable from: 17]
udev/bionic-updates 237-3ubuntu10.47 amd64 [upgradable from: 237-3ubuntu10.46]

Anteriormente, quando atualizamos todos os pacotes usando apt upgrade, notamos que o MySQL iria cair e precisávamos esperar até que todos os pacotes fossem atualizados antes que o MySQL fosse reinicializado. Isso levaria vários minutos e todos os sites neste servidor ficariam inativos enquanto aguardava a reinicialização do MySQL.

Portanto, como podemos minimizar o tempo de inatividade do MySQL ao atualizar todos os pacotes no servidor?

Por exemplo, estou pensando em atualizar apenas pacotes MySQL com os seguintes comandos:

apt --only-upgrade install mysql-client-5.7
apt --only-upgrade install mysql-client-core-5.7
apt --only-upgrade install mysql-server
apt --only-upgrade install mysql-server-5.7
apt --only-upgrade install mysql-server-core-5.7

e então, depois que os pacotes MySQL forem atualizados, atualize todos os outros pacotes com um apt upgradecomando simples.

Esta é uma boa abordagem para minimizar o tempo de inatividade do MySQL?

Responder1

Geralmente, o que faço com servidores de produção dedicados a um mecanismo de banco de dados é holdum pacote, evitando que sejam atualizados até que eu tenha tempo suficiente para testar a atualização nos ambientes de desenvolvimento e/ou teste.

Você pode fazer isso aptassim:

sudo apt-mark hold {package}

Isso torna possível instalar todas as outras atualizações de um sistema sem potencialmente quebrar algo no banco de dados. Quando estiver pronto para atualizar o MySQL, você pode remover a retenção assim:

sudo apt-mark unhold {package}

O interessante desse método é que atualizações e patches de segurança podem ser aplicados ao servidor semanalmente, enquanto as atualizações do banco de dados são realizadas apenas durante as janelas de manutenção programadas a cada trimestre. (A menos que algo realmente importante precise ser eliminado, é claro).

informação relacionada