

As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.

# Ajuste sua instância do EC2 para obter desempenho
<a name="ec2-instance-performance-tuning"></a>

**nota**  
Se você provisionou seus recursos da AWS usando CloudFormation modelos, esses ajustes serão aplicados automaticamente. Se você usou uma AMI ou criou manualmente sua instância do EC2, esses ajustes de desempenho devem ser aplicados para obter o desempenho mais confiável.

Lembre-se de reinicializar sua instância depois de aplicar qualquer ajuste.

**Tópicos**
+ [Ajuste interrupções de hardware e filas de recebimento - afeta a CPU e a rede](#tune-hardware-interrupts)
+ [Tune Rx interrompe a coalescência - afeta a rede](#tune-rx-interrupts)
+ [Tune Rx ring buffer - afeta a rede](#tune-rx-ring-buffer)
+ [Ajuste a CPU C-State - afeta a CPU](#tune-cpu-c-state)
+ [Portas de entrada de reserva - impacta a rede](#reserve-ingress-ports)
+ [Reinicializar](#reboot)

## Ajuste interrupções de hardware e filas de recebimento - afeta a CPU e a rede
<a name="tune-hardware-interrupts"></a>

Esta seção configura o uso principal da CPU do systemd, SMP IRQs, Receive Packet Steering (RPS) e Receive Flow Steering (RFS). Consulte [Apêndice: Parâmetros recomendados para ajuste interrupt/RPS](#recommended-parameters) para ver um conjunto de configurações recomendadas com base no tipo de instância que você está usando.

1. Afaste os processos do systemd dos núcleos da CPU do agente.

1. Redirecione as solicitações de interrupção de hardware para fora dos núcleos da CPU do agente.

1. Configure o RPS para evitar que a fila de hardware de uma única placa de interface de rede se torne um gargalo no tráfego da rede.

1. Configure o RFS para aumentar a taxa de acertos de cache da CPU e, assim, reduzir a latência da rede.

O script `set_irq_affinity.sh` fornecido pelo RPM configura todas as opções acima para você. Adicione ao crontab, para que ele seja aplicado em cada inicialização:

```
echo "@reboot sudo /opt/aws/groundstation/bin/set_irq_affinity.sh '${interrupt_core_list}' '${rps_core_mask}' >> /var/log/user-data.log 2>&1" >>/var/spool/cron/root
```
+ `interrupt_core_list`Substitua por núcleos reservados para o kernel e o sistema operacional - normalmente o primeiro e o segundo, juntamente com pares de núcleos hiperencadeados. Isso não deve se sobrepor aos núcleos selecionados acima. (Por exemplo: '0,1,48,49' para uma instância hyper-threaded de 96 CPUs).
+ `rps_core_mask`é uma máscara de bits hexadecimal que especifica quais CPUs devem processar os pacotes recebidos, com cada dígito representando 4. CPUs Também deve ser separado por vírgula a cada oito caracteres, começando pela direita. É recomendável permitir tudo CPUs e deixar o cache lidar com o balanceamento.
  + Para ver a lista de parâmetros recomendados para cada tipo de instância, consulte [Apêndice: Parâmetros recomendados para ajuste interrupt/RPS](#recommended-parameters).
+  Exemplo de instância de 96 CPUs: 

  ```
  echo "@reboot sudo /opt/aws/groundstation/bin/set_irq_affinity.sh '0,1,48,49' 'ffffffff,ffffffff,ffffffff' >> /var/log/user-data.log 2>&1" >>/var/spool/cron/root
  ```

## Tune Rx interrompe a coalescência - afeta a rede
<a name="tune-rx-interrupts"></a>

 A coalescência de interrupções ajuda a evitar inundar o sistema host com muitas interrupções e ajuda a aumentar o throughput da rede. Com essa configuração, os pacotes são coletados e uma única interrupção é gerada a cada 128 microssegundos. Adicione ao crontab, para que ele seja aplicado em cada inicialização: 

```
echo "@reboot sudo ethtool -C ${interface} rx-usecs 128 tx-usecs 128 >>/var/log/user-data.log 2>&1" >>/var/spool/cron/root
```
+ Substitua `interface` pela interface de rede (adaptador Ethernet) configurada para receber dados. Normalmente, essa é `eth0` a interface de rede padrão atribuída a uma instância do EC2.

## Tune Rx ring buffer - afeta a rede
<a name="tune-rx-ring-buffer"></a>

 Aumente o número de entradas de anel para o buffer de anel Rx para evitar quedas ou sobrecargas de pacotes durante conexões intermitentes. Adicione ao crontab, para que fique configurado corretamente em cada inicialização: 

```
echo "@reboot sudo ethtool -G ${interface} rx 16384 >>/var/log/user-data.log 2>&1" >>/var/spool/cron/root
```
+ Substitua `interface` pela interface de rede (adaptador Ethernet) configurada para receber dados. Normalmente, essa é `eth0` a interface de rede padrão atribuída a uma instância do EC2.
+ Ao configurar uma instância `c6i` familiar, o comando precisa ser modificado para definir o buffer de anel como`8192`, em vez de`16384`.

## Ajuste a CPU C-State - afeta a CPU
<a name="tune-cpu-c-state"></a>

 Defina o estado C da CPU para evitar a ociosidade, o que pode causar a perda de pacotes durante o início de um contato. Requer reinicialização da instância. 

```
echo "GRUB_CMDLINE_LINUX_DEFAULT=\"console=tty0 console=ttyS0,115200n8 net.ifnames=0 biosdevname=0 nvme_core.io_timeout=4294967295 intel_idle.max_cstate=1 processor.max_cstate=1 max_cstate=1\"" >/etc/default/grub
echo "GRUB_TIMEOUT=0" >>/etc/default/grub
grub2-mkconfig -o /boot/grub2/grub.cfg
```

## Portas de entrada de reserva - impacta a rede
<a name="reserve-ingress-ports"></a>

 Reserve todas as portas no intervalo de portas do endereço de entrada de `AwsGroundStationAgentEndpoint` para evitar conflitos com o uso do kernel. O conflito de uso da porta levará à falha no contato e na entrega de dados. 

```
echo "net.ipv4.ip_local_reserved_ports=${port_range_min}-${port_range_max}" >> /etc/sysctl.conf
```
+ Exemplo: `echo "net.ipv4.ip_local_reserved_ports=42000-43500" >> /etc/sysctl.conf`.

## Reinicializar
<a name="reboot"></a>

Depois que todos os ajustes forem aplicados com êxito, reinicialize a instância para que os ajustes entrem em vigor.

```
sudo reboot
```

## Apêndice: Parâmetros recomendados para ajuste interrupt/RPS
<a name="recommended-parameters"></a>

 Esta seção determina os valores de parâmetros recomendados para uso na seção Ajustar interrupções de hardware e filas de recebimento: impactam a CPU e a rede. 


| Família | Tipo de instância | ${interrupt\_core\_list} | ${rps\_core\_mask} | 
| --- | --- | --- | --- | 
| c7i |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 
| c6i |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 
| c5 |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 
| c5n |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 
| m5 |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 
| r5 |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 
| r5n |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 
| g4dn |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 
| p4d |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 
| p3dn |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  |  [See the AWS documentation website for more details](http://docs.aws.amazon.com/pt_br/ground-station/latest/gs-agent-ug/ec2-instance-performance-tuning.html)  | 