É amplamente aceito que os desenvolvedores devem testar as atualizações através de um site intermediário antes de liberá-las para o servidor ativo, no entanto, uma vez que as atualizações de desenvolvimento exigem modificações no Wordpress DB, as coisas ficam complicadas, pois os usuários no site ativo também atualizam o banco de dados.
O único fluxo (confuso) que posso imaginar é o seguinte:
- Teste em um servidor local (WAMP, XAMP, etc)
- Quando estiver pronto para implantar, coloque o site ativo no modo de manutenção
- Site ativo de backup (duplicador, sqldump, etc.)
- Crie um clone do site ativo bloqueado para o site intermediário
- Carregar modificações do ambiente local para o site intermediário
- Teste o site intermediário
- Envie o site de preparação para a exibição.
- Remover modo de manutenção
Desvantagens do fluxo acima:
- os tempos de inatividade podem ser maiores do que o esperado para os usuários enquanto o desenvolvedor está testando cuidadosamente as atualizações no site de preparação;
- pode exigir gerenciamento manual de modificações: por exemplo, layouts de construtor de páginas originais ou de site são armazenados no banco de dados; portanto, uma vez que um layout é modificado, ele deve ser importado manualmente no site temporário; nesse caso, pode ser adequado simplesmente soltar e importar páginas no site intermediário e, se estiver funcionando, importá-las no site ativo
Gostaria de saber se existe uma maneira melhor e mais automatizada de conseguir isso.
O que você acha?
EDIT, conforme solicitado, algumas soluções foram propostas no passado, mas nenhuma oferece uma solução definitiva:
- 9/2010 - Sincronização de banco de dados entre desenvolvimento / preparação e produção
- 12/2011 - Implantando plug-ins atualizados ou novos que modificam a tabela wp_options
- 9/2014 - Como fazer upload de alterações locais em um servidor ativo sem substituir novas postagens / páginas?
- 1/2015 - Como manter os blogs do site wordpress em produção e preparação?