<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: 99mvps</title>
    <description>The latest articles on DEV Community by 99mvps (@99mvps).</description>
    <link>https://dev.to/99mvps</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F1045084%2F700123d3-0269-4995-8be7-a7959a6f259d.png</url>
      <title>DEV Community: 99mvps</title>
      <link>https://dev.to/99mvps</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/99mvps"/>
    <language>en</language>
    <item>
      <title>html+css+js=ola mundo</title>
      <dc:creator>99mvps</dc:creator>
      <pubDate>Mon, 20 Mar 2023 02:00:31 +0000</pubDate>
      <link>https://dev.to/99mvps/htmlcssjsola-mundo-291m</link>
      <guid>https://dev.to/99mvps/htmlcssjsola-mundo-291m</guid>
      <description>&lt;p&gt;primeiro post.&lt;/p&gt;

&lt;p&gt;Google Domains + AWS Route53 + CloudFront + SSL + S3... &lt;/p&gt;

&lt;p&gt;lendo assim, pode não parecer tão simples configurar, mas é e tem algumas vantagens de segurança fazer dessa forma, na AWS.&lt;/p&gt;

&lt;h2&gt;
  
  
  Domínio
&lt;/h2&gt;

&lt;p&gt;o domínio, foi comprado no Google Domains, que achei relativamente barato (R$ 50 no primeiro ano), mas o controle do domínio, quero na AWS. &lt;/p&gt;

&lt;p&gt;no &lt;a href="https://us-east-1.console.aws.amazon.com/route53/home"&gt;Route 53&lt;/a&gt;, para criar um novo registro, uma nova &lt;a href="https://us-east-1.console.aws.amazon.com/route53/v2/hostedzones"&gt;hosted zone&lt;/a&gt;, a criação super simples também. você vai colocar o nome do seu domínio, na sua nova zona. alguns registros iniciais serão criados. substitua os valores dos &lt;code&gt;Records&lt;/code&gt; criados no Route 53, na sua conta do Google Domain, ativando a opção de customizar no nome do servidor. &lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--cFWXSSUa--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/qt3jne6qxww2utaay993.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--cFWXSSUa--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/qt3jne6qxww2utaay993.png" alt="Route 53 hosted zones list" width="880" height="522"&gt;&lt;/a&gt;&lt;br&gt;
clicando no &lt;code&gt;Record&lt;/code&gt;, e selecionando editar, apenas cole os valores no espaço correspondente.&lt;/p&gt;

&lt;p&gt;ficando mais ou menos assim:&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--XR8mZs1H--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/d9wpdgm7k81dcn0yu8jh.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--XR8mZs1H--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/d9wpdgm7k81dcn0yu8jh.png" alt="google domains customizar nome do servidor" width="880" height="586"&gt;&lt;/a&gt;&lt;/p&gt;
&lt;h2&gt;
  
  
  Email
&lt;/h2&gt;

&lt;p&gt;como estou usando o Google Workspace também, precisei criar os registros de MX do Google no Route 53. processo simples também; só copiar as entradas de MX Google Domains e criar o registro de MX no route 53.&lt;/p&gt;
&lt;h2&gt;
  
  
  SSL
&lt;/h2&gt;

&lt;p&gt;para criar o nosso certificado SSL, irei usar o próprio &lt;a href="https://us-east-1.console.aws.amazon.com/acm/home?region=us-east-1#/certificates/list"&gt;gerenciador de certificados da AWS&lt;/a&gt;, basta criar clicando em &lt;code&gt;"Request"&lt;/code&gt;, mas é possível usar outros como por exemplo o próprio let's encrypt. &lt;/p&gt;

&lt;p&gt;nesse formulário, coloque o seu FDQN ou o "nome" do seu domínio, no nosso caso &lt;a href="https://99mvps.dev"&gt;99mvps.dev&lt;/a&gt;. deixa tudo selecionado como padrão, principalmente a opção, &lt;code&gt;"DNS validation"&lt;/code&gt; pois isso vai tornar o processo mais simples, pois será automático. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--5PN3s5gc--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/zf3tircahrvgoa6ek8bh.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--5PN3s5gc--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/zf3tircahrvgoa6ek8bh.png" alt='print da opção selecionada: "DNS validation - recommended"' width="770" height="151"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;feito isso, ele vai entrar no processo de requisitar essas informações e isso pode levar um tempo.&lt;/p&gt;

