
పరిస్థితి
నేను మూడు నెలల పాటు S-Terra VPN ప్రోడక్ట్స్ వెర్షన్ 4.3 డెమో వెర్షన్ని అందుకున్నాను. కొత్త వెర్షన్కి మారిన తర్వాత నా ఇంజినీరింగ్ జీవితం సులభమవుతుందా లేదా అని నేను గుర్తించాలనుకుంటున్నాను.
ఈ రోజు ఇది కష్టం కాదు, 3 ఇన్స్టంట్ కాఫీలో 1 బ్యాగ్ సరిపోతుంది. డెమో వెర్షన్లను ఎలా పొందాలో నేను మీకు చెప్తాను. నేను GRE-over-IPsec మరియు IPsec-over-GRE పథకాలను కలిపి ఉంచడానికి ప్రయత్నిస్తాను.
డెమో ఎలా పొందాలి

మీకు అవసరమైన డెమో వెర్షన్ను పొందడానికి చిత్రం నుండి ఇది అనుసరిస్తుంది:
- మీ కార్పొరేట్ చిరునామా నుండి presale@s-terra.ru కు లేఖ రాయండి;
- లేఖలో, మీ సంస్థ యొక్క TINని సూచించండి;
- ఉత్పత్తులు మరియు వాటి పరిమాణాలను జాబితా చేయండి.
డెమో సంస్కరణలు మూడు నెలల వరకు చెల్లుబాటులో ఉంటాయి. విక్రేత వారి కార్యాచరణను పరిమితం చేయలేదు.
చిత్రాన్ని విప్పుతోంది
సెక్యూరిటీ గేట్వే యొక్క డెమో వెర్షన్ వర్చువల్ మెషీన్ యొక్క చిత్రం. నేను VMWare వర్క్స్టేషన్ని ఉపయోగిస్తున్నాను. మద్దతు ఉన్న హైపర్వైజర్లు మరియు వర్చువలైజేషన్ పరిసరాల పూర్తి జాబితా విక్రేత వెబ్సైట్లో అందుబాటులో ఉంది.
మీరు ప్రారంభించడానికి ముందు, డిఫాల్ట్ వర్చువల్ మెషీన్ ఇమేజ్లో నెట్వర్క్ ఇంటర్ఫేస్లు లేవని దయచేసి గమనించండి:

లాజిక్ స్పష్టంగా ఉంది, వినియోగదారు తనకు అవసరమైనన్ని ఇంటర్ఫేస్లను జోడించాలి. నేను ఒకేసారి నాలుగు జోడిస్తాను:

ఇప్పుడు నేను వర్చువల్ మిషన్ను ప్రారంభించాను. ప్రారంభించిన వెంటనే, గేట్వేకి లాగిన్ మరియు పాస్వర్డ్ అవసరం.
S-Terra గేట్వే వివిధ ఖాతాలతో అనేక కన్సోల్లను కలిగి ఉంది. నేను వారి సంఖ్యను ప్రత్యేక వ్యాసంలో లెక్కిస్తాను. ఈలోగా:
Login as: administrator
Password: s-terra
నేను గేట్వేని ప్రారంభిస్తున్నాను. ప్రారంభించడం అనేది చర్యల క్రమం: లైసెన్స్ను నమోదు చేయడం, బయోలాజికల్ యాదృచ్ఛిక సంఖ్య జనరేటర్ను సెటప్ చేయడం (కీబోర్డ్ సిమ్యులేటర్ - నా రికార్డ్ 27 సెకన్లు) మరియు నెట్వర్క్ ఇంటర్ఫేస్ మ్యాప్ను సృష్టించడం.
నెట్వర్క్ ఇంటర్ఫేస్ మ్యాప్. ఇది సులభంగా మారింది
సంస్కరణ 4.2 సందేశాలతో క్రియాశీల వినియోగదారుని స్వాగతించింది:
Starting IPsec daemon….. failed
ERROR: Could not establish connection with daemon
యాక్టివ్ యూజర్ (అనామక ఇంజనీర్ ప్రకారం) ఏదైనా త్వరగా మరియు డాక్యుమెంటేషన్ లేకుండా కాన్ఫిగర్ చేయగల వినియోగదారు.
ఇంటర్ఫేస్లో IP చిరునామాను కాన్ఫిగర్ చేయడానికి ప్రయత్నించే ముందు కూడా ఏదో తప్పు జరుగుతోంది. ఇదంతా నెట్వర్క్ ఇంటర్ఫేస్ మ్యాప్ గురించి. ఇది చేయవలసి వచ్చింది:
/bin/netifcfg enum > /home/map
/bin/netifcfg map /home/map
service networking restart
ఫలితంగా, నెట్వర్క్ ఇంటర్ఫేస్ల మ్యాప్ సృష్టించబడుతుంది, ఇందులో ఫిజికల్ ఇంటర్ఫేస్ల పేర్ల మ్యాపింగ్ (0000:02:03.0) మరియు ఆపరేటింగ్ సిస్టమ్ (eth0) మరియు సిస్కో లాంటి కన్సోల్ (FastEthernet0/0)లో వాటి తార్కిక హోదాలు ఉంటాయి. :
#Unique ID iface type OS name Cisco-like name
0000:02:03.0 phye eth0 FastEthernet0/0
లాజికల్ ఇంటర్ఫేస్ హోదాలను మారుపేర్లు అంటారు. మారుపేర్లు /etc/ifaliases.cf ఫైల్లో నిల్వ చేయబడతాయి.
వెర్షన్ 4.3లో, మీరు మొదట వర్చువల్ మిషన్ను ప్రారంభించినప్పుడు, ఇంటర్ఫేస్ మ్యాప్ స్వయంచాలకంగా సృష్టించబడుతుంది. మీరు వర్చువల్ మెషీన్లో నెట్వర్క్ ఇంటర్ఫేస్ల సంఖ్యను మార్చినట్లయితే, దయచేసి ఇంటర్ఫేస్ మ్యాప్ను మళ్లీ సృష్టించండి:
/bin/netifcfg enum > /home/map
/bin/netifcfg map /home/map
systemctl restart networking
పథకం 1: GRE-over-IPsec
నేను రెండు వర్చువల్ గేట్వేలను అమలు చేస్తాను మరియు చిత్రంలో చూపిన విధంగా మారతాను:

దశ 1. IP చిరునామాలు మరియు మార్గాలను కాన్ఫిగర్ చేయండి
VG1(config) #
interface fa0/0
ip address 172.16.1.253 255.255.255.0
no shutdown
interface fa0/1
ip address 192.168.1.253 255.255.255.0
no shutdown
ip route 0.0.0.0 0.0.0.0 172.16.1.254VG2(config) #
interface fa0/0
ip address 172.16.1.254 255.255.255.0
no shutdown
interface fa0/1
ip address 192.168.2.254 255.255.255.0
no shutdown
ip route 0.0.0.0 0.0.0.0 172.16.1.253నేను IP కనెక్టివిటీని తనిఖీ చేస్తున్నాను:
root@VG1:~# ping 172.16.1.254 -c 4
PING 172.16.1.254 (172.16.1.254) 56(84) bytes of data.
64 bytes from 172.16.1.254: icmp_seq=1 ttl=64 time=0.545 ms
64 bytes from 172.16.1.254: icmp_seq=2 ttl=64 time=0.657 ms
64 bytes from 172.16.1.254: icmp_seq=3 ttl=64 time=0.687 ms
64 bytes from 172.16.1.254: icmp_seq=4 ttl=64 time=0.273 ms
--- 172.16.1.254 ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3005ms
rtt min/avg/max/mdev = 0.273/0.540/0.687/0.164 msదశ 2. GREని సెటప్ చేయడం
నేను అధికారిక స్క్రిప్ట్ల నుండి GREని సెటప్ చేయడానికి ఒక ఉదాహరణ తీసుకుంటాను. నేను కంటెంట్లతో /etc/network/interfaces.d డైరెక్టరీలో gre1 ఫైల్ని సృష్టిస్తాను.
VG1 కోసం:
auto gre1
iface gre1 inet static
address 1.1.1.1
netmask 255.255.255.252
pre-up ip tunnel add gre1 mode gre remote 172.16.1.254 local 172.16.1.253 key 1 ttl 64 tos inherit
pre-up ethtool -K gre1 tx off > /dev/null
pre-up ip link set gre1 mtu 1400
post-down ip link del gre1VG2 కోసం:
auto gre1
iface gre1 inet static
address 1.1.1.2
netmask 255.255.255.252
pre-up ip tunnel add gre1 mode gre remote 172.16.1.253 local 172.16.1.254 key 1 ttl 64 tos inherit
pre-up ethtool -K gre1 tx off > /dev/null
pre-up ip link set gre1 mtu 1400
post-down ip link del gre1నేను సిస్టమ్లో ఇంటర్ఫేస్ను పెంచుతాను:
root@VG1:~# ifup gre1
root@VG2:~# ifup gre1నేను సరిచుస్తా:
root@VG1:~# ip address show
8: gre1@NONE: <POINTOPOINT,NOARP,UP,LOWER_UP> mtu 1400 qdisc noqueue state UNKNOWN group default qlen 1
link/gre 172.16.1.253 peer 172.16.1.254
inet 1.1.1.1/30 brd 1.1.1.3 scope global gre1
valid_lft forever preferred_lft forever
root@VG1:~# ip tunnel show
gre0: gre/ip remote any local any ttl inherit nopmtudisc
gre1: gre/ip remote 172.16.1.254 local 172.16.1.253 ttl 64 tos inherit key 1S-Terra గేట్వేలో అంతర్నిర్మిత ప్యాకెట్ స్నిఫర్ ఉంది - tcpdump. నేను pcap ఫైల్కి ట్రాఫిక్ డంప్ వ్రాస్తాను:
root@VG2:~# tcpdump -i eth0 -w /home/dump.pcapనేను GRE ఇంటర్ఫేస్ల మధ్య పింగ్ రన్ చేస్తున్నాను:
root@VG1:~# ping 1.1.1.2 -c 4
PING 1.1.1.2 (1.1.1.2) 56(84) bytes of data.
64 bytes from 1.1.1.2: icmp_seq=1 ttl=64 time=0.918 ms
64 bytes from 1.1.1.2: icmp_seq=2 ttl=64 time=0.850 ms
64 bytes from 1.1.1.2: icmp_seq=3 ttl=64 time=0.918 ms
64 bytes from 1.1.1.2: icmp_seq=4 ttl=64 time=0.974 ms
--- 1.1.1.2 ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3006ms
rtt min/avg/max/mdev = 0.850/0.915/0.974/0.043 msGRE సొరంగం సక్రియంగా ఉంది మరియు నడుస్తోంది:

దశ 3. GOST GREతో గుప్తీకరించండి
నేను గుర్తింపు రకాన్ని సెట్ చేసాను - చిరునామా ద్వారా. ముందే నిర్వచించబడిన కీని ఉపయోగించి ప్రమాణీకరణ (ఉపయోగ నిబంధనల ప్రకారం, డిజిటల్ సర్టిఫికేట్లను తప్పనిసరిగా ఉపయోగించాలి):
VG1(config)#
crypto isakmp identity address
crypto isakmp key KEY address 172.16.1.254నేను IPsec దశ I పారామితులను సెట్ చేసాను:
VG1(config)#
crypto isakmp policy 1
encr gost
hash gost3411-256-tc26
auth pre-share
group vko2నేను IPsec దశ II పారామితులను సెట్ చేసాను:
VG1(config)#
crypto ipsec transform-set TSET esp-gost28147-4m-imit
mode tunnelనేను ఎన్క్రిప్షన్ యాక్సెస్ లిస్ట్ని క్రియేట్ చేస్తున్నాను. టార్గెట్ ట్రాఫిక్ - GRE:
VG1(config)#
ip access-list extended LIST
permit gre host 172.16.1.253 host 172.16.1.254నేను క్రిప్టో కార్డ్ని సృష్టించి, దానిని WAN ఇంటర్ఫేస్కి బంధిస్తాను:
VG1(config)#
crypto map CMAP 1 ipsec-isakmp
match address LIST
set transform-set TSET
set peer 172.16.1.253
interface fa0/0
crypto map CMAPVG2 కోసం కాన్ఫిగరేషన్ ప్రతిబింబిస్తుంది, తేడాలు:
VG2(config)#
crypto isakmp key KEY address 172.16.1.253
ip access-list extended LIST
permit gre host 172.16.1.254 host 172.16.1.253
crypto map CMAP 1 ipsec-isakmp
set peer 172.16.1.254నేను సరిచుస్తా:
root@VG2:~# tcpdump -i eth0 -w /home/dump2.pcaproot@VG1:~# ping 1.1.1.2 -c 4
PING 1.1.1.2 (1.1.1.2) 56(84) bytes of data.
64 bytes from 1.1.1.2: icmp_seq=1 ttl=64 time=1128 ms
64 bytes from 1.1.1.2: icmp_seq=2 ttl=64 time=126 ms
64 bytes from 1.1.1.2: icmp_seq=3 ttl=64 time=1.07 ms
64 bytes from 1.1.1.2: icmp_seq=4 ttl=64 time=1.12 ms
--- 1.1.1.2 ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3006ms
rtt min/avg/max/mdev = 1.077/314.271/1128.419/472.826 ms, pipe 2
ISAKMP/IPsec గణాంకాలు:
root@VG1:~# sa_mgr show
ISAKMP sessions: 0 initiated, 0 responded
ISAKMP connections:
Num Conn-id (Local Addr,Port)-(Remote Addr,Port) State Sent Rcvd
1 1 (172.16.1.253,500)-(172.16.1.254,500) active 1086 1014
IPsec connections:
Num Conn-id (Local Addr,Port)-(Remote Addr,Port) Protocol Action Type Sent Rcvd
1 1 (172.16.1.253,*)-(172.16.1.254,*) 47 ESP tunn 480 480GRE ట్రాఫిక్ డంప్లో ప్యాకెట్లు లేవు:

ముగింపు: GRE-over-IPsec పథకం సరిగ్గా పని చేస్తుంది.
పథకం 1.5: IPsec-over-GRE
నేను నెట్వర్క్లో IPsec-over-GREని ఉపయోగించడానికి ప్లాన్ చేయను. నేను కోరుకున్నందున నేను దానిని సేకరిస్తాను.

