Поочередная настройка оборудования на конкретном примере сети: различия между версиями
м (→NAT) |
(→SSH) |
||
(не показано 25 промежуточных версий 2 участников) | |||
Строка 13: | Строка 13: | ||
Настроим туннель на RTR-HQ командой | Настроим туннель на RTR-HQ командой | ||
nmcli connection add type ip-tunnel ip-tunnel.mode ipip con-name tun0 ifname tun0 ipv4.address 10.0.0.1/30 ipv4.method manual remote <172.16. | nmcli connection add type ip-tunnel ip-tunnel.mode ipip con-name tun0 ifname tun0 ipv4.address 10.0.0.1/30 ipv4.method manual remote <172.16.1.2 IP-адрес RTR-BR> local <172.16.2.2 IP-адрес RTR-HQ> | ||
Настроим туннель на RTR-BR командой nmcli connection add type ip-tunnel ip-tunnel.mode ipip con-name tun0 ifname tun0 ipv4.address 10.0.0.2/30 ipv4.method manual remote <172.16. | Настроим туннель на RTR-BR командой | ||
nmcli connection add type ip-tunnel ip-tunnel.mode ipip con-name tun0 ifname tun0 ipv4.address 10.0.0.2/30 ipv4.method manual remote <172.16.2.2 IP-адрес RTR-HQ> local <172.16.1.2 IP-адрес RTR-BR> | |||
==VLAN== | ==VLAN== | ||
==SWITCH== | ===SWITCH=== | ||
Обновим список пакетов командой | Обновим список пакетов командой | ||
Строка 31: | Строка 32: | ||
ovs-vsctl add-br HQ-SW | ovs-vsctl add-br HQ-SW | ||
Настроим порт на созданном коммутаторе в сторону роутера командой | Настроим порт на созданном коммутаторе в сторону роутера командой | ||
ovs-vsctl add-port HQ-SW ens3 trunks=100, 200 | ovs-vsctl add-port HQ-SW ens3 trunks=100,200 | ||
, где ensX - это интерфейс в сторону RTR-HQ | , где ensX - это интерфейс в сторону RTR-HQ | ||
Настроим порт доступа в сторону первого клиента командой | Настроим порт доступа в сторону первого клиента командой | ||
ovs-vsctl add-port HQ-SW ens4 tag= | ovs-vsctl add-port HQ-SW ens4 tag=100 | ||
где ensX - это интерфейс в сторону HQ-SRV | где ensX - это интерфейс в сторону HQ-SRV | ||
Настроим порт доступа в сторону второго клиента командой | Настроим порт доступа в сторону второго клиента командой | ||
ovs-vsctl add-port HQ-SW ens5 tag= | ovs-vsctl add-port HQ-SW ens5 tag=200 | ||
где ensX - это интерфейс в сторону HQ-CLI | где ensX - это интерфейс в сторону HQ-CLI | ||
==HQ-RTR== | |||
===HQ-RTR=== | |||
Перейдем на RTR-HQ | Перейдем на RTR-HQ | ||
Строка 50: | Строка 54: | ||
Добавим интерфейс для 100 VLAN командой | Добавим интерфейс для 100 VLAN командой | ||
nmcli con add type vlan con-name ens4 dev ens4 id 100 ipv4.address 192.168. | nmcli con add type vlan con-name ens4 dev ens4 id 100 ipv4.address 192.168.10.1/26 ipv4.method manual | ||
где ensX - интерфейс в сторону SW-HQ | где ensX - интерфейс в сторону SW-HQ | ||
Добавим интерфейс для 200 VLAN командой | Добавим интерфейс для 200 VLAN командой | ||
nmcli con add type vlan con-name ens4 dev ens4 id 200 ipv4.address 192.168. | nmcli con add type vlan con-name ens4 dev ens4 id 200 ipv4.address 192.168.20.1/28 ipv4.method manual | ||
где ensX - интерфейс в сторону SW-HQ | где ensX - интерфейс в сторону SW-HQ | ||
Строка 85: | Строка 89: | ||
</pre> | </pre> | ||
Сохраним и выйдем | Сохраним и выйдем | ||
== DHCP == | |||
apt-get update | apt-get update | ||
apt-get install dhcp-server | apt-get install dhcp-server | ||
Строка 95: | Строка 100: | ||
ddns-update-style none; | ddns-update-style none; | ||
subnet 192.168. | subnet 192.168.20.0 netmask 255.255.255.240 { | ||
option routers 192.168. | option routers 192.168.20.1; | ||
option subnet-mask 255.255.255. | option subnet-mask 255.255.255.240; | ||
option domain-name "au-team.ipo"; | option domain-name "au-team.ipo"; | ||
option domain-name-servers 192.168. | option domain-name-servers 192.168.10.2; | ||
range dynamic-bootp 192.168. | range dynamic-bootp 192.168.20.2 192.168.20.14; | ||
default-lease-tame 21600; | default-lease-tame 21600; | ||
max-lease-time 43200; | max-lease-time 43200; | ||
} | } | ||
host HQ-CLI { | host HQ-CLI { | ||
!!! hardware ethernet 50:5f:c8:0d:00; | |||
fixed-address 192.168.20.2; | |||
} | } | ||
Строка 114: | Строка 119: | ||
Настроим на каком интерфейсе будет работать Наш DHCP-сервер, для этого откроем файл | Настроим на каком интерфейсе будет работать Наш DHCP-сервер, для этого откроем файл | ||
mcedit /etc/sysconfig/dhcpd | mcedit /etc/sysconfig/dhcpd | ||
В строке DHCPARGS после знака = ens4. | В строке DHCPARGS после знака = ens4.200 | ||
Сохраним и выйдем. | Сохраним и выйдем. | ||
Строка 137: | Строка 142: | ||
Поменяем в строке ospfd с no на yes | Поменяем в строке ospfd с no на yes | ||
Выходим | Выходим. | ||
Перезагружаем службу frr командой | Перезагружаем службу frr командой | ||
Строка 153: | Строка 158: | ||
Объявим сеть туннеля в ospf командой | Объявим сеть туннеля в ospf командой | ||
network 10.0.0.0/30 area 0 | network 10.0.0.0/30 area 0 | ||
Объявим сеть первого VLAN 192.168. | Объявим сеть первого VLAN 192.168.10.0/26 командой | ||
network 192.168. | network 192.168.10.0/26 area 1 | ||
Объявим сеть второго VLAN 192.168. | Объявим сеть второго VLAN 192.168.20.0/28 командой | ||
network 192.168. | network 192.168.20.0/28 area 1 | ||
{{Attention|network 192.168.30.0/27 area 1 - Сеть br}} | |||
Выйдем в режим глобальной конфигурации командой | Выйдем в режим глобальной конфигурации командой | ||
exit | exit | ||
Строка 181: | Строка 189: | ||
Сохраним настройки для этого выйдем в пользовательский режим сочетанием клавиш Ctrl+Z и сохраним командой | Сохраним настройки для этого выйдем в пользовательский режим сочетанием клавиш Ctrl+Z и сохраним командой | ||
write | write | ||
Проверка | |||
sh ip ospf nei | |||
Выходим из vtysh командой | Выходим из vtysh командой | ||
exit | exit | ||
== DNS == | |||
Установим локальный DNS-сервер и текстовый редактор nano командой | |||
apt-get install nano bind bind-utils -y | |||
Открываем файл /etc/bind/options.conf командой | |||
nano /etc/bind/options.conf | |||
В строке listen-on меняем 127.0.0.1 на any | |||
Раскомментируем строку forwarders (убираем //) и между фигурными скобками указываем адрес DNS-сервера на который будем ссылаться при отсутствии необходимой записи на локальном сервере. В нашем случае указываем 77.88.8.8; | |||
Также раскомментируем строку allow-query и меняем в ней localnets на any | |||
Сохраняем и закрываем файл. | |||
Переходим непосредственно к настройке зоны. Для этого открываем файл /etc/bind/local.conf командой nano /etc/bind/local.conf | |||
Добавляем в конец информацию о Нашей зоне: | |||
zone "au-team.irpo" { | |||
type master; | |||
file "au-team.irpo"; | |||
}; | |||
zone "10.168.192.in-addr.arpa" { | |||
type master; | |||
file "au-team_rev1.irpo"; | |||
}; | |||
zone "20.168.192.in-addr.arpa" { | |||
type master; | |||
file "au-team_rev2.irpo"; | |||
}; | |||
zone "30.168.192.in-addr.arpa" { | |||
type master; | |||
file "au-team_rev3.irpo"; | |||
}; | |||
Сохраняем и выходим | |||
sudo nano /etc/bind/zone/au-team.irpo | |||
Заполните его следующими данными: | |||
$TTL 1D | |||
@ IN SOA au-team.irpo. root.au-team.irpo. ( | |||
2024021400 ; serial | |||
12H ; refresh | |||
1H ; retry | |||
1W ; expire | |||
1H ; ncache | |||
) | |||
IN NS au-team.irpo. | |||
IN A 192.168.10.2 | |||
hq-rtr IN A 192.168.10.1 | |||
hq-rtr IN A 192.168.20.1 | |||
br-rtr IN A 192.168.30.1 | |||
hq-srv IN A 192.168.10.2 | |||
hg-cli IN A 192.168.20.2 | |||
br-srv IN A 192.168.30.2 | |||
moodle IN CNAME hq-rtr.au-team.irpo. | |||
wiki IN CNAME hq-rtr.au-team.irpo. | |||
Сохраняем и выходим | |||
sudo nano /etc/bind/zone/au-team_rev1.irpo | |||
Заполните его следующими данными: | |||
$TTL 1D | |||
@ IN SOA au-team.irpo. root.au-team.irpo. ( | |||
2024021400 ; serial | |||
12H ; refresh | |||
1H ; retry | |||
1W ; expire | |||
1H ; ncache | |||
) | |||
IN NS hq-srv.au-team.irpo. | |||
1 IN PTR hq-rtr.au-team.irpo. | |||
2 IN PTR hg-srv.au-team.irpo. | |||
Сохраняем и выходим | |||
sudo nano /etc/bind/zone/au-team_rev2.irpo | |||
Заполните его следующими данными: | |||
$TTL 1D | |||
@ IN SOA au-team.irpo. root.au-team.irpo. ( | |||
2024021400 ; serial | |||
12H ; refresh | |||
1H ; retry | |||
1W ; expire | |||
1H ; ncache | |||
) | |||
IN NS hq-srv.au-team.irpo. | |||
1 IN PTR hq-rtr.au-team.irpo. | |||
2 IN PTR hg-cli.au-team.irpo. | |||
Сохраняем и выходим | |||
sudo nano /etc/bind/zone/au-team_rev3.irpo | |||
Заполните его следующими данными: | |||
$TTL 1D | |||
@ IN SOA au-team.irpo. root.au-team.irpo. ( | |||
2024021400 ; serial | |||
12H ; refresh | |||
1H ; retry | |||
1W ; expire | |||
1H ; ncache | |||
) | |||
IN NS hq-srv.au-team.irpo. | |||
1 IN PTR br-rtr.au-team.irpo. | |||
2 IN PTR br-srv.au-team.irpo. | |||
Сохраняем и выходим | |||
Назначаем владельцем файла служебного пользователя named командой | |||
chown named /etc/bind/zone/domain.test.db | |||
Также для корректной работы с файлами зон необходимо настроить в качестве владельца файлов зон системного пользователя named командой | |||
chown named -R /etc/bind/zone/ | |||
Увеличиваем права пользователя командой | |||
chmod 710 /var/lib/bind/var | |||
Перезагружаем | |||
systemctl reestart bind | |||
Включаем | |||
systemctl enable --now bind | |||
На роуторах hq-rtr и br-rtr нужно прописать dns | |||
nmcli con modify ens3 ipv4.dns 192.168.10.2 | |||
После чего выключаем и включаем интерфейс | |||
==IP-ADDRESS== | ==IP-ADDRESS== | ||
ISP-NET-DHCP-DHCP | ISP-NET-DHCP-DHCP | ||
-HQRTR-172.16. | ISP-HQRTR-172.16.1.1/29 | ||
-BR-RTR-172.16. | HQ-RTR-ISP-172.16.1.2/29-GATEWAY-172.16.1.1 | ||
ISP-BR-RTR-172.16.2.1/29 | |||
-HQ-SRV-192.168. | BR-RTR-ISP-172.16.2.2/29-GATEWAY-172.16.2.1 | ||
-HQ-CLI-192.168. | HQ-RTR-HQ-SRV-192.168.10.1/26(VLAN100) | ||
HQ-RTR-HQ-CLI-192.168.20.1/28(VLAN200) | |||
BR-RTR-BR-SRV-192.168.30.1/27 | |||
HQ-SRV-HQ-RTR 192.168. | HQ-SRV-HQ-RTR 192.168.10.2/26-GATEWAY-192.168.10.1 | ||
BR-SRV-BR-RTR-192.168. | BR-SRV-BR-RTR-192.168.30.2/27-GATEWAY-192.168.30.1 | ||
HQ-CLI-HQ-RTR-192.168. | HQ-CLI-HQ-RTR-192.168.20.2/28-GATEWAY-192.168.20.1 |
Текущая версия от 20:19, 19 декабря 2024
NAT
На всех роуторах
iptables -t nat -A POSTROUTING -o ens3 -j MASQUERADE iptables -t mangle -A POSTROUTING -j TTL --ttl-set 65 iptables-save -f /etc/sysconfig/iptables systemctl enable --now iptables mcedit /etc/net/sysctl.conf ----- forward - 1
TUNNEL
Настроим туннель на RTR-HQ командой
nmcli connection add type ip-tunnel ip-tunnel.mode ipip con-name tun0 ifname tun0 ipv4.address 10.0.0.1/30 ipv4.method manual remote <172.16.1.2 IP-адрес RTR-BR> local <172.16.2.2 IP-адрес RTR-HQ>
Настроим туннель на RTR-BR командой
nmcli connection add type ip-tunnel ip-tunnel.mode ipip con-name tun0 ifname tun0 ipv4.address 10.0.0.2/30 ipv4.method manual remote <172.16.2.2 IP-адрес RTR-HQ> local <172.16.1.2 IP-адрес RTR-BR>
VLAN
SWITCH
Обновим список пакетов командой
apt-get update
Установим пакет OpenVSwitch командой
apt-get install openvswitch
Если сервис не запущен, то включаем его и сразу же добавляем в автозагрузку командой
systemctl enable --now openvswitch
Проверим что сервис OpenVSwitch работает командой
systemctl status openvswitch
Создадим виртуальный коммутатор HQ-SW командой
ovs-vsctl add-br HQ-SW
Настроим порт на созданном коммутаторе в сторону роутера командой
ovs-vsctl add-port HQ-SW ens3 trunks=100,200
, где ensX - это интерфейс в сторону RTR-HQ
Настроим порт доступа в сторону первого клиента командой
ovs-vsctl add-port HQ-SW ens4 tag=100
где ensX - это интерфейс в сторону HQ-SRV
Настроим порт доступа в сторону второго клиента командой
ovs-vsctl add-port HQ-SW ens5 tag=200
где ensX - это интерфейс в сторону HQ-CLI
HQ-RTR
Перейдем на RTR-HQ
Удалим созданный Нами в начале практической интерфейс в сторону внутренней сети командой
nmcli con del ensX
где ensX - это интерфейс в сторону внутренней сети.
Добавим интерфейс для 100 VLAN командой
nmcli con add type vlan con-name ens4 dev ens4 id 100 ipv4.address 192.168.10.1/26 ipv4.method manual
где ensX - интерфейс в сторону SW-HQ
Добавим интерфейс для 200 VLAN командой
nmcli con add type vlan con-name ens4 dev ens4 id 200 ipv4.address 192.168.20.1/28 ipv4.method manual
где ensX - интерфейс в сторону SW-HQ
SSH
Переходим на SRV1
Перед началом
Открываем файл настройки SSH командой
mcedit /etc/openssh/sshd_config
Раскомментируем строку Port и изменяем 22 на 2024
Укажем количество попыток входа, для этого раскомментируем строку MaxAuthTries и изменим количество попыток на 2
Настроим баннер при подключении для пользователя, для этого раскомментируем строку Banner и укажем путь к файлу с текстом заменив значение по-умолчания на /etc/motd
Сохраним и выйдем
Создадим файл /etc/motd командой mcedit /etc/motd
Заполним файл следующим содержимым:
-------------------------------------------------------------------------------------- -------------------------------------------------------------------------------------- Authorized access only! --------------------------------------------------------------------------------------- ---------------------------------------------------------------------------------------
Сохраним и выйдем
DHCP
apt-get update apt-get install dhcp-server cp /etc/dhcp/dhcpd.conf.sample /etc/dhcp/dhcpd.conf
mcedit /etc/dhcp/dhcp.conf
ddns-update-style none; subnet 192.168.20.0 netmask 255.255.255.240 { option routers 192.168.20.1; option subnet-mask 255.255.255.240; option domain-name "au-team.ipo"; option domain-name-servers 192.168.10.2; range dynamic-bootp 192.168.20.2 192.168.20.14; default-lease-tame 21600; max-lease-time 43200; } host HQ-CLI { !!! hardware ethernet 50:5f:c8:0d:00; fixed-address 192.168.20.2; }
Сохраним и выйдем
Настроим на каком интерфейсе будет работать Наш DHCP-сервер, для этого откроем файл
mcedit /etc/sysconfig/dhcpd
В строке DHCPARGS после знака = ens4.200
Сохраним и выйдем.
Перезапустим службу, отвечающую за DHCP-сервер командой
systemctl restart dhcpd.service
Добавим службу в автозагрузку командой
systemctl enable --now dhcpd.service
OSPF
Перейдем на RTR-HQ
Обновим список пакетов командой
apt-get update
Установим пакет frr командой
apt-get install frr
Включим демон ospfd для этого:
Откроем файл /etc/frr/daemons командой
mcedit /etc/frr/deamons
Поменяем в строке ospfd с no на yes
Выходим.
Перезагружаем службу frr командой
systemctl restart frr
Добавим frr в автозагрузку командой
systemctl enable --now frr
Заходим в frr командой
vtysh
Переходим в режим глобальной конфигурации командой
conf t
Заходим в процесс маршрутизации командой
router ospf
Настроим Router ID равным 1.1.1.1 командой
ospf router-id 1.1.1.1
Объявим сеть туннеля в ospf командой
network 10.0.0.0/30 area 0
Объявим сеть первого VLAN 192.168.10.0/26 командой
network 192.168.10.0/26 area 1
Объявим сеть второго VLAN 192.168.20.0/28 командой
network 192.168.20.0/28 area 1
Выйдем в режим глобальной конфигурации командой
exit
Перейдем в режим настройки интерфейса командой
interface tun0
Включим аутентификацию OSPF командой
ip ospf authentication
Настроим авторизацию OSPF по ключу DEMO командой
ip ospf authentication-key DEMO
Выйдем из режима настройки интерфейса командой
exit
Перейдем на подинтерфейс в сторону первого VLAN командой
interface ens4.100
Отключим рассылку пакетов ospf на этом интерфейсе командой
ip ospf passive
Перейдем на подинтерфейс в сторону второго VLAN командой
interface ens4.200
Отключим рассылку пакетов ospf на этом интерфейсе командой
ip ospf passive
Перейдем на интерфейс в сторону внешней сети командой
interface ens3
Отключим рассылку пакетов ospf на этом интерфейсе командой
ip ospf passive
Сохраним настройки для этого выйдем в пользовательский режим сочетанием клавиш Ctrl+Z и сохраним командой
write
Проверка
sh ip ospf nei
Выходим из vtysh командой
exit
DNS
Установим локальный DNS-сервер и текстовый редактор nano командой
apt-get install nano bind bind-utils -y
Открываем файл /etc/bind/options.conf командой
nano /etc/bind/options.conf
В строке listen-on меняем 127.0.0.1 на any
Раскомментируем строку forwarders (убираем //) и между фигурными скобками указываем адрес DNS-сервера на который будем ссылаться при отсутствии необходимой записи на локальном сервере. В нашем случае указываем 77.88.8.8;
Также раскомментируем строку allow-query и меняем в ней localnets на any
Сохраняем и закрываем файл.
Переходим непосредственно к настройке зоны. Для этого открываем файл /etc/bind/local.conf командой nano /etc/bind/local.conf
Добавляем в конец информацию о Нашей зоне:
zone "au-team.irpo" { type master; file "au-team.irpo"; }; zone "10.168.192.in-addr.arpa" { type master; file "au-team_rev1.irpo"; }; zone "20.168.192.in-addr.arpa" { type master; file "au-team_rev2.irpo"; }; zone "30.168.192.in-addr.arpa" { type master; file "au-team_rev3.irpo"; };
Сохраняем и выходим
sudo nano /etc/bind/zone/au-team.irpo
Заполните его следующими данными:
$TTL 1D @ IN SOA au-team.irpo. root.au-team.irpo. ( 2024021400 ; serial 12H ; refresh 1H ; retry 1W ; expire 1H ; ncache ) IN NS au-team.irpo. IN A 192.168.10.2 hq-rtr IN A 192.168.10.1 hq-rtr IN A 192.168.20.1 br-rtr IN A 192.168.30.1 hq-srv IN A 192.168.10.2 hg-cli IN A 192.168.20.2 br-srv IN A 192.168.30.2 moodle IN CNAME hq-rtr.au-team.irpo. wiki IN CNAME hq-rtr.au-team.irpo.
Сохраняем и выходим
sudo nano /etc/bind/zone/au-team_rev1.irpo
Заполните его следующими данными:
$TTL 1D @ IN SOA au-team.irpo. root.au-team.irpo. ( 2024021400 ; serial 12H ; refresh 1H ; retry 1W ; expire 1H ; ncache ) IN NS hq-srv.au-team.irpo. 1 IN PTR hq-rtr.au-team.irpo. 2 IN PTR hg-srv.au-team.irpo.
Сохраняем и выходим
sudo nano /etc/bind/zone/au-team_rev2.irpo
Заполните его следующими данными:
$TTL 1D @ IN SOA au-team.irpo. root.au-team.irpo. ( 2024021400 ; serial 12H ; refresh 1H ; retry 1W ; expire 1H ; ncache ) IN NS hq-srv.au-team.irpo. 1 IN PTR hq-rtr.au-team.irpo. 2 IN PTR hg-cli.au-team.irpo.
Сохраняем и выходим
sudo nano /etc/bind/zone/au-team_rev3.irpo
Заполните его следующими данными:
$TTL 1D @ IN SOA au-team.irpo. root.au-team.irpo. ( 2024021400 ; serial 12H ; refresh 1H ; retry 1W ; expire 1H ; ncache ) IN NS hq-srv.au-team.irpo. 1 IN PTR br-rtr.au-team.irpo. 2 IN PTR br-srv.au-team.irpo.
Сохраняем и выходим
Назначаем владельцем файла служебного пользователя named командой
chown named /etc/bind/zone/domain.test.db
Также для корректной работы с файлами зон необходимо настроить в качестве владельца файлов зон системного пользователя named командой
chown named -R /etc/bind/zone/
Увеличиваем права пользователя командой
chmod 710 /var/lib/bind/var
Перезагружаем
systemctl reestart bind
Включаем
systemctl enable --now bind
На роуторах hq-rtr и br-rtr нужно прописать dns
nmcli con modify ens3 ipv4.dns 192.168.10.2
После чего выключаем и включаем интерфейс
IP-ADDRESS
ISP-NET-DHCP-DHCP ISP-HQRTR-172.16.1.1/29 HQ-RTR-ISP-172.16.1.2/29-GATEWAY-172.16.1.1 ISP-BR-RTR-172.16.2.1/29 BR-RTR-ISP-172.16.2.2/29-GATEWAY-172.16.2.1 HQ-RTR-HQ-SRV-192.168.10.1/26(VLAN100) HQ-RTR-HQ-CLI-192.168.20.1/28(VLAN200) BR-RTR-BR-SRV-192.168.30.1/27 HQ-SRV-HQ-RTR 192.168.10.2/26-GATEWAY-192.168.10.1 BR-SRV-BR-RTR-192.168.30.2/27-GATEWAY-192.168.30.1 HQ-CLI-HQ-RTR-192.168.20.2/28-GATEWAY-192.168.20.1