Olá!
Se você decidiu aprender mais sobre a AWS, então chegou ao post certo!
Este guia é projetado para iniciantes ou desenvolvedores com alguma experiência em nuvem que querem aprender os fundamentos da construção de aplicações web na plataforma de nuvem da AWS. Vamos guiá-lo através da implantação de um sistema básico de gerenciamento de contatos, apresentando-lhe os principais serviços da AWS ao longo do caminho.
Neste projeto, como você pode deduzir pelo título, usaremos a AWS, que significa Amazon Web Services; uma excelente plataforma de nuvem com serviços infinitos para tantos casos de uso variados, desde treinar modelos de machine learning até hospedar sites e aplicações.
Computação em nuvem fornece acesso sob demanda a recursos de computação como servidores, armazenamento e bancos de dados. Funções sem servidor são um tipo de serviço de computação em nuvem que permite executar código sem gerenciar servidores.
Ao final deste tutorial, você será capaz de:
- Implantar um site estático na AWS Amplify.
- Criar uma função sem servidor usando AWS Lambda.
- Construir uma API REST com API Gateway.
- Armazenar dados em um banco de dados NoSQL usando DynamoDB.
- Gerenciar permissões com políticas IAM.
- Integrar seu código frontend com os serviços de backend.
Recomendo que você siga o tutorial uma vez e depois tente por si mesmo pela segunda vez. E antes de começarmos, certifique-se de ter uma conta AWS. Inscreva-se para uma conta gratuita se você ainda não tem.
Agora vamos começar!
Passo 1: Implante o código frontend na AWS Amplify 🔗
Neste passo, vamos aprender como implantar recursos estáticos para nossa aplicação web usando o console AWS Amplify.
Conhecimentos básicos de desenvolvimento web serão úteis para esta parte. Criaremos nosso arquivo HTML com o código CSS (estilo) e Javascript (funcionalidade) embutidos nele. Deixei comentários ao longo do código para explicar o que cada parte faz.
Aqui está o trecho de código da página:
<!DOCTYPE html> | |
<html lang="en" dir="ltr"> | |
<head> | |
<meta charset="UTF-8"> | |
<title>Contact Management System</title> | |
<style> | |
body { | |
background-color: #202b3c; | |
display: flex; /* Centering the form */ | |
justify-content: center; /* Centering the form */ | |
align-items: center; /* Centering the form */ | |
height: 100vh; /* Centering the form */ | |
margin: 0; /* Removing default margin */ | |
} | |
form { | |
display: flex; | |
flex-direction: column; /* Aligning form elements vertically */ | |
align-items: center; /* Centering form elements horizontally */ | |
background-color: #fff; /* Adding a white background to the form */ | |
padding: 20px; /* Adding padding to the form */ | |
border-radius: 8px; /* Adding border radius to the form */ | |
} | |
label, button { | |
color: #FF9900; | |
font-family: Arial, Helvetica, sans-serif; | |
font-size: 20px; | |
margin: 10px 0; /* Adding margin between elements */ | |
} | |
input { | |
color: #232F3E; | |
font-family: Arial, Helvetica, sans-serif; | |
font-size: 20px; | |
margin: 10px 0; /* Adding margin between elements */ | |
width: 250px; /* Setting input width */ | |
padding: 5px; /* Adding padding to input */ | |
} | |
button { | |
background-color: #FF9900; /* Adding background color to button */ | |
color: #fff; /* Changing button text color */ | |
border: none; /* Removing button border */ | |
padding: 10px 20px; /* Adding padding to button */ | |
cursor: pointer; /* Changing cursor to pointer on hover */ | |
} | |
h1{ | |
color: #202b3c; | |
font-family: Arial, Helvetica, sans-serif; | |
} | |
</style> | |
<script> | |
// Define the function to call the API with the provided first name, last name, and phone number | |
let callAPI = (fname, lname, pnumber)=>{ | |
// Create a new Headers object and set the 'Content-Type' to 'application/json' | |
let myHeaders = new Headers(); | |
myHeaders.append("Content-Type", "application/json"); | |
// Create the JSON string from the input values | |
let raw = JSON.stringify({"firstname": fname, "lastname": lname, "phone_number": pnumber}); | |
// Define the request options including method, headers, body, and redirect behavior | |
let requestOptions = { | |
method: 'POST', // Method type | |
headers: myHeaders, // Headers for the request | |
body: raw, // The body of the request containing the JSON string | |
redirect: 'follow' // Automatically follow redirects | |
}; | |
// Use the fetch API to send the request to the specified URL | |
fetch("https://uvibtoen42.execute-api.us-east-1.amazonaws.com/web-app-stage", requestOptions) // Replace "API_KEY" with your actual API endpoint | |
.then(response => response.text()) // Parse the response as text | |
.then(result => alert(JSON.parse(result).message)) // Parse the result as JSON and alert the message | |
.catch(error => console.log('error', error)); // Log any errors to the console | |
} | |
</script> | |
</head> | |
<body> | |
<form> | |
<h1>Contact Management System</h1> | |
<label>First Name :</label> | |
<input type="text" id="fName"> | |
<label>Last Name :</label> | |
<input type="text" id="lName"> | |
<label>Phone Number :</label> | |
<input type="text" id="pNumber"> | |
<button type="button" onclick="callAPI(document.getElementById('fName').value, document.getElementById('lName').value, document.getElementById('pNumber').value)">Submit</button> | |
<!-- Button to submit user input without reloading the page --> | |
<!-- When clicked, it calls the callAPI function with values from the input fields --> | |
</form> | |
</body> | |
</html> |
Existem várias maneiras de carregar nosso código no console do Amplify. Por exemplo, gosto de usar Git e Github. Para manter este artigo simples, vou mostrar como fazer isso diretamente pelo método de arrastar e soltar no Amplify. Para isso — temos que comprimir nosso arquivo HTML.
Agora, certifique-se de estar na região mais próxima de onde você vive. Você pode ver o nome da região no canto superior direito da página, ao lado do nome da conta. Então, vamos para o console AWS Amplify. Parecerá algo assim:
Quando clicamos em “Começar”, seremos levados para a seguinte tela (iremos com o Hosting do Amplify nesta tela):
Você iniciará uma implantação manual. Dê um nome ao seu aplicativo, eu chamarei de “Sistema de Gerenciamento de Contatos”, e ignore o nome do ambiente. Então, solte o arquivo index comprimido e clique em Salvar e Implantar.
O Amplify implantará o código e retornará uma URL de domínio onde podemos acessar o site.
Clique no link e você deverá ver isso:
Passo 2: Criar uma função serverless AWS Lambda 🔗
Neste passo, criaremos uma função serverless usando o serviço AWS Lambda. Uma função Lambda é uma função serverless que executa código em resposta a eventos. Você não precisa gerenciar servidores ou se preocupar com escalabilidade, tornando-a uma solução econômica para tarefas simples.
Para lhe dar uma ideia, um ótimo exemplo de computação Serverless na vida real são as máquinas de venda automática. Elas enviam a solicitação para a nuvem e processam o trabalho apenas quando alguém começa a usar a máquina.
Vamos para o serviço Lambda dentro do console da AWS. A propósito, certifique-se de que você está criando a função na mesma região em que implantou o código da aplicação web no Amplify.
Hora de criar uma função. Dê um nome a ela, eu chamarei de “my-web-app-function”, e para os parâmetros de linguagem de programação de runtime: escolhi Python 3.12, mas fique à vontade para escolher a linguagem e versão com as quais você se sente mais confortável e familiarizado.
Após a nossa função lambda ser criada, desça a página e você verá a seguinte tela:
Agora, vamos editar a função lambda. Aqui está uma função que extrai nomes e sobrenomes do JSON de entrada do evento. E então retorna um dicionário de contexto. A chave body armazena o JSON, que é uma string de saudação.
import json | |
def lambda_handler(event, context): | |
name = event['firstname'] +' '+ event['lastname'] +' '+ event['phone_number'] | |
return { | |
'statusCode': 200, | |
'body': json.dumps('Hello from Lambda, ' + name) | |
} |
Após a edição, clique em Deploy para salvar my-web-app-function, e então clique em Test para criar um evento.
Para configurar um evento de teste, dê um nome ao evento como “MyEventTest”, modifique os atributos do Event JSON e salve.
Agora clique no grande botão azul de teste para que possamos testar a função Lambda.
O resultado da execução tem os seguintes elementos:
- Nome do Evento de Teste
- Resposta
- Logs da Função
- ID do Pedido
Passo 3: Criar API Rest com API Gateway 🔗
Agora vamos avançar e implantar nossa função Lambda na Aplicação Web. Usaremos o Amazon API Gateway para criar uma API REST que nos permitirá fazer solicitações a partir do navegador web. O API Gateway atua como uma ponte entre seus serviços de backend (como funções Lambda) e sua aplicação frontend. Ele permite criar APIs que expõem funcionalidades para sua aplicação web.
REST: Transferência de Estado Representacional.
API: Interface de Programação de Aplicações.
Vá até o Amazon API Gateway para criar uma nova API REST.
Na página de criação da API, temos que dar um nome, por exemplo “Web App API”, e escolher um tipo de protocolo e tipo de endpoint para a API REST (selecione Otimizado para Edge).
Agora temos que criar um método POST então clique em Criar método.
Na página Criar método, selecione o tipo de método como POST, o tipo de integração deve ser função Lambda, garanta que a Região seja a mesma Região que você usou para criar a função lambda e selecione a função Lambda que acabamos de criar. Finalize clicando em Criar método na parte inferior da página.
Agora precisamos habilitar o CORS, então selecione o / e depois clique em habilitar CORS
Nas configurações de CORS, apenas marque a caixa POST e deixe tudo o mais como padrão, então clique em salvar.
Após habilitar os cabeçalhos CORS, clique no botão laranja Deploy API.
Uma janela aparecerá, em estágio selecione novo estágio e dê um nome ao estágio, por exemplo “web-app-stage”, então clique em implantar.
Quando você visualizar o estágio, haverá uma URL chamada Invoke URL. Certifique-se de copiar essa URL; usaremos para invocar nossa função lambda na etapa final deste projeto.
Passo 4: Criar uma tabela DynamoDB 🔗
Neste passo, criaremos uma tabela de dados no Amazon DynamoDB, outro serviço da AWS. O DynamoDB é um serviço de banco de dados NoSQL que armazena dados em pares chave-valor. É altamente escalável e flexível, tornando-o adequado para várias aplicações. Clique no botão laranja criar tabela.
Agora temos que preencher algumas informações sobre nossa tabela de dados, como o nome “contact-management-system-table”, e a chave de partição é ID. O resto deixe como padrão. Clique em Criar tabela.
Uma vez que a tabela seja criada com sucesso, clique nela e uma nova janela com os detalhes da tabela se abrirá. Expanda as Informações Adicionais e copie o Nome do Recurso da Amazon (ARN). Usaremos o ARN no próximo passo ao criar políticas de acesso IAM.
Etapa 5: Configurar Políticas e Permissões do IAM 🔗
AWS IAM é uma das coisas mais básicas e importantes a serem configuradas, mas muitas pessoas negligenciam isso. Para uma segurança aprimorada, sempre é recomendado um modelo de acesso de menor privilégio, o que significa não dar mais acesso do que o necessário a um usuário. Por exemplo, mesmo para este simples projeto de aplicativo web, já trabalhamos com vários serviços da AWS: Amplify, Lambda, DynamoDB e API Gateway. É essencial entender como eles se comunicam entre si e que tipo de informação compartilham.
Agora, voltando ao nosso projeto, precisamos definir uma política do IAM para dar acesso à nossa função lambda para escrever/atualizar os dados na tabela DynamoDB.
Então, volte ao console do AWS Lambda e clique na função lambda que acabamos de criar. Depois, vá para a aba de configuração, e no menu à esquerda clique em Permissões. Sob a Role de execução, você verá um nome de Role.
Clique no link, que nos levará às configurações de permissão desta role do IAM. Agora clique em Adicionar permissões, depois crie uma política inline.
Então clique em JSON, apague o que está no editor de Política e cole o seguinte.
Certifique-se de substituir o “YOUR-DB-TABLE-ARN” pelo seu real ARN da tabela DynamoDB. Clique em Próximo, dê um nome à política, como “lambda-dynamodb”, e então clique em Criar política. Esta política permitirá que nossa função Lambda leia, edite, delete e atualize itens da tabela de dados DynamoDB.
Agora feche esta janela, e de volta à função Lambda, vá para a aba Código e atualizaremos o código python da função lambda com o seguinte.
import json | |
import boto3 | |
from time import gmtime, strftime | |
dynamodb = boto3.resource('dynamodb') | |
table = dynamodb.Table('contact-management-system-table') | |
now = strftime("%a, %d %b %Y %H:%M:%S +0000", gmtime()) | |
def lambda_handler(event, context): | |
name = event['firstname'] +' '+ event['lastname'] +' '+ event['phone_number'] | |
response = table.put_item( | |
Item={ | |
'ID': name, | |
'LatestGreetingTime':now | |
}) | |
return { | |
'statusCode': 200, | |
'body': json.dumps('Hello from Lambda, ' + name) | |
} | |
'statusCode': 200, | |
'body': json.dumps('Hello from Lambda, ' + name) | |
} |
A resposta está no formato REST API. Após fazer as alterações, certifique-se de implantar o código. Após a conclusão da implantação, podemos Testar o programa clicando no botão de teste azul.
Também podemos verificar os resultados na tabela DynamoDB. Quando executamos a função, ela atualiza os dados na nossa tabela. Então, vá para o AWS DynamoDB, clique em explorar itens na barra lateral esquerda, clique na sua tabela. Aqui está o objeto retornado da função lambda:
Etapa 6: Atualizar o código frontend com Rest API 🔗
Parabéns por chegar até aqui!
Nesta etapa final, veremos tudo o que acabamos de construir em ação. Atualizaremos o front-end para ser capaz de invocar a REST API com a ajuda da nossa função lambda e receber dados.
Primeiro, volte ao seu index.html no seu editor de código. Veja na linha 68 que você tinha “API_KEY”? Vá em frente e substitua isso pela URL de invocação que você copiou do serviço API Gateway em detalhes da sua REST API. Uma vez feito isso, salve e comprima o arquivo novamente, como fizemos na etapa 1, e faça o upload novamente para a AWS usando o console.
Clique no novo link que você obteve e vamos testá-lo.
Nossas tabelas de dados recebem a solicitação post com os dados inseridos. A função lambda invoca a API quando o botão “Chamar API” é clicado. Então, usando javascript, enviamos os dados em formato JSON para a API. Você pode encontrar as etapas sob a função callAPI.
Você pode encontrar os itens retornados para minha tabela de dados abaixo:
Conclusão 🔗
Parabéns! Você criou um aplicativo web simples usando a plataforma de nuvem AWS. A computação em nuvem está crescendo rapidamente e se tornando cada vez mais parte do desenvolvimento de novos softwares e tecnologias.
Se você estiver pronto para um desafio, a seguir você poderia:
- Melhorar o design do frontend
- Adicionar autenticação e autorização do usuário
- Configurar painéis de monitoramento e análise
- Implementar pipelines de CI/CD para automatizar os processos de construção, teste e implantação de seu aplicativo web usando serviços como AWS CodePipeline, AWS CodeBuild e AWS CodeDeploy.
Trabalhar em projetos de programação práticos é a melhor maneira de aprimorar suas habilidades.
Estarei abordando alguns outros cenários na AWS em meus próximos posts no blog, então fique de olho!
E novamente, fique à vontade para me dar feedback, e se eu estiver fora do caminho, não hesite em me avisar. Estamos todos juntos nisso, aprendendo e crescendo como uma comunidade!
Se você gostou deste artigo, siga-me no Twitter (onde compartilho minha jornada tecnológica diariamente), conecte-se comigo no LinkedIn, confira meu IG e não se esqueça de se inscrever no meu canal do Youtube para mais conteúdo incrível!!