<?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: Jann Carlo Martinez</title>
    <description>The latest articles on DEV Community by Jann Carlo Martinez (@jannkee).</description>
    <link>https://dev.to/jannkee</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%2F3907022%2F1546c7ca-9611-45dc-a816-a4a1b6cf23f5.jpeg</url>
      <title>DEV Community: Jann Carlo Martinez</title>
      <link>https://dev.to/jannkee</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/jannkee"/>
    <language>en</language>
    <item>
      <title>Cómo limité el acceso SSH a una sola IP en AWS — mi primera implementación de Least Privilege</title>
      <dc:creator>Jann Carlo Martinez</dc:creator>
      <pubDate>Fri, 01 May 2026 05:10:49 +0000</pubDate>
      <link>https://dev.to/jannkee/como-limite-el-acceso-ssh-a-una-sola-ip-en-aws-mi-primera-implementacion-de-least-privilege-3a2k</link>
      <guid>https://dev.to/jannkee/como-limite-el-acceso-ssh-a-una-sola-ip-en-aws-mi-primera-implementacion-de-least-privilege-3a2k</guid>
      <description>&lt;h2&gt;
  
  
  El problema que nadie menciona en los tutoriales
&lt;/h2&gt;

&lt;p&gt;La mayoría de guías de AWS te dicen: "abre el puerto 22 para conectarte por SSH" y configuran el acceso desde &lt;code&gt;0.0.0.0/0&lt;/code&gt;. Eso significa que cualquier persona en internet puede intentar conectarse a tu servidor.&lt;/p&gt;

&lt;p&gt;Es un desastre de seguridad. Y es el punto de partida de este laboratorio.&lt;/p&gt;




&lt;h2&gt;
  
  
  ¿Qué construí?
&lt;/h2&gt;

&lt;p&gt;Un Security Group en AWS configurado bajo el principio de &lt;strong&gt;Least Privilege&lt;/strong&gt;: conceder solo los permisos mínimos necesarios. En este caso, acceso SSH restringido exclusivamente a mi IP pública.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Servicios utilizados:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;VPC por defecto de AWS&lt;/li&gt;
&lt;li&gt;EC2 Security Groups&lt;/li&gt;
&lt;li&gt;AWS CLI&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Conceptos clave antes de arrancar
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Security Group:&lt;/strong&gt; es el firewall virtual de AWS. Controla qué tráfico puede entrar y salir de tus recursos.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;CIDR /32:&lt;/strong&gt; notación que representa una única dirección IP. Si pones &lt;code&gt;203.0.113.10/32&lt;/code&gt;, solo esa IP específica tiene acceso. No el vecino. No un atacante con tu misma red.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Least Privilege:&lt;/strong&gt; principio fundamental de seguridad. No des más permisos de los necesarios. Si alguien solo necesita leer, no le des permisos de escritura. Si solo tu IP necesita acceso SSH, no abras el puerto al mundo.&lt;/p&gt;




&lt;h2&gt;
  
  
  Paso 1: Obtener tu IP pública
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;curl https://checkip.amazonaws.com
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Guarda ese número. Lo vas a usar en el Paso 4.&lt;/p&gt;




&lt;h2&gt;
  
  
  Paso 2: Obtener el ID de tu VPC por defecto
&lt;/h2&gt;

&lt;p&gt;AWS crea una VPC por defecto en cada región lista para usar. La consultamos así:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;aws ec2 describe-vpcs &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--filters&lt;/span&gt; &lt;span class="s2"&gt;"Name=isDefault,Values=true"&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--query&lt;/span&gt; &lt;span class="s1"&gt;'Vpcs[0].VpcId'&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--output&lt;/span&gt; text
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Resultado esperado: algo como &lt;code&gt;vpc-0a1b2c3d4e5f6g7h8&lt;/code&gt;&lt;/p&gt;




