<?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: Arnau Colominas</title>
    <description>The latest articles on DEV Community by Arnau Colominas (@acolominas).</description>
    <link>https://dev.to/acolominas</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%2F1236076%2Fb92b3dbd-5b25-4447-8562-eda1c4d1190e.JPG</url>
      <title>DEV Community: Arnau Colominas</title>
      <link>https://dev.to/acolominas</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/acolominas"/>
    <language>en</language>
    <item>
      <title>🚀 ECSGO o como hacer troubleshooting ⚙️ en ECS rapidamente</title>
      <dc:creator>Arnau Colominas</dc:creator>
      <pubDate>Fri, 26 Jan 2024 12:07:01 +0000</pubDate>
      <link>https://dev.to/aws-espanol/ecsgo-o-como-hacer-troubleshooting-en-ecs-rapidamente-1bha</link>
      <guid>https://dev.to/aws-espanol/ecsgo-o-como-hacer-troubleshooting-en-ecs-rapidamente-1bha</guid>
      <description>&lt;p&gt;Todos los que hemos usado &lt;a href="https://aws.amazon.com/ecs/"&gt;ECS&lt;/a&gt; (Elastic Container Service) estamos acostumbrados a visitar Cloudwatch regularmente para ver los logs y a partir de ahí depurar ciertos errores. &lt;/p&gt;

&lt;p&gt;Hay veces que unicamente viendo las trazas de los logs no es suficiente. Nos gustaría poder estar dentro del contenedor y poder ejecutar ciertos comandos para realizar un examen más exhaustivo de lo que está pasando. Por ejemplo: depuración de networking... &lt;/p&gt;

&lt;p&gt;Vamos, el típico &lt;strong&gt;docker exec -it [container-id]&lt;/strong&gt; de toda la vida. &lt;/p&gt;

&lt;p&gt;Para este caso existe la herramienta &lt;a href="https://github.com/tedsmitt/ecsgo"&gt;ECSGO&lt;/a&gt; que nos facilita mucho la vida. &lt;/p&gt;

&lt;p&gt;Y en este post os voy a enseñar como configurarla y usarla!&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Hay que recordar que, ejecutar comandos dentro de un container únicamente está aconsejado para tareas de troubleshooting. Si realizamos cambios en el contenedor, una vez este se termine, estos cambios se perderán. Los cambios siempre en Dockerfile!&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h2&gt;
  
  
  📍&lt;strong&gt;Qué es ECSGO?&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;ECSGO es una herramienta que facilita la conexion a contenedores que estan corriendo en ECS (ya sea en EC2 o Fargate). También se puede usar para hacer port-forwarding de un container a tu local. &lt;/p&gt;

&lt;p&gt;Esta herramienta está inspirada en &lt;a href="https://github.com/gjbae1212/gossm"&gt;gossm&lt;/a&gt;(Lo mismo pero para instancias EC2). &lt;/p&gt;

&lt;h2&gt;
  
  
  📍&lt;strong&gt;Cómo funciona ECSGO?&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;ECSGO utiliza la funcionalidad de &lt;a href="https://aws.amazon.com/blogs/containers/new-using-amazon-ecs-exec-access-your-containers-fargate-ec2/"&gt;ECS ExecuteCommand API &lt;/a&gt; . &lt;/p&gt;

&lt;p&gt;Anteriormente a ECS ExecuteCommand, la única manera de conectarnos a un contenedor en ejecución era:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Localizar la Instancia EC2 especifica en el cluster dónde la task a la que te quieres conectar esta corriendo&lt;/li&gt;
&lt;li&gt;Conectarte por SSH o SSM a la instancia&lt;/li&gt;
&lt;li&gt;Ejecutar docker exec al contenedor&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;(En el caso de que la task fuera serverless con FARGATE, ya podías olvidarte de poder conectar)&lt;/p&gt;

&lt;h2&gt;
  
  
  📍&lt;strong&gt;Pre-requisitos&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;Para poder usarlo, hay que configurar previamente ciertas cosas...&lt;/p&gt;

&lt;p&gt;1.El servicio de ECS debe tener activado el flag execute-command&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt; resource "aws_ecs_service" "service" {
   ...
   enable_execute_command = true
   ...
 }
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;2.El IAM role usado por la task debe tener ciertos permisos&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt; data "aws_iam_policy_document" "ecs-ssm" {
   statement {

     actions = [
       "ssmmessages:CreateControlChannel",
       "ssmmessages:CreateDataChannel",
       "ssmmessages:OpenControlChannel",
       "ssmmessages:OpenDataChannel"
     ]

     resources = ["*"]
   }
 }
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;3.Tener instalado &lt;a href="https://docs.aws.amazon.com/systems-manager/latest/userguide/session-manager-working-with-install-plugin.html"&gt;session-manager-plugin&lt;/a&gt; en tu portatil.&lt;/p&gt;

&lt;p&gt;Usa &lt;a href="https://github.com/aws-containers/amazon-ecs-exec-checker"&gt;ecs-exec-checker&lt;/a&gt; para comprobar los pre-requisitos antes de user ECS Exec.&lt;/p&gt;

&lt;p&gt;Además deberemos tener configurada la AWS-CLI y disponer de un usuario IAM con permisos suficientes.&lt;/p&gt;

&lt;h2&gt;
  
  
  📍&lt;strong&gt;Vamos a probarlo!&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;Para instalar ECSGO vamos &lt;a href="https://github.com/tedsmitt/ecsgo/releases"&gt;https://github.com/tedsmitt/ecsgo/releases&lt;/a&gt; y nos descargamos el tar.gz con el binario para nuestro sistema.&lt;/p&gt;

&lt;p&gt;Ejecutamos ecsgo y nos aparecen los clusters ECS.&lt;br&gt;
Seleccionamos el cluster del container al que queremos conectarnos&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F3isuil6h02e6h6pzt1ps.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F3isuil6h02e6h6pzt1ps.png" alt="Lista de los ECS clusters" width="284" height="71"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Después de escoger el cluster ECS, nos muestra una lista con los servicios que estan corriendo dentro del cluster seleccionado previamente. Seleccionamos el servicio del container al que queremos conectarnos.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fz0qznt628il7p2y3jwfz.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fz0qznt628il7p2y3jwfz.png" alt="Lista de los servicios ECS" width="494" height="88"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Finalmente nos aparecen las tareas dentro del servicio, es decir, los containers. Seleccionamos el container al que queremos conectarnos.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fn4to2e1b8go12jpux8gw.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fn4to2e1b8go12jpux8gw.png" alt="Lista de las Tasks" width="569" height="85"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Ya estamos dentro!&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fdxv32nkr9xn983u9ize7.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fdxv32nkr9xn983u9ize7.png" alt="Image description" width="567" height="175"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;A partir de aqui, pues ya podemos ejecutar comandos básicos de troubleshooting...&lt;/p&gt;

&lt;p&gt;Hasta el próximo post!&lt;/p&gt;

</description>
      <category>aws</category>
      <category>devops</category>
      <category>ecs</category>
      <category>docker</category>
    </item>
  </channel>
</rss>
