*O autor selecionou a COVID-19 Relief Fund​​​​​ para receber uma doação como parte do programa Write for DOnations.*

Introdução

O servidor Web do Apache usa hosts virtuais para gerenciar vários domínios em uma única instância. De igual modo, o PHP-FPM utiliza um daemon para gerenciar várias versões de PHP em uma única instância. Você pode usar o Apache e o PHP-FPM juntos para hospedar vários aplicativos Web em PHP, cada qual usando uma versão diferente de PHP, porém todas as versões em um mesmo servidor e ao mesmo tempo. Isso é útil, pois diferentes aplicativos exigem diferentes versões de PHP. Porém, algumas pilhas de servidor – como uma pilha LAMP configurada regularmente – podem gerenciar somente uma versão de PHP. A combinação do Apache com o PHP-FPM também é uma solução mais econômica do que hospedar cada aplicativo em sua própria instância.

O PHP-FPM também oferece opções de configuração para o acesso ao stderr e ao stdout, reinicializações de emergência e geração de processos adaptáveis, o que é útil para sites muito carregados. Na verdade, o uso do Apache com o PHP-FPM é uma das melhores pilhas para a hospedagem de aplicativos PHP, especialmente em relação ao desempenho.

Neste tutorial, você configurará dois sites PHP em uma única instância. Cada site usará seu próprio domínio e cada domínio implantará sua própria versão de PHP. O primeiro,<^>site1.your_domain<^>, implantará o PHP 7.0. O segundo, <^>site2.your_domain<^>, implantará o PHP 7.2.

Pré-requisitos

php illustration for: Pré-requisitos

Passo 1 — Instalando as versões 7.0 e 7.2 do PHP com o PHP-FPM

Com os pré-requisitos concluídos, você instalará as versões 7.0 e 7.2 do PHP, além do PHP-FPM e várias extensões adicionais. Mas para isso, primeiro será necessário adicionar o repositório sury php ao seu sistema.

Primeiro, instale os diversos pacotes necessários, entre eles o curl, o wget e o gnupg2:

				
					
sudo apt-get install curl wget gnupg2 ca-certificates lsb-release apt-transport-https -y

				
			

Os pacotes acima permitirão, de maneira segura, o seu acesso ao repositório sury php. O sury php é um repositório de terceiros ou um PPA (arquivo de pacote pessoal). Ele oferece o PHP nas versões 7.4, 7.3, 7.2, 7.1 e 7.0 para o sistema operacional Debian. Este repositório também oferece versões mais recentes do PHP do que aquelas encontradas nos repositórios oficiais do Debian 10, e permitirá que você instale várias versões do PHP no mesmo sistema.

Em seguida, importe a chave do pacote:

				
					
wget https://packages.sury.org/php/apt.gpg

sudo apt-key add apt.gpg

				
			

Agora, adicione o repositório sury php ao seu sistema:

				
					
echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" | sudo tee /etc/apt/sources.list.d/php7.list

				
			

Atualize o repositório:

				
					
sudo apt-get update -y

				
			

Em seguida, instale o php7.0, o php7.0-fpm, o php7.0-mysql, o libapache2-mod-php7.0 e o libapache2-mod-fcgid com os comandos a seguir:

				
					
sudo apt-get install php7.0 php7.0-fpm php7.0-mysql libapache2-mod-php7.0 libapache2-mod-fcgid -y

				
			
  • O php7.0 é um metapacote que pode ser utilizado para executar aplicativos PHP.
  • O php7.0-fpm fornece o interpretador do gerenciador de processos rápidos que funciona como um daemon e recebe solicitações do Fast/CGI.
  • O php7.0-mysql conecta o PHP ao banco de dados MySQL.
  • O libapache2-mod-php7.0 fornece o módulo PHP para o servidor Web do Apache.
  • O libapache2-mod-fcgid contém um mod_fcgid que inicia uma série de instâncias do programa CGI para tratar solicitações simultâneas.

Agora, repita o processo para a versão PHP 7.2. Instale o php7.2, o php7.2-fpm, o php7.2-mysql e o libapache2-mod-php7.2.

				
					
sudo apt-get install php7.2 php7.2-fpm php7.2-mysql libapache2-mod-php7.2 -y

				
			

Após instalar ambas as versões do PHP, inicie o serviço php7.0-fpm:

				
					
sudo systemctl start php7.0-fpm

				
			

Em seguida, verifique o status do serviço php7.0-fpm:

				
					