&lt;p&gt;aliás tanto os processos de criação do domínio, vincular ao Route 53, criar Certificado, etc, leva um tempo, pois os serviços serão propagados pela internet. pode levar até algumas horas, mas é normal terminar em alguns minutos. provavelmente, se você estiver seguindo cada passo como estou fazendo aqui, ao final já estará tudo funcionando 🤞&lt;/p&gt;

&lt;p&gt;parte de domínios, ok.&lt;br&gt;
enquanto isso, vamos ao nosso bucket.&lt;/p&gt;
&lt;h2&gt;
  
  
  S3 + CloudFront
&lt;/h2&gt;

&lt;p&gt;vamos até o serviço &lt;a href="https://s3.console.aws.amazon.com/s3/home?region=us-east-1"&gt;S3&lt;/a&gt; e criaremos um bucket com o nome do nosso domínio, apenas por uma questão de convenção. mas é importante deixar que vai ficar mais fácil de acompanhar. &lt;/p&gt;

&lt;p&gt;entre as configurações uma muito importante é definir se o nosso bucket pode ser acessado de maneira pública. nesse caso, não queremos isso, pois os nossos objetos (arquivos, imagens, css, js), serão acessados através de outro serviço.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--QJRkuPsQ--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/zntds6ujwyubbiuut7ta.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--QJRkuPsQ--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/zntds6ujwyubbiuut7ta.png" alt="opções que define o nível de acesso a um bucket AWS S3" width="797" height="193"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;não precisa mexer em nenhuma configuração, apenas coloque o nome, siga até o final e crie o bucket.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;se o bucket não pode ser acessado de maneira pública, como ele vai ser acessado?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;é aí que entra o CloudFront, que por sua vez além de um serviço de distribuição de conteúdo, fazendo com que nosso site ou aplicação esteja distribuído pelo planeta, entregando os recursos mais próximos do clientes, também irá ser o único serviço permitido a ter acesso ao S3, ou seja, essa é a parte segura, uma vez que para acessar qualquer objeto no S3 precisará assinar as requisições garantindo mais segurança e restringindo o controle de acesso aos arquivos e ao bucket S3.&lt;/p&gt;
&lt;h3&gt;
  
  
  CloudFront
&lt;/h3&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--_rhgQCIF--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/nyaz0nt8i9vud7pbkct6.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--_rhgQCIF--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/nyaz0nt8i9vud7pbkct6.png" alt="criação de uma distribuição no CloudFront" width="708" height="340"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;como podemos ver, o bucket, recém criado, já é listado entre as opções no CloudFront. selecione o bucket.&lt;br&gt;
para criar esse acesso do CloudFront para o S3, precisar criar a chave OAI: Amazon Cloudfront Origin Access Identity. que é uma função do CloudFront que irá criar uma camada de segurança autenticando e autorizando esse cliente o acesso ao S3.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--vErN8BY6--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/x8foe1wf845ap7htvhkg.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--vErN8BY6--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/x8foe1wf845ap7htvhkg.png" alt="apontando o botão de criação do OAI" width="786" height="282"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;uma caixa de diálogo será aberta e pode colocar ali um nome qualquer.&lt;br&gt;
é importante deixar a opção &lt;code&gt;"Yes, update the bucket policy"&lt;/code&gt; ou atualizar a política do bucket. é importante pois nesse processo o bucket será atualizado com a política de acesso restrita ao OAI.&lt;/p&gt;