&lt;h2&gt;
  
  
  Paso 3: Crear el Security Group
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;&lt;span class="nv"&gt;SECURITY_GROUP_ID&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="si"&gt;$(&lt;/span&gt;aws ec2 create-security-group &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--group-name&lt;/span&gt; &lt;span class="s2"&gt;"proyecto-seguridad"&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--description&lt;/span&gt; &lt;span class="s2"&gt;"Security group - acceso restringido a IP específica"&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--vpc-id&lt;/span&gt; &lt;span class="si"&gt;$(&lt;/span&gt;aws ec2 describe-vpcs &lt;span class="se"&gt;\&lt;/span&gt;
    &lt;span class="nt"&gt;--filters&lt;/span&gt; &lt;span class="s2"&gt;"Name=isDefault,Values=true"&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
    &lt;span class="nt"&gt;--query&lt;/span&gt; &lt;span class="s1"&gt;'Vpcs[0].VpcId'&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
    &lt;span class="nt"&gt;--output&lt;/span&gt; text&lt;span class="si"&gt;)&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--query&lt;/span&gt; &lt;span class="s1"&gt;'GroupId'&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--output&lt;/span&gt; text&lt;span class="si"&gt;)&lt;/span&gt;

&lt;span class="nb"&gt;echo&lt;/span&gt; &lt;span class="nv"&gt;$SECURITY_GROUP_ID&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;La variable &lt;code&gt;$SECURITY_GROUP_ID&lt;/code&gt; almacena el ID para los siguientes comandos. Resultado esperado: &lt;code&gt;sg-0123456789abcdef0&lt;/code&gt;&lt;/p&gt;




&lt;h2&gt;
  
  
  Paso 4: Crear la regla de acceso — solo desde tu IP
&lt;/h2&gt;

&lt;p&gt;⚠️ Reemplaza &lt;code&gt;203.0.113.10&lt;/code&gt; con la IP que obtuviste en el Paso 1.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;aws ec2 authorize-security-group-ingress &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--group-id&lt;/span&gt; &lt;span class="nv"&gt;$SECURITY_GROUP_ID&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--protocol&lt;/span&gt; tcp &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--port&lt;/span&gt; 22 &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--cidr&lt;/span&gt; 203.0.113.10/32
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;El &lt;code&gt;/32&lt;/code&gt; es lo que hace toda la diferencia. Sin él, estarías abriendo un rango de IPs. Con él, es solo la tuya.&lt;/p&gt;




&lt;h2&gt;
  
  
  Paso 5: Verificar que todo quedó bien
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;aws ec2 describe-security-groups &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--group-ids&lt;/span&gt; &lt;span class="nv"&gt;$SECURITY_GROUP_ID&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--query&lt;/span&gt; &lt;span class="s1"&gt;'SecurityGroups[0].IpPermissions'&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--output&lt;/span&gt; table
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Deberías ver una tabla con el puerto 22, protocolo TCP, y tu IP con &lt;code&gt;/32&lt;/code&gt;.&lt;/p&gt;




&lt;h2&gt;
  
  
  Limpieza
&lt;/h2&gt;

&lt;p&gt;Siempre elimina los recursos cuando termines para evitar cargos inesperados:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;aws ec2 delete-security-group &lt;span class="nt"&gt;--group-id&lt;/span&gt; &lt;span class="nv"&gt;$SECURITY_GROUP_ID&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h2&gt;
  
  
  Lo que aprendí
&lt;/h2&gt;

&lt;p&gt;El mayor aprendizaje no fue el comando en sí, sino entender &lt;strong&gt;por qué&lt;/strong&gt; el &lt;code&gt;/32&lt;/code&gt; importa. La diferencia entre &lt;code&gt;0.0.0.0/0&lt;/code&gt; y &lt;code&gt;tu-ip/32&lt;/code&gt; es la diferencia entre dejar la puerta abierta a internet y entregarle una llave solo a quien la necesita.&lt;/p&gt;

&lt;p&gt;Eso es Least Privilege en la práctica. No es un concepto abstracto de libro, es una decisión de un comando.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;Este es el primer laboratorio de mi Road to DevOps. Cada semana voy a documentar lo que aprendo — sin filtros, con los errores incluidos.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>devops</category>
      <category>vpc</category>
      <category>aws</category>
      <category>securitygroup</category>
    </item>
  </channel>
</rss>