sudo systemctl status php7.0-fpm

				
			

Você verá o seguinte resultado:

				
					
[secondary_label Output]

● php7.0-fpm.service - The PHP 7.0 FastCGI Process Manager

   Loaded: loaded (/lib/systemd/system/php7.0-fpm.service; enabled; vendor preset: enabled)

   Active: &lt;^&gt;active&lt;^&gt; (running) since Sat 2020-04-04 08:51:47 UTC; 1min 17s ago

     Docs: man:php-fpm7.0(8)

 Main PID: 13016 (php-fpm7.0)

   Status: "Processes active: 0, idle: 2, Requests: 0, slow: 0, Traffic: 0req/sec"

    Tasks: 3 (limit: 1149)

   Memory: 19.1M

   CGroup: /system.slice/php7.0-fpm.service

           ├─13016 php-fpm: master process (/etc/php/7.0/fpm/php-fpm.conf)

           ├─13017 php-fpm: pool www

           └─13018 php-fpm: pool www



Apr 04 08:51:47 debian10 systemd[1]: Starting The PHP 7.0 FastCGI Process Manager...

Apr 04 08:51:47 debian10 systemd[1]: Started The PHP 7.0 FastCGI Process Manager.



				
			

Repetindo esse processo, agora inicie o serviço php7.2-fpm:

				
					
sudo systemctl start php7.2-fpm

				
			

E, em seguida, verifique o status do serviço php7.2-fpm:

				
					
sudo systemctl status php7.2-fpm

				
			

Você verá o seguinte resultado:

				
					
[secondary_label Output]

