Configurar e habilitar o monitoramento avançado
Para usar o monitoramento avançado, você deve criar uma função do IAM e habilitar o monitoramento avançado.
Tópicos
Criar uma função do IAM para o monitoramento avançado
O Monitoramento avançado requer permissão para agir em seu nome para enviar informações de métricas do SO ao CloudWatch Logs. Você concede as permissões ao monitoramento avançado usando uma função do AWS Identity and Access Management (IAM). Você pode criar essa função ao ativar o monitoramento aprimorado ou criá-la de antemão.
Tópicos
Criar a função do IAM ao habilitar o Monitoramento Avançado
Quando você habilita o Monitoramento Avançado no console do RDS, o Amazon RDS pode criar a função do IAM necessária para você. A função é chamada rds-monitoring-role
. O RDS usa essa função para a instância de banco de dados especificada, réplica de leitura ou cluster de banco de dados multi-AZ.
Para criar a função do IAM ao habilitar o Monitoramento Avançado
-
Siga as etapas em Ativar e desativar o monitoramento aprimorado.
-
Defina a Monitoring Role (Função de monitoramento) como Default (Padrão) na etapa em que você escolhe uma função.
Criar a função do IAM antes de ativar o Monitoramento Avançado
Você pode criar a função necessária antes de habilitar o Monitoramento Avançado. Ao habilitar o Monitoramento Avançado, especifique o nome da nova função. Você deverá criar essa função necessária se habilitar o Monitoramento avançado usando a AWS CLI ou a API do RDS.
O usuário que habilita o monitoramento aprimorado precisa receber a permissão PassRole
. Para obter mais informações, consulte o Exemplo 2 em Conceder permissões ao usuário para transmitir uma função para um serviço da AWS no Guia do usuário do IAM.
Como criar uma função do IAM para o monitoramento avançado do Amazon RDS
-
Abra o Console do IAM
em https://console.aws.amazon.com . -
No painel de navegação, escolha Roles.
-
Escolha Criar Perfil.
-
Escolha a guia Serviço da AWS e, em seguida, RDS na lista de serviços.
-
Escolha RDS - Enhanced Monitoring (RDS: monitoramento aprimorado) e Next (Próximo).
-
A página Permissions policies (Políticas de permissões) deve mostrar AmazonRDSEnhancedMonitoringRole. Escolha Next (Próximo).
-
Em Role name (Nome da função), digite um nome para sua função. Por exemplo, digite
emaccess
.A entidade confiável para sua função é o serviço da AWS monitoring.rds.amazonaws.com.
-
Selecione Create role (Criar função).
Ativar e desativar o monitoramento aprimorado
É possível gerenciar o monitoramento avançado usando o AWS Management Console, a AWS CLI ou a API do RDS. Você pode definir detalhamentos diferentes para a coleta de métricas em cada cluster de banco de dados. Você também pode ativar o monitoramento avançado para um cluster de banco de dados existente pelo console.
É possível ativar o monitoramento avançado ao criar um cluster de banco de dados ou uma réplica de leitura, ou ao modificar um cluster de banco de dados. Se você modificar uma instância ou um cluster de banco de dados para ativar o monitoramento avançado, não será necessário reinicializar a instância de banco de dados para que a alteração entre em vigor.
Você pode ativar o monitoramento aprimorado no console do RDS ao realizar uma das seguintes ações na página Databases (Banco de dados):
-
”Create a DB cluster” (Criar um cluster de banco de dados): escolha Create database (Criar banco de dados).
-
Create a read replica (Criar uma réplica de leitura) — Escolha Actions (Ações) e depois Create read replica (Criar réplica de leitura).
-
Modificar uma instância de banco de dados ou cluster de banco de dados : escolha Modificar.
nota
Ao habilitar o monitoramento avançado para um cluster de banco de dados, não é possível gerenciá-lo para instâncias de banco de dados individuais dentro do cluster.
Se você estiver gerenciando o monitoramento avançado para instâncias de banco de dados individuais em um cluster de banco de dados e o detalhamento estiver definido com valores diferentes para instâncias diferentes, o cluster de banco de dados será heterogêneo em relação ao monitoramento avançado. Nesses casos, você não pode modificar o cluster de banco de dados para gerenciar o monitoramento avançado no nível do cluster.
Para ativar ou desativar o monitoramento aprimorado no console do RDS
-
Role até Additional configuration (Configuração adicional).
-
Em Monitoramento, escolha Habilitar monitoramento avançado para o cluster de banco de dados ou a réplica de leitura. Habilitar o monitoramento avançado no nível do cluster permite gerenciar as configurações e opções desse recurso no nível do cluster. As configurações no nível do cluster se aplicam a todas as instâncias de banco de dados no cluster.Desmarque a opção para desabilitar o monitoramento avançado no nível do cluster. Posteriormente, é possível modificar as configurações do monitoramento avançado para instâncias de banco de dados individuais no cluster.
Na página Criar banco de dados, você pode optar por ativar o monitoramento avançado no nível do cluster.
Se não habilitar o monitoramento avançado ao criar um cluster, você poderá modificar o cluster na página Modificar cluster de banco de dados.
nota
Não é possível gerenciar o monitoramento avançado para uma instância de banco de dados individual em um cluster de banco de dados que já tenha o monitoramento avançado gerenciado no nível do cluster.
-
Você não pode optar por gerenciar o monitoramento avançado no nível do cluster se o cluster for heterogêneo em relação ao monitoramento avançado. Para gerenciar o monitoramento avançado no nível do cluster, altere as configurações do monitoramento avançado de cada instância para que elas correspondam. Agora você pode optar por gerenciar o monitoramento avançado no nível do cluster ao modificar o cluster.
-
Defina a propriedade Monitoring Role (Função de monitoramento) como a função do IAM que você criou para permitir que o Amazon RDS se comunique com o Amazon CloudWatch Logs por você. Ou escolha Default (Padrão) para que o RDS crie uma função para você chamada
rds-monitoring-role
. -
Defina a propriedade Granularidade como o intervalo, em segundos, entre pontos quando as métricas são coletadas para a instância de banco de dados, o cluster de banco de dados ou a réplica de leitura. A propriedade Granularity (Granularidade) pode ser definida como um dos seguintes valores:
1
,5
,10
,15
,30
ou60
.A frequência de atualização mais rápida do console do RDS é a cada 5 segundos. Se você definir a granularidade como 1 segundo no console do RDS, ainda verá as métricas atualizadas apenas a cada 5 segundos. É possível recuperar atualizações de métricas de 1 segundo usando a CloudWatch Logs.
Para ativar o monitoramento avançado usando a AWS CLI, defina a opção --monitoring-interval
nos comandos a seguir como um valor diferente de 0
e defina a opção --monitoring-role-arn
para a função criada em Criar uma função do IAM para o monitoramento avançado.
A opção --monitoring-interval
especifica o intervalo, em segundos, entre pontos quando as métricas de monitoramento avançado são coletadas. Os valores válidos para a opção são 0
, 1
, 5
, 10
, 15
, 30
e 60
.
Para desativar o monitoramento aprimorado usando a AWS CLI, defina a opção --monitoring-interval
para 0
nestes comandos.
exemplo
O seguinte exemplo ativa o monitoramento avançado para uma instância de banco de dados:
Para Linux, macOS ou Unix:
aws rds modify-db-instance \ --db-instance-identifier
mydbinstance
\ --monitoring-interval30
\ --monitoring-role-arnarn:aws:iam::123456789012:role/emaccess
Para Windows:
aws rds modify-db-instance ^ --db-instance-identifier
mydbinstance
^ --monitoring-interval30
^ --monitoring-role-arnarn:aws:iam::123456789012:role/emaccess
exemplo
O seguinte exemplo ativa o monitoramento avançado para um cluster de banco de dados:
Para Linux, macOS ou Unix:
aws rds modify-db-cluster \ --db-cluster-identifier
mydbinstance
\ --monitoring-interval30
\ --monitoring-role-arnarn:aws:iam::123456789012:role/emaccess
Para Windows:
aws rds modify-db-cluster ^ --db-cluster-identifier
mydbinstance
^ --monitoring-interval30
^ --monitoring-role-arnarn:aws:iam::123456789012:role/emaccess
exemplo
O seguinte exemplo ativa o monitoramento avançado para um cluster de banco de dados multi-AZ:
Para Linux, macOS ou Unix:
aws rds modify-db-cluster \ --db-cluster-identifier
mydbcluster
\ --monitoring-interval30
\ --monitoring-role-arnarn:aws:iam::123456789012:role/emaccess
Para Windows:
aws rds modify-db-cluster ^ --db-cluster-identifier
mydbcluster
^ --monitoring-interval30
^ --monitoring-role-arnarn:aws:iam::123456789012:role/emaccess
Para ativar o monitoramento aprimorado usando a API do RDS, defina o parâmetro MonitoringInterval
como um valor diferente de 0
e defina o parâmetro MonitoringRoleArn
para a função criada em Criar uma função do IAM para o monitoramento avançado. Defina esses parâmetros nas seguintes ações:
O parâmetro MonitoringInterval
especifica o intervalo, em segundos, entre pontos quando as métricas de monitoramento avançado são coletadas. Os valores válidos são 0
, 1
, 5
, 10
, 15
, 30
e 60
.
Para desativar o monitoramento aprimorado usando a API do RDS, defina MonitoringInterval
como 0
.
Proteção contra o problema do substituto confuso
O problema de "confused deputy" é uma questão de segurança em que uma entidade que não tem permissão para executar uma ação pode coagir uma entidade mais privilegiada a executá-la. Na AWS, a personificação entre serviços pode resultar no problema do ‘confused deputy’. A personificação entre serviços pode ocorrer quando um serviço (o serviço de chamada) chama outro serviço (o serviço chamado). O serviço de chamada pode ser manipulado de modo a usar suas permissões para atuar nos recursos de outro cliente de uma forma na qual ele não deveria ter permissão para acessar. Para evitar isso, a AWS fornece ferramentas que ajudam você a proteger seus dados para todos os serviços com entidades principais de serviço que receberam acesso aos recursos em sua conta. Para obter mais informações, consulte O problema do substituto confuso.
Para limitar as permissões ao recurso que o Amazon RDS pode fornecer a outro serviço, recomendamos usar as chaves de contexto de condição global aws:SourceArn
e aws:SourceAccount
em uma política de confiança para sua função de monitoramento aprimorado. Se você usar as duas chaves de contexto de condição global, elas deverão usar o mesmo ID de conta.
A maneira mais eficaz de se proteger contra o problema do substituto confuso é usar a chave de contexto de condição global aws:SourceArn
com o ARN completo do recurso. Para o Amazon RDS, defina aws:SourceArn
como arn:aws:rds:
.Region
:my-account-id
:db:dbname
O exemplo a seguir usa as chaves de contexto de condição global aws:SourceArn
e aws:SourceAccount
em uma política de confiança para evitar o problema de substituto confuso.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "Service": "monitoring.rds.amazonaws.com" }, "Action": "sts:AssumeRole", "Condition": { "StringLike": { "aws:SourceArn": "arn:aws:rds:
Region
:my-account-id
:db:dbname
" }, "StringEquals": { "aws:SourceAccount": "my-account-id
" } } } ] }