Configurando VLans para segmentar nuestra red, podemos tener varias redes lógicas, con direcciones IPs diferentes.
Sabiendo de eso, cuando fui contratado por una empresa para arreglar la red en un nuevo edificio, me encontré con el siguiente escenario: En el edificio funcionan cuatro departamentos: Financiero, Comercial, RH y Jurídica y cada departamento tienen, en media, 50 hosts.
El departamento comercial envía muchas propuestas técnicas que son archivos bien pesados, por eso la red de todos los departamentos está quedando lenta e inestable.
Además de eso, como todos los departamentos están en la misma red, o sea, en caso de que algún departamento tenga un problema, todos los departamentos serán afectados.
Entonces, vamos atribuir las direcciones de cada departamento. Nosotros podemos utilizar cualquier IP privado para eso, como son pocos hosts. Voy a utilizar las direcciones de clase C(192.168.x.x).
Podemos atribuir por ejemplo un departamento con la dirección de red 192.168.0.0
, otro con 192.168.1.0
y así en adelante.
Esa es una opción totalmente correcta, pero si paramos para analizar, con ese tipo de configuración, vamos a estar desperdiciando direcciones IPs.
Nosotros podemos dividir nuestra red en partes menores, cada una representando un departamento, o sea, dividimos nuestra red en subredes.
Toda dirección IP tiene una máscara correspondiente. Esa máscara que identifica cuál parte de la dirección pertenece a la red y cuál parte al host.
Por ejemplo, la dirección 192.168.0.50
con una máscara 255.255.255.0
, identifica como parte de la red la dirección 192.168.0
y el host como 50
:
Red: 192,168,0
Host: 50
Para dividir esa red, nosotros podemos “dividir” esa máscara. Para eso, podemos usar valores diferentes entre 0
o 255
. Cuando hacemos eso, damos el nombre de subred
Pero ¿cuáles valores podemos colocar?
Cada tres dígitos en la máscara, corresponden a una parte de la dirección IP de host. Esas partes son formadas por ocho bits, por eso reciben el nombre de octetos.
Cada bit en el octeto, posee un valor en decimal correspondiente a su posición
Por ser bits, solo poseen dos estados, el 0, representando el host, el 1, representando la red.
En este caso, la máscara (255.255.255.0
), puede ser representada en binario como: 11111111.11111111.11111111.0000000
.
Máscara: 255,255,255,0
Binario: 11111111,11111111,11111111,00000000
Caso todos los ocho bits de la máscara de subred posean valor 1
, el valor en decimal es 255
, caso todos los bits fueran 0
, posee el valor 0
en decimal.
1
, el valor en decimal que queda es 255
?esa es por causa de la conversión de binario para decimall.
Vimos que los bits 1
en la máscara especifican la porción de la red y que los bits 0
especifican el host en la dirección IP. Para crear nuestra red, podemos tomar algún bit 0
y transformarlos en 1
.
Por ejemplo, si tomamos el primer bit 0
en la máscara y transformarlo en bit 1
, tendríamos la siguiente máscara en binario: 11111111.11111111.11111111.1000000
Y ¿cómo queda el valor de ella en decimal?
Sabemos que los tres primeros octetos tienen el valor en decimal de 255
. ya para saber el valor del último, basta realizar la conversión:
2^7,2^6,2^5,2^4,2^3,2^2,2^1,2^0
1,0,0,0,0,0,0,0
O sea, tenemos: 1 x 2^7 + 0 x 2^6 + 0 x 2^5 + 0 x 2^4 + 0 x 2^3 + 0 x 2^2 + 0 x 2^1 + 0 x 2^0. Que nos deja con128
.
Luego, la máscara de esa red es: 255.255.255.128
.
Pero ¿cuántas redes tenemos con esa máscara?
Para saber cuántas redes tenemos con esa nueva máscara basta elevar el número 2, que son el número de bits posibles, al número de bits emprestados de la porción del host.
En este caso tomamos un bit de la porción del host, por tanto, tenemos 2^1 redes. O sea, tenemos dos redes.
Y ¿cuántos hosts contiene cada red?
Los hosts son definidos como bits 0
en la máscara de subred, ¿cierto? Entonces para saber cuántos hosts admite nuestra red, basta elevar 2
al número de bits 0
en la máscara.
En este caso tenemos siete bits 0
(10000000
), luego, 2^7, que nos da 128.
¿Entonces cada una de nuestras redes componen 128 hosts?
Entre las direcciones IPs, dos necesitan ser reservados. Uno para especificar la red y el otro para especificar el dominio de broadcast. Entonces, en verdad tenemos 128 - 2 hosts, luego tenemos 126
hosts en cada subred.
Y ¿cuáles son esas direcciones reservadas?
La dirección que especifica la red es siempre la primera dirección IP, ya el de broadcast es la última dirección IP de la red.
En una red clase C con máscara patrón, la dirección de la red es 192.168.0.0
y el de broadcast es 192.168.0.255
. Solo que, en nuestro caso, son dos subredes, cada una con una dirección de red y de broadcast.
La primera red posee la dirección de red 192.168.0.0
, ya la dirección de broadcast nosotros descubrimos sumando 1
al número de hosts, que en este caso son 126
, más la dirección de red. O sea, tenemos 1 + 126 + 0. De esta forma tenemos que la dirección de broadcast de la primera subred es 192.168.0.127
.
ya la dirección de red de la segunda subred es la dirección de broadcast de la primera subred más 1
. O sea, tenemos como dirección de la red la segunda subred 192.168.0.128
. La dirección de broadcast conseguimos obtener de la misma forma.
Sumamos 1
al número de hosts, más la dirección de red. Por tanto, 1 + 126 + 128, eso nos da la dirección de broadcast 192.168.0.255
.
Bueno, calculamos las subredes, pero con esa máscara tenemos apenas dos subredes. Sin embargo, tenemos cuatro departamentos y queremos colocar cada uno en una subred. ¿Cómo podemos hacer eso?
Si nosotros tomamos un bit a más de la máscara de subred del ejemplo anterior. Entonces, tendremos dos elevado a dos, que es el número de bits que tomamos en la porción de host, eso nos deja con cuatro que es el número de subred que queremos.
O sea, nuestra máscara quedará en binario: 11111111.11111111.11111111.1100000
. Realizando la conversión:
2^7,2^6,2^5,2^4,2^3,2^2,2^1,2^0 1,1,0,0,0,0,0,0
Luego: 1 x 2^7 + 1 x 2^6 + 0 x 2^5 + 0 x 2^4 + 0 x 2^3 + 0 x 2^2 + 0 x 2^1 + 0 x 2^0. Que nos deja con 192
.
O sea, nuestra máscara de subred será 255.255.255.192
. Pero ¿cuántos hosts admitirá cada subred ?
Para saber eso, basta elevar 2
al número de bits 0
en la máscara, menos los dos bits reservados de cada red, o sea, como tenemos seis bits cero nuestra cuenta queda 2^6 - 2, eso nos deja con 62 hosts para cada red.
Si quisiéramos saber cuál es la dirección de cada subred, basta realizar los mismos pasos de antes.
La dirección de red primera subred será 192.168.0.0
, ya su de broadcast será uno más el número de hosts más la dirección de red. eso nos deja con 1 + 62 + 0. Luego, la dirección de broadcast de nuestra primera subred será 192.168.0.63
.
De esa forma, después de calcular cada subred tendremos el siguiente resultado:
Red: 192.168.0.0,
Broadcast: 192.168.0.63
Red: 192.168.0.64,
Broadcast: 192.168.0.127
Red: 192.168.0.128,
Broadcast: 192.168.0.191
Red: 192.168.0.192,
Broadcast: 192.168.0.255
Todas esas direcciones utilizando la máscara 255.255.255.192
.
De esa forma conseguimos colocar cada departamento en una subred, lo que optimiza la red y aislar los problemas.
Como cada subred es una red distinta, ellas necesitan de un ruteador para que se comuniquen unas con las otras.
En este ejemplo, utilizamos un IP da clase C para crear las subredes, sin embargo, conseguimos realizar esa configuración con todas las clases de IPs disponibles.
Nosotros podemos utilizar otra connotación cuando hablamos de máscaras de rede. En vez de utilizar la máscara en su formato decimal, podemos decir apenas la cantidad de bits 1 contenidos en ella.
Por ejemplo, la máscara patrón de la clase C, 255.255.255.0
, en formato binario queda 11111111.11111111.11111111.0000000
. O sea, ella tiene 24
bits 1
. Entonces en caso que deseemos hablar que la dirección IP 192.168.0.35
utiliza la máscara patrón, podemos utilizar la connotación /24
. quedando así: 192.168.0.35 /24
.
El nombre de esa connotación es: CIDR.
Atribuir direcciones IPs a las redes es uno de los trabajos de un administrador de redes. Saber cuál dirección atribuir y cuál máscara utilizar hace parte de ese trabajo.
Cuando estamos instalando una red, sería bueno si separásemos los departamentos para aislar posibles problemas, mejorar el desempeño de la red, además de la seguridad.
Una forma de hacer eso es creando VLans, por tanto, mismo con esa configuración, algunas redes pueden tener problemas con el broadcast. Entonces una forma de resolver eso es dividiendo la red en partes menores, creando subredes.
Alura Latam tiene variados cursos de redes. En los cuales son presentados los conceptos de subredes y diversas otras situaciones interesantes de utilizar.
Yuri Matheus
Yuri es desarrollador e instructor. Es estudiante de Sistemas de Información en FIAP y graduado como Técnico en Informática en el Senac SP. Su enfoque es en las plataformas Java y Python y en otras áreas como Arquitectura de Software y Machine Learning. Yuri también actúa como editor de contenido en el blog de Alura, donde escribe, principalmente, sobre Redes, Docker, Linux, Java y Python.
Cursos de Programación, Front End, Data Science, Innovación y Gestión.
Luri es nuestra inteligencia artificial que resuelve dudas, da ejemplos prácticos y ayuda a profundizar aún más durante las clases. Puedes conversar con Luri hasta 100 mensajes por semana
Paga en moneda local en los siguientes países
Cursos de Programación, Front End, Data Science, Innovación y Gestión.
Luri es nuestra inteligencia artificial que resuelve dudas, da ejemplos prácticos y ayuda a profundizar aún más durante las clases. Puedes conversar con Luri hasta 100 mensajes por semana
Paga en moneda local en los siguientes países
Puedes realizar el pago de tus planes en moneda local en los siguientes países:
País | |||||||
---|---|---|---|---|---|---|---|
Plan Semestral |
487.37
BOB |
69289.36
CLP |
307472.10
COP |
65.90
USD |
264.35
PEN |
1435.53
MXN |
2978.57
UYU |
Plan Anual |
738.82
BOB |
105038.04
CLP |
466107.17
COP |
99.90
USD |
400.74
PEN |
2176.17
MXN |
4515.32
UYU |
Acceso a todos
los cursos
Estudia las 24 horas,
dónde y cuándo quieras
Nuevos cursos
cada semana