● php7.2-fpm.service - The PHP 7.2 FastCGI Process Manager

   Loaded: loaded (/lib/systemd/system/php7.2-fpm.service; enabled; vendor preset: enabled)

   Active: &lt;^&gt;active&lt;^&gt; (running) since Sat 2020-04-04 08:52:52 UTC; 1min 32s ago

     Docs: man:php-fpm7.2(8)

  Process: 22207 ExecStartPost=/usr/lib/php/php-fpm-socket-helper install /run/php/php-fpm.sock /etc/php/7.2/fpm/pool.d/www.conf 72 (code=exite

 Main PID: 22204 (php-fpm7.2)

   Status: "Processes active: 0, idle: 2, Requests: 0, slow: 0, Traffic: 0req/sec"

    Tasks: 3 (limit: 1149)

   Memory: 12.0M

   CGroup: /system.slice/php7.2-fpm.service

           ├─22204 php-fpm: master process (/etc/php/7.2/fpm/php-fpm.conf)

           ├─22205 php-fpm: pool www

           └─22206 php-fpm: pool www



Apr 04 08:52:52 debian10 systemd[1]: Starting The PHP 7.2 FastCGI Process Manager...

Apr 04 08:52:52 debian10 systemd[1]: Started The PHP 7.2 FastCGI Process Manager.



				
			

Por fim, você deve habilitar vários módulos para que o seu serviço Apache2 possa funcionar com várias versões do PHP:

				
					
sudo a2enmod actions fcgid alias proxy_fcgi

				
			
  • As actions são usadas para executar scripts de CGI baseados no tipo de mídia, ou método de solicitação.
  • O fcgid é uma alternativa de alto desempenho ao mod_cgi, que inicia um número suficiente de instâncias do programa CGI para processar solicitações simultâneas.
  • O alias dá suporte ao mapeamento de diferentes partes do sistema de arquivos do host na árvore de documentos e ao redirecionamento da URL.
  • O proxy_fcgi permite que o Apache encaminhe solicitações para o PHP-FPM.

Agora, reinicie o serviço do Apache para aplicar suas alterações:

				
					
sudo systemctl restart apache2

				
			

Neste ponto, você instalou duas versões do PHP em seu servidor. Em seguida, você criará uma estrutura de diretório para cada site que deseja implantar.

Passo 2 — Criando estruturas de diretório para ambos os sites

Nesta seção, você criará um diretório para o diretório base e uma página de índice para cada um dos seus dois sites.

Primeiro, crie os diretórios de diretório base para os dois sites, o <^>site1.your_domain<^> e o <^>site2.your_domain<^>:

				
					
sudo mkdir /var/www/&lt;^&gt;site1.your_domain&lt;^&gt;

sudo mkdir /var/www/&lt;^&gt;site2.your_domain&lt;^&gt;

				
			

Por padrão, o servidor Web do Apache funciona como um usuário www-data e um grupo www-data. Para garantir que você tenha a propriedade e as permissões corretas de seus diretórios base de seu site, execute os comandos a seguir:

				
					
sudo chown -R www-data:www-data /var/www/&lt;^&gt;site1.your_domain&lt;^&gt;

sudo chown -R www-data:www-data /var/www/&lt;^&gt;site2.your_domain&lt;^&gt;

sudo chmod -R 755 /var/www/&lt;^&gt;site1.your_domain&lt;^&gt;

sudo chmod -R 755 /var/www/&lt;^&gt;site2.your_domain&lt;^&gt;

				
			

Em seguida, você criará um arquivo info.php dentro do diretório base de cada site. Isso exibirá as informações da versão do PHP de cada site. Comece com o <^>site1<^>:

				
					
sudo nano /var/www/&lt;^&gt;site1.your_domain&lt;^&gt;/info.php

				
			

Adicione a linha a seguir:

				
					
[label /var/www/site1.your_domain/info.php]

&lt;?php phpinfo(); ?&gt;

				
			

Salve e feche o arquivo. Agora, copie o arquivo info.php que você criou para o <^>site2<^>:

				
					
sudo cp /var/www/&lt;^&gt;site1.your_domain&lt;^&gt;/info.php /var/www/&lt;^&gt;site2.your_domain&lt;^&gt;/info.php

				
			

Agora, o seu servidor Web deverá ter os diretórios de documento base que cada site exige para fornecer dados aos visitantes. Em seguida, você configurará seu servidor Web do Apache para funcionar com duas versões diferentes do PHP.

Passo 3 — Configurando o Apache para ambos os sites

Nesta seção, você criará dois arquivos de configuração do host virtual. Isso permitirá que seus dois sites funcionem simultaneamente com duas versões diferentes do PHP.

Para que o Apache distribua esse conteúdo, é necessário criar um arquivo de host virtual com as diretivas corretas. Em vez de modificar o arquivo de configuração padrão, localizado em /etc/apache2/sites-available/000-default.conf, você criará dois novos arquivos dentro do diretório /etc/apache2/sites-available/.

Primeiro,crie um novo arquivo de configuração de host virtual para o site <^>site1.your_domain<^>. Aqui, você direcionará o Apache a renderizar o conteúdo usando o php7.0:

				
					
sudo nano /etc/apache2/sites-available/&lt;^&gt;site1.your_domain&lt;^&gt;.conf

				
			

Adicione o conteúdo a seguir: Verifique se o caminho do diretório do site, o nome do servidor e a versão de PHP correspondem à sua configuração:

				
					
[label /etc/apache2/sites-available/site1.your_domain.conf]



&lt;VirtualHost *:80&gt;

     ServerAdmin admin@&lt;^&gt;site1.your_domain&lt;^&gt;

     ServerName &lt;^&gt;site1.your_domain&lt;^&gt;

     DocumentRoot /var/www/&lt;^&gt;site1.your_domain&lt;^&gt;

     DirectoryIndex info.php



     &lt;Directory /var/www/&lt;^&gt;site1.your_domain&lt;^&gt;&gt;

        Options Indexes FollowSymLinks MultiViews

        AllowOverride All

        Order allow,deny

        allow from all

     &lt;/Directory&gt;



    &lt;FilesMatch \.php$&gt;

      # For Apache version 2.4.10 and above, use SetHandler to run PHP as a fastCGI process server

      SetHandler "proxy:unix:/run/php/&lt;^&gt;php7.0&lt;^&gt;-fpm.sock|fcgi://localhost"

    &lt;/FilesMatch&gt;



     ErrorLog ${APACHE_LOG_DIR}/&lt;^&gt;site1.your_domain&lt;^&gt;_error.log

     CustomLog ${APACHE_LOG_DIR}/&lt;^&gt;site1.your_domain&lt;^&gt;_access.log combined

&lt;/VirtualHost&gt;

				
			

Neste arquivo, você atualizou o DocumentRoot para o seu novo diretório e o ServerAdmin para um e-mail que o administrador do site your_domain pode acessar. Você também atualizou o ServerName, o qual estabelece o domínio base dessa configuração do host virtual, bem como adicionou uma diretiva SetHandler para executar o PHP como um servidor de processos fastCGI.

Salve e feche o arquivo.

Em seguida, crie um novo arquivo de configuração de host virtual para o site <^>site2.your_domain<^>. Você especificará este subdomínio para implantar o php7.2:

				
					
sudo nano /etc/apache2/sites-available/&lt;^&gt;site2.your_domain&lt;^&gt;.conf

				
			

Adicione o conteúdo a seguir: Novamente, verifique se o caminho do diretório do site, o nome do servidor e a versão PHP correspondem às suas informações únicas:

				
					
[label /etc/apache2/sites-available/site2.your_domain.conf]

&lt;VirtualHost *:80&gt;

     ServerAdmin admin@&lt;^&gt;site2.your_domain&lt;^&gt;

     ServerName &lt;^&gt;site2.your_domain&lt;^&gt;

     DocumentRoot /var/www/&lt;^&gt;site2.your_domain&lt;^&gt;

     DirectoryIndex info.php  



     &lt;Directory /var/www/&lt;^&gt;site2.your_domain&lt;^&gt;&gt;

        Options Indexes FollowSymLinks MultiViews

        AllowOverride All

        Order allow,deny

        allow from all

     &lt;/Directory&gt;



    &lt;FilesMatch \.php$&gt;

      # For Apache version 2.4.10 and above, use SetHandler to run PHP as a fastCGI process server

      SetHandler "proxy:unix:/run/php/&lt;^&gt;php7.2&lt;^&gt;-fpm.sock|fcgi://localhost"

    &lt;/FilesMatch&gt;



     ErrorLog ${APACHE_LOG_DIR}/&lt;^&gt;site2.your_domain&lt;^&gt;_error.log

     CustomLog ${APACHE_LOG_DIR}/&lt;^&gt;site2.your_domain&lt;^&gt;_access.log combined

&lt;/VirtualHost&gt;

				
			

Salve e feche o arquivo quando você terminar. Em seguida, verifique se há erros de sintaxe no arquivo de configuração do Apache:

				
					
sudo apachectl configtest

				
			

Você verá o seguinte resultado:

				
					
[secondary_label Output]

Syntax OK

				
			

Agora, habilite ambos os arquivos de configuração de host virtual:

				
					
sudo a2ensite &lt;^&gt;site1.your_domain&lt;^&gt;

sudo a2ensite &lt;^&gt;site2.your_domain&lt;^&gt;

				
			

Você não precisará do site padrão. Desabilite-o:

				
					
sudo a2dissite 000-default.conf

				
			

Finalmente, reinicie o serviço do Apache para implementar suas alterações:

				
					
sudo systemctl restart apache2

				
			

Após configurar o Apache para atender a cada site, você os testará para garantir que as versões apropriadas do PHP estejam funcionando corretamente.

Passo 4 — Testando os sites

Até aqui, você já configurou dois sites para executar duas versões diferentes do PHP. Agora, teste os resultados.

Abra seu navegador Web e visite os dois sites http://<^>site1.your_domain<^> e http://<^>site2.your_domain<^>. Você verá duas páginas parecidas com estas:

Observe os títulos. A primeira página indica que o <^>site1.your_domain<^> implantou o PHP 7.0. A segunda indica que o <^>site2.your_domain<^> implantou o PHP 7.2.

Agora que você testou seus sites, remova os arquivos info.php. Como eles contêm informações confidenciais sobre seu servidor e estão acessíveis a usuários não autorizados, eles representam uma ameaça à segurança. Para remover os dois arquivos, execute os comandos a seguir:

				
					
sudo rm -rf /var/www/&lt;^&gt;site1.your_domain&lt;^&gt;/info.php

sudo rm -rf /var/www/&lt;^&gt;site2.your_domain&lt;^&gt;/info.php

				
			

Agora, você tem um único servidor Debian 10 cuidando de dois sites, com duas versões diferentes do PHP. No entanto, o PHP-FPM não está limitado a este aplicativo.

Conclusão

Você combinou os hosts virtuais e o PHP-FPM para atender vários sites e várias versões do PHP em um único servidor. O único limite prático sobre o número de sites PHP e de versões do PHP que o seu serviço do Apache pode gerenciar é a capacidade de processamento de sua instância.

A partir daqui, considere explorar recursos mais avançados do PHP-FPM, como sua geração de processos adaptáveis ou a maneira como ele pode acessar o sdtout e o stderr. Como uma alternativa, você pode agora proteger seus sites. Para fazer isso, você pode seguir nosso tutorial sobre como proteger seus sites com certificados TLS/SSL gratuitos do Let's Encrypt.