&lt;p&gt;um pouco mais abaixo, você terá que ver três opções em &lt;code&gt;"Settings"&lt;/code&gt;: &lt;br&gt;
1) primeiro deve criar um CNAME. ele diz ser opcional, mas devemos criar um CNAME para a nossa distribuição.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--ZPsyLHqi--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/kis7a3fif6fhniiqcyuk.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--ZPsyLHqi--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/kis7a3fif6fhniiqcyuk.png" alt="CNAME" width="801" height="197"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;2) selecione o seu Certificado SSL, que por esse momento, já deve ter conseguido ser requisitado.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--cj14PwO9--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/2ujibpk4m8zujulq3nns.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--cj14PwO9--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/2ujibpk4m8zujulq3nns.png" alt="lista de certificados gerenciador pela AWS" width="810" height="327"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;se não aparecer aí, pode ainda não ter terminado o processo. se mesmo assim, após alguns minutos não apareceu nada, coloca sua dúvida aqui ou me manda uma DM no twitter que podemos tentar resolver. selecione a sua chave SSL criada.&lt;/p&gt;

&lt;p&gt;marcar a opção de &lt;code&gt;Redirect HTTP to HTTPS&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--HSfWG8l5--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/phqpgaendpnad6f4877i.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--HSfWG8l5--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/phqpgaendpnad6f4877i.png" alt="opção de redirecionar http para https" width="419" height="158"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;após isso próximo do final coloque qual arquivo será o root da sua distribuição.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--EY3hRdc0--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/7otr8k92yfg4e1xtklbo.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--EY3hRdc0--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/7otr8k92yfg4e1xtklbo.png" alt="definindo arquivo root da distribuição" width="672" height="91"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;3) o bucket será atualizado com a nova política&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--b4v00mEz--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/2izuwj60vej09knugb5m.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--b4v00mEz--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/2izuwj60vej09knugb5m.png" alt="S3 atualizado com a nova política" width="755" height="755"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;a partir desse momento, poderá notar que o CloudFront vai estar com o status "Deploy"  e após finalizar colocará a hora que a distribuição acabou o deploy.&lt;/p&gt;

&lt;p&gt;para validar se o deploy funcionou e seu website está distribuído, pode testar de duas formas: &lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--aqJDoxbu--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/ny72m5gosnsk9ws8sko6.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--aqJDoxbu--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/ny72m5gosnsk9ws8sko6.png" alt="listagem de distribuições do cloud front" width="880" height="145"&gt;&lt;/a&gt;&lt;br&gt;
toda distribuição tem um domínio: a coluna "Domain Name" é o domínio da distrição. se copiar esse domínio e colar no browser, voilá: &lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--wJbYdniv--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/uv1ldx2920id7dk0cpe2.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--wJbYdniv--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/uv1ldx2920id7dk0cpe2.png" alt="website sendo acessado pelo domínio gerado pelo cloud front" width="464" height="180"&gt;&lt;/a&gt;&lt;/p&gt;
&lt;h3&gt;
  
  
  SSL Server Test
&lt;/h3&gt;

&lt;p&gt;&lt;a href="https://www.ssllabs.com/ssltest/analyze.html"&gt;https://www.ssllabs.com/ssltest/analyze.html&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--fqSd5juE--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/ev5ax5n0xou4vsmedixu.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--fqSd5juE--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/ev5ax5n0xou4vsmedixu.png" alt="SSL testing tool" width="880" height="600"&gt;&lt;/a&gt;&lt;/p&gt;
&lt;h3&gt;
  
  
  finalizando
&lt;/h3&gt;

&lt;p&gt;se seu certificado estiver &lt;code&gt;"Issued"&lt;/code&gt; podemos fazer os dois últimos passos (ufa!) que são vincular a chave SSL ao domínio e finalmente o nome do domínio, no Route 53 ao nosso CloudFront.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--jkdrcWiO--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/u8rd62kgfcrmrnoteq0m.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--jkdrcWiO--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/u8rd62kgfcrmrnoteq0m.png" alt="listagem de certificados gerenciados pela AWS" width="880" height="82"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;1) você deve vincular o &lt;code&gt;CNAME&lt;/code&gt; gerado pelo Gerenciador de Certificados com o Route 53.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--UJpjH2Gk--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/vxp32f8zv2vlsv2e5kcw.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--UJpjH2Gk--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/vxp32f8zv2vlsv2e5kcw.png" alt="CNAME do gerenciador de certificados " width="880" height="261"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;automaticamente esse registro será adicionado ao Route 53&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--BrRSOFyH--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/vbz9vopll44zwzwhcxsn.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--BrRSOFyH--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/vbz9vopll44zwzwhcxsn.png" alt="adicionando o registro do CNAME no Route 53" width="880" height="286"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;2) criar um alias que vincule o Route 53 a distribuição do CloudFront.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--GISkxNZB--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/23xoxtxhpnkkm12f3w03.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--GISkxNZB--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/23xoxtxhpnkkm12f3w03.png" alt="cloudfront route 53 alias" width="880" height="441"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;pronto! se eu não esqueci nenhum passo, em alguns minutos você irá ver sua página funcionando.&lt;/p&gt;
&lt;h3&gt;
  
  
  Github Actions (bônus)