GRE-over-IPsec పథకాన్ని రివర్స్లో అమలు చేయడానికి, మీరు వీటిని చేయాలి:
- ఎన్క్రిప్షన్ కోసం యాక్సెస్ జాబితాను సరి చేయండి - LAN1 నుండి LAN2కి మరియు వైస్ వెర్సా వరకు ట్రాఫిక్ని లక్ష్యంగా చేసుకోండి;
- GRE ద్వారా రూటింగ్ని కాన్ఫిగర్ చేయండి;
- క్రిప్టో కార్డ్ని GRE ఇంటర్ఫేస్లో వేలాడదీయండి.
డిఫాల్ట్గా, సిస్కో లాంటి గేట్వే కన్సోల్కు GRE ఇంటర్ఫేస్ లేదు. ఇది ఆపరేటింగ్ సిస్టమ్లో మాత్రమే ఉంటుంది.
నేను సిస్కో లాంటి కన్సోల్కి GRE ఇంటర్ఫేస్ని జోడిస్తున్నాను. దీన్ని చేయడానికి, నేను /etc/ifaliases.cf ఫైల్ని సవరించాను:
interface (name="FastEthernet0/0" pattern="eth0")
interface (name="FastEthernet0/1" pattern="eth1")
interface (name="FastEthernet0/2" pattern="eth2")
interface (name="FastEthernet0/3" pattern="eth3")
interface (name="Tunnel0" pattern="gre1")
interface (name="default" pattern="*")ఇక్కడ gre1 అనేది ఆపరేటింగ్ సిస్టమ్లో ఇంటర్ఫేస్ హోదా, Tunnel0 అనేది సిస్కో లాంటి కన్సోల్లో ఇంటర్ఫేస్ హోదా.
నేను ఫైల్ యొక్క హాష్ను మళ్లీ గణిస్తాను:
root@VG1:~# integr_mgr calc -f /etc/ifaliases.cf
SUCCESS: Operation was successful.ఇప్పుడు Tunnel0 ఇంటర్ఫేస్ Cisco లాంటి కన్సోల్లో కనిపిస్తుంది:
VG1# show run
interface Tunnel0
ip address 1.1.1.1 255.255.255.252
mtu 1400నేను ఎన్క్రిప్షన్ కోసం యాక్సెస్ జాబితాను సర్దుబాటు చేస్తున్నాను:
VG1(config)#
ip access-list extended LIST
permit ip 192.168.1.0 0.0.0.255 192.168.3.0 0.0.0.255GRE ద్వారా రూటింగ్ని సెటప్ చేస్తోంది:
VG1(config)#
no ip route 0.0.0.0 0.0.0.0 172.16.1.254
ip route 192.168.3.0 255.255.255.0 1.1.1.2నేను Fa0/0 నుండి క్రిప్టో కార్డ్ని తీసివేసి, దానిని GRE ఇంటర్ఫేస్కి బంధిస్తాను:
VG1(config)#
interface Tunnel0
crypto map CMAPVG2 కోసం ఇది అదే.
నేను సరిచుస్తా:
root@VG2:~# tcpdump -i eth0 -w /home/dump3.pcaproot@VG1:~# ping 192.168.2.254 -I 192.168.1.253 -c 4
PING 192.168.2.254 (192.168.2.254) from 192.168.1.253 : 56(84) bytes of data.
64 bytes from 192.168.2.254: icmp_seq=1 ttl=64 time=492 ms
64 bytes from 192.168.2.254: icmp_seq=2 ttl=64 time=1.08 ms
64 bytes from 192.168.2.254: icmp_seq=3 ttl=64 time=1.06 ms
64 bytes from 192.168.2.254: icmp_seq=4 ttl=64 time=1.07 ms
--- 192.168.2.254 ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3006ms
rtt min/avg/max/mdev = 1.064/124.048/492.972/212.998 msISAKMP/IPsec గణాంకాలు:
root@VG1:~# sa_mgr show
ISAKMP sessions: 0 initiated, 0 responded
ISAKMP connections:
Num Conn-id (Local Addr,Port)-(Remote Addr,Port) State Sent Rcvd
1 2 (172.16.1.253,500)-(172.16.1.254,500) active 1094 1022
IPsec connections:
Num Conn-id (Local Addr,Port)-(Remote Addr,Port) Protocol Action Type Sent Rcvd
1 2 (192.168.1.0-192.168.1.255,*)-(192.168.2.0-192.168.2.255,*) * ESP tunn 352 352ESP ట్రాఫిక్ డంప్లో, ప్యాకెట్లు GREలో నిక్షిప్తం చేయబడ్డాయి:

ముగింపు: IPsec-over-GRE సరిగ్గా పనిచేస్తుంది.
ఫలితాలు
ఒక కప్పు కాఫీ సరిపోతుంది. నేను డెమో పొందడానికి సూచనలను వ్రాసాను. GRE-over-IPsec కాన్ఫిగర్ చేయబడింది మరియు దానిని ఇతర మార్గంలో అమలు చేసింది.
వెర్షన్ 4.3లోని నెట్వర్క్ ఇంటర్ఫేస్ మ్యాప్ స్వయంచాలకంగా ఉంది! నేను ఇంకా పరీక్షిస్తున్నాను.
అజ్ఞాత ఇంజనీర్
t.me/anonymous_engineer
మూలం: www.habr.com