&lt;/h3&gt;

&lt;p&gt;agora que fizemos todo o processo de "hospedagem" do nosso site, podemos modificá-lo e na medida que as modificações ocorram, vamos subindo isso ao S3. &lt;br&gt;
porém aí tem um detalhe: lembra do CloudFront que adicionamos como camada de segurança? ele também cria uma camada de cache, para permtir que o acesso ao arquivo seja o mais rápido, por estar mais próximo do objeto disponível. por isso ele é um serviço de distribuição de conteúdo. &lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;certo, então após fazermos o upload e invalidarmos o cache do nosso serviço, em alguns instantes seu site estará atualizado. &lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;em&gt;agora sim, aí tudo certo.&lt;/em&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;toda vez que eu atualizar uma vírgula no meu site, preciso fazer todo esse processo?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;_sim. toda vez. _&lt;/p&gt;

&lt;p&gt;não seria muito diferente na maioria dos serviços que vemos por aí, porém para tornar menos cansativo e mais simples, automatizado, podemos usar o &lt;a href="https://github.com/features/actions"&gt;Github Actions&lt;/a&gt; em nosso favor.&lt;/p&gt;

&lt;p&gt;no nosso projeto, já temos um &lt;a href="https://github.com/99mvps/landing-page/blob/main/.github/workflows/main.yml"&gt;Workflow configurado&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;primeiro você deve criar as chaves secretas, no Github Actions para não expor suas credenciais no seu código!&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--Vivcguvi--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/nygc8c8el72zqv1da6py.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--Vivcguvi--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/nygc8c8el72zqv1da6py.png" alt="github actions chaves secretas" width="880" height="495"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;acredito que todas as chaves sejam auto explicativas, mas ao criar um usuário no &lt;a href="https://docs.aws.amazon.com/pt_br/IAM/latest/UserGuide/id_users_create.html"&gt;IAM da AWS&lt;/a&gt; você terá acesso a essas chaves.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;o nome do bucket e a região vão depender do que você colocou na AWS, em suas configurações.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;S3_BUCKET 
S3_BUCKET_REGION
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;o &lt;code&gt;CLOUDFRONT_DISTRIBUTION_ID&lt;/code&gt; você vai encontrar aqui:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--AdOYSaD---/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/oo05cqyx6v5v0rzulerl.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--AdOYSaD---/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/oo05cqyx6v5v0rzulerl.png" alt="id da distribuição" width="880" height="245"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;resumindo: toda vez que alguém fizer um pull request na branch main, esse processo vai acontecer.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;todos os arquivos vão ser enviados para o S3&lt;/li&gt;
&lt;li&gt;a distribuição será invalidada e o cache será refeito&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;agora sim, temos um site entregue, (melhor que ótimo) com um cache, segurança e um processo automatizado para não haver erros na hora de colocar algo no ar.&lt;/p&gt;

&lt;p&gt;é isso, espero que gostem. por favor, preciso de feedback para entender melhor minha escrita e como torná-la menos entediante.&lt;/p&gt;

&lt;p&gt;até +&lt;/p&gt;

&lt;p&gt;github: &lt;a href="https://github.com/99mvps/landing-page"&gt;https://github.com/99mvps/landing-page&lt;/a&gt;&lt;/p&gt;

</description>
      <category>html</category>
      <category>javascript</category>
      <category>aws</category>
      <category>99mvps</category>
    </item>
  </channel>
</rss>
