Портты басқару хаттамасы - Port Control Protocol

Портты басқару хаттамасы (PCP) Бұл компьютерлік желі хаттама бұл мүмкіндік береді хосттар қосулы IPv4 немесе IPv6 кіріс IPv4 немесе IPv6 қалай басқарылатынын желілер пакеттер ағынмен аударылады және жіберіледі маршрутизатор орындайды желі мекенжайын аудару (NAT) немесе пакетті сүзу. Хосттарға анық жасауға мүмкіндік беру арқылы портты бағыттау ережелер, желілік трафикті өңдеуді NAT-тің артында орналасқан хосттар жасау үшін оңай конфигурациялауға болады брандмауэрлер Интернеттің қалған бөлігіне қол жетімді (сондықтан олар да әрекет ете алады) желілік серверлер ), бұл көптеген қосымшаларға қойылатын талап.[1][2]

Сонымен қатар, PCP арқылы қол жетімді портты бағыттаудың нақты ережелері хосттарға жойылған трафиктің санын азайтуға мүмкіндік береді уақытша шешімдер шығыс NAT түрінде сақтаушы хабарламалар, олар серверлермен байланыстарды қолдау үшін және әр түрлі үшін қажет NAT өтуі сияқты техникалар TCP саңылауын тесу. Сонымен бірге аз трафик трафикті азайтады қуат тұтыну, тікелей жақсарту батарея жұмыс уақыты мобильді құрылғылар.[1]

PCP 2013 жылы ізбасар ретінде стандартталған NAT портын салыстыру хаттамасы (NAT-PMP), ол онымен ұқсас хаттамалық тұжырымдамалармен және пакеттік форматтармен бөліседі.[3]:87

Жергілікті желіде Universal Plug and Play Internet Gateway Device (UPnP IGD) қолданылатын ортада UPnP IGD және PCP арасындағы өзара жұмыс функциясын IGD-ге енгізу қажет. UPnP IGD-PCP IWF RFC6970 стандартында көрсетілген.[4]

Порттарды басқару протоколы (PCP) серверінің IP-мекен-жайлары бар хосттарды конфигурациялауға арналған DHCP (IPv4 және IPv6) опциялары RFC7291-де көрсетілген.[5] PCP серверінің тізімінен серверді таңдау бойынша орындалатын процедура RFC7488 стандартында қарастырылған.[6]

NAT64 орналастырылған ортада PCP, NAT64 (RFC7225) арқылы IPv4-түрлендірілген IPv6 адрестерін құру үшін PCP басқарылатын NAT64 құрылғысы пайдаланатын IPv6 префиксін (суреттерін) білуге ​​мүмкіндік береді.

Шолу

Көптеген қосымшалар және желілік жабдық орналастыру үшін олардың желілік орналасуы сырттан қол жетімді болуын талап етеді жергілікті желілер, бастапқыда қарастырылған модельге сәйкес IP ұшынан-ұшына дейінгі байланыс Интернет желісінде, сондықтан олар желілік серверлер ретінде жұмыс істей алады және қосылымды қашықтан қабылдай алады клиенттер. Мұндай жабдықтың мысалы ретінде IP камера, оған қашықтан қамтамасыз ететін желілік сервер кіреді қадағалау IP желілері арқылы.

Әдетте, желілік жабдықты орналастыру құрылғыларды NAT-ті орындайтын маршрутизаторлардың немесе брандмауэрлердің артына орналастырады (бөлісуді қосу үшін IPv4 мекен-жайы, мысалы) немесе пакетті сүзу (жақсарту үшін) желінің қауіпсіздігі аяқталу байланысын бұзумен және жабдық пен қосымшаларды Интернеттің қалған бөлігінен қол жетімсіз етуімен аяқталады.[1][3]

Мәселесі

Орналастырылған жабдықты қол жетімді ету, оның серверлік рөлін жергілікті желіден тыс кеңейту арқылы, портты қайта бағыттауды қолмен конфигурациялауды қажет етеді. желілік шлюз (бұл әдетте а CPE ) немесе орналастырылған жабдықтан осы «брандмауэрді тесу» қосылымдары мен нақты клиенттердің қосылыстарын «біріктіру» үшін қолданылатын қосымша аралық серверлерге қосылуды бастайтын бағдарлама деңгейіндегі уақытша шешімдер. Екі тәсілдің де минустары бар - CPE-ді қолмен конфигурациялау әдетте ыңғайсыз немесе мүмкін емес, ал қосымша аралық серверлерді пайдалану күрделілік пен құнын арттырады.[2][3]

Мысалы, ан желілік компьютерлік ойын (клиенттің рөлін атқаратын) алмасу үшін ойын серверімен байланысты қажет етеді геймплей деректер. Ойын серверінің өз клиенттеріне деректерді ұсынуы үшін, бұл клиенттерге серверге қол жетімді болу керек. Әдетте, клиенттер байланыс арналарын ашу үшін ойын серверіне қосылуды бастайды. Алайда, мұндай ашық қосылыстар жұмыс істемей қалуы мүмкін және оларды кейіннен желілік шлюздермен жабуға болады, бұл оларды сақтау хабарламаларының формасын қолдану арқылы сақтау қажеттілігіне әкеледі.[3] Keepalive хабарламалары - бұл байланыс арнасы арқылы трафик жасайтын және сондықтан шлюз серверлерінің оны жабуына жол бермейтін клиент пен сервер арасында жіберілетін шағын хабарламалар. Осылайша, байланыстың тірі болуы клиент пен сервер арасында үнемі бос хабар алмасуды қажет етеді. Бұл желідегі әңгімелерді, қалдықтарды көбейтеді желінің өткізу қабілеттілігі және CPU циклдары, және дербестігін төмендетеді батареямен жұмыс істейді құрылғылар.

Сонымен қатар, кейбір желілік қосымшалар (мысалы, FTP қамтитын бірнеше байланыстың динамикалық ашылуын талап етеді бағдарлама деңгейіндегі шлюздер (ALGs) және күрделілікті қосымша арттырады.[2][3]

PCP шешім ретінде

PCP жабдық пен қосымшаларға сыртқы көріністер арасында нақты кескіндер жасауға мүмкіндік береді IP мекен-жайы, хаттама және порт, және ішкі IP-мекен-жайы, протоколы және порт. Осындай айқын кескіндер болған кезде, кіру байланысы NAT немесе брандмауэр артындағы хосттарға жете алады, бұл олардың серверлік рөлдерін жергілікті желілер шегінен тыс кеңейтеді немесе әртүрлі қызметтерді жеңілдетеді және ресурстарды аз жұмсайды. Құрылған кескіндер белгілі бір өмір сүру ұзақтығына дейін тұрақты болады, бұл жолға ұқсас Динамикалық хостты конфигурациялау хаттамасы (DHCP) оны жүзеге асырады жалдау. Сонымен бірге, PCP қосымшаларға қажеттілікке қарай динамикалық түрде қосымша кескіндер жасауға мүмкіндік береді, бұл қажеттілікті азайтады немесе жояды. ALG - қосылған NAT құрылғылары мен брандмауэрлар.[1][3]

Құрылған нақты кескінделулер белгілі бір қызмет ету мерзіміне ие, әдетте бірнеше сағатты құрайды, бұл картада сақтау үшін хосттар мен серверлер арасында қолданбалы деңгейдегі сақтаушы хабарламалармен алмасудың қажеті жоқ. Нәтижесінде желіні пайдалану және электр қуатын тұтыну азаяды, клиент пен сервер жағында қолданбалы деңгейдегі тұрақты логикалық логиканы енгізу қажет болмайды. PCP картасына жауап қосымшаны сыртқы көрінетін параметрлермен қамтамасыз етеді (IP мекен-жайы, протокол және порт), содан кейін басқа клиенттерге қолданбаға кіретін байланыстарды орнатуға болатын арнайы тәсілдермен хабарлауға болады. Сонымен қатар, PCP қолданбалы карталар орнатылған кезде сыртқы IP мекенжайы өзгерген кезде қосымшалар туралы ақпарат бере алады.[1][3]

NAT-тің әр түрлі түрлерін қолдаумен қамтамасыз ететін PCP өңдеуге болады NAT64, NAT66, және NAT44; PCP-ді IPv4 және IPv6 брандмауэр құрылғыларына қосуға қолдау көрсетіледі. PCP екі ауқымды біріктіру нүктелерінде де қолдануға арналған (мысалы, оның бөлігі ретінде) тасымалдаушы деңгейіндегі NAT ), ал ішіндегі бағасы арзан тұтынушылық деңгей құрылғылар. Ұзақ мерзімді (мысалы, IP-камера немесе сервер ретінде жұмыс жасайтын температура датчигі үшін) де, қысқа мерзімді карталар да (мысалы, интернеттегі компьютерлік ойынды ойнау кезінде) қолдауға ие.[1][2][3]

PCP қолдайды көлік қабаты 16-разрядты порт нөмірлерін қолданатын протоколдар (мысалы, TCP, UDP, Ағынды басқару протоколы (SCTP) немесе Datagram кептелісін бақылау хаттамасы (DCCP). Порт нөмірлерін қолданбайтын протоколдар (мысалы, Ресурстарды резервтеу туралы хаттама (ӨТІНЕМІН ЖАУАП БЕРІҢІЗШІ), Инкапсуляциялық қауіпсіздік жүктемесі (ESP), ICMP немесе ICMPv6 ) IPv4 брандмауэріне, IPv6 брандмауэріне және NPTv6 (IPv6 префиксінің аудармасы) функциялары, бірақ NAT жағдайында сыртқы IP-мекен-жайға бірнеше клиент қолдау көрсете алмайды.[3]

PCP спецификациясы жұмыс істеу механизмін анықтамайды көп үй желілер (бірнеше желілік шлюздері бар немесе әдепкі маршруттар ). Сияқты үйлестіру механизмін қолдана отырып, осындай желілерде PCP-ді енгізу мүмкін conntrackd. Алайда, егер әр түрлі желілердің әрқайсысының өздерінің сыртқы IP мекен-жайлары болса, онда берілген PCP картографиясы тек біреуін немесе екіншісін қолдана алады, себебі протокол клиентке белгілі бір сыртқы IP-адрес беруді қажет етеді. Егер бұл желі қол жетімсіз болып қалса, басқа желінің сыртқы IP-адресін пайдалану үшін PCP картасын жаңартуға тура келеді.[3]

Тарих

PCP 2013 жылы NAT порт картаға түсіру хаттамасының ізбасары ретінде стандартталған (NAT-PMP ), ұқсас протокол тұжырымдамаларын және онымен пакет форматтарын бөлісу. Дизайн айырмашылықтарының бірі ретінде NAT-PMP тұтынушылық деңгейдегі құрылғыларда орналастырумен шектеледі, ал PCP қолдау үшін де жасалған тасымалдаушы сынып жабдық.[3]:50, 87 2005 жылдан бастап NAT-PMP әртүрлі бағытта жүзеге асырыла бастады алма өнімдер.[7]:1

NAT-PMP Интернет шлюзі құрылғысының хаттамасы Бөлігі ретінде 2001 жылы стандартталған (IGDP) Әмбебап қосу және қосу (UPnP) сипаттамасы. IGDP күрделі және қолмен конфигурацияға сәйкес жасалғанымен, NAT-PMP қарапайымдылық пен бағдарламалық жасақтамада қолдануға арналған.[7]:26–32

Қауіпсіздік

Қоспағанда шабуылдаушылар айқын PCP картасын жасау кезінде алмасатын желілік пакеттерді өзгертуге қабілетті (хосттар мен PCP қолдайтын NAT құрылғылары немесе брандмауэрлер арасында алмасатын айқын картографияны құру үшін келіссөздерді қамтитын пакеттер), PCP құрылғанға дейін қауіпсіз болып саналады айқын кескіндер айқын емес кескіндер доменінен аспайды. Басқаша айтқанда, жасырын кескіндер NAT құрылғылары мен брандмауэрлердің клиенттің тұрақты шығыс байланыстарымен жұмыс жасауы нәтижесінде жасалады, яғни нақты картографиялау механизмі арқылы жаңа картографиялық мүмкіндіктер енгізілмеген жағдайда, PCP қауіпсіз болады.[3]

Бастап қауіпсіздік тұрғысынан, PCP маңызды ерекшелігі болып табылады ҮШІНШІ ЖАҚ картаға түсіру сұрау опция. Қолданған кезде, бұл опция салыстыру сұранысының бөлігі ретінде қосымша көрсетілген IP-мекен-жайды сол үшін нақты картаға сұраныс пакетінің бастапқы IP мекен-жайын пайдаланудың әдепкі әрекетін ұстанудың орнына, жасалған нақты салыстырудың ішкі мекен-жайы ретінде пайдалану керектігін білдіреді. мақсаты. Мұндай картаға түсіру сұраныстары PCP қолдайтын NAT құрылғысымен немесе брандмауэрмен анықталған салыстыру артықшылықтарын бере отырып, көрсетілген IP мекен-жайы үшін басқа жерде орнатылған белгісіз ережелерге байланысты айқын емес кескінделулерден жоғары болуы мүмкін, бұл шабуылдаушыға трафикті ұрлауға немесе жүргізуге мүмкіндік береді. а қызмет көрсетуден бас тарту (DoS) шабуыл.[3]

Сонымен қатар, PCP қауіпсіздігінің нақты механизмдері PCP протоколының кеңейтімі ретінде қол жетімді аутентификация және қатынасты басқару аутентификацияланған және тұтастықпен қорғалған механизмдерді қолдану жолақтық сигнал беру сүйенетін арна Кеңейтілген аутентификация хаттамасы (EAP) PCP келіссөздер сессиясына қатысатын құрылғылар арасындағы аутентификацияны жүзеге асыру үшін. Мұндай PCP қолдайтын NAT құрылғылары немесе брандмауэрлер әлі де расталмаған салыстыру сұрауларын қабылдай алады; сонымен бірге, бұрын сипатталған барлық айқын картографиялық шектеулер қолданылады.[1][3][8]

Ішкі

Ішкі PCP хосттар мен PCP қолдайтын NAT құрылғыларымен немесе брандмауэрлармен (серверлер деп аталады) басқару хабарламаларын алмасу арқылы жұмыс істейді. Пайдаланушының Datagram хаттамасы (UDP) негізгі протокол ретінде. Бұл байланыс хосттар жасаған портты бейнелеу сұраныстарынан тұрады жауаптар серверлерге жіберілген және өңделген. UDP-дің сенімсіздік сипатына сүйене отырып, бұл UDP дегенді білдіреді датаграммалар жоғалып, қайталануы немесе өзгертілуі мүмкін, сұрау салғаннан кейін кез-келген жауапқа кепілдік жоқ, осылайша хост сұраулары «кеңестер» деп те аталады. Тікелей жауаптардан басқа, серверлер ақысыз хабарламалар жасайды - мысалы, біржолғы хосттарға сыртқы IP мекен-жайындағы өзгерістер туралы хабарлау.[1][3]

Портты басқару протоколының опкодтары[3]
ОпкодСипаттама
КАРТАХосттарға сервер ретінде жұмыс істеуге және кіріс байланысын алуға мүмкіндік беретін кіріс экспедициясы үшін картаны жасайды немесе жаңартады.
ПИРСыртқы картаны жасайды немесе жаңартады, бұл хосттың бір құрдастарымен байланысын ашуға мүмкіндік береді.
ХабарландыруХосттардағы әртүрлі өзгерістер туралы, соның ішінде серверді қайта қосу және сыртқы IP-мекен-жайға өзгерістер енгізу туралы хабарлайды.

Айырбасталған хабарламаларда олардың қандай мәмілеге жататындығын немесе «сеанстың» қай кезеңін ұсынатындығын анықтайтын құралдар жоқ. Мұндай оңайлатылған дизайн барлық хабарламалардың өзін-өзі сипаттайтын және толықтырусыз, толықтыру негізінде жасалады контекст әр хабарламаның сәтті өңделуі үшін қажет. Серверлер хост сұрауларын әзірге өңдей алмайтын жағдайда үнсіз елемеуге шешім қабылдауы мүмкін; мұндай жағдайларда хосттар қажет ретрансляция өтініш. Сондай-ақ, хосттар кез-келген қажетсіз карта жауаптарын үнсіз елемеуге шешім қабылдауы мүмкін.[3]

PCP сұраныстарын құру үшін сервердің IP-мекен-жайы хостта қолмен конфигурацияланады, хосттың бөлігі ретінде табылады DHCP жалдау немесе хосттың конфигурацияланған күйіне орнатылады әдепкі шлюз. Хостқа сұраныс хабарламалары клиенттегі кез келген UDP портынан сервердің 5351 UDP порталы тыңдайтын жіберіледі; шақырылмаған мультикаст сервер хабарламалары (мысалы, серверді қайта іске қосу туралы хабарландыру) сервердің UDP 5351 портынан UDP портына 5350 өздері тыңдайтын хосттарда жіберіледі.[3]

Максималды UDP пайдалы жүктеме барлық PCP хабарламаларының ұзындығы 1100 құрайды сегіздіктер. Әрбір PCP хабарламасы құрамында an бар сұрау немесе жауап тақырыбынан тұрады опкод байланысты операцияны, кез-келген сәйкес опкодты ақпаратты (мысалы, порттарды салыстыру керек) және нөлдік немесе одан да көп нұсқаларды (мысалы, ҮШІНШІ ЖАҚ опция сипатталған жоғарыда ). Нәтиже кодтары сервер жауаптарының бөлігі ретінде қайтарылады; әрбір нәтиже кодында белгілі бір операциялардың қайтадан қайталануы немесе қайтадан жасалуы мүмкін болатындығы туралы хосттарға айтылатын байланысқан қызмет ету мерзімі бар. Мысалы, нәтиженің өмір сүру уақыты сәтсіздік шарты қанша уақытқа созылатындығын немесе жасалған салыстырудың қанша уақытқа созылатынын көрсете алады.[3]

Сондай-ақ қараңыз

Пайдаланылған әдебиеттер

  1. ^ а б c г. e f ж сағ Дэн Винг (желтоқсан 2011). «Портты басқару хаттамасы». Интернет-хаттама журналы. Cisco жүйелері. Алынған 31 қаңтар, 2014.
  2. ^ а б c г. «Портты басқару протоколына шолу (Junos OS 13.3)». Арша желілері. 2013 жылғы 14 тамыз. Алынған 31 қаңтар, 2014.
  3. ^ а б c г. e f ж сағ мен j к л м n o б q р с D. қанат; С.Чешир; М.Букадаир; Р.Пенно; П.Селкирк (сәуір, 2013). «RFC 6887: Портты басқару хаттамасы (PCP)». Интернет-инженерлік жұмыс тобы (IETF). Алынған 31 қаңтар, 2014.
  4. ^ Букадаир, М .; Пенно, Р .; Wing, D. (шілде 2013). «Universal Plug and Play (UPnP) Internet Gateway Device - Port Control Protocol Interworking Function (IGD-PCP IWF)» «Интернет-шлюз құрылғысы». дои:10.17487 / rfc6970. Журналға сілтеме жасау қажет | журнал = (Көмектесіңдер)
  5. ^ Букадаир, М .; Пенно, Р .; Wing, D. (шілде 2014). «Портты басқару протоколына (PCP) арналған DHCP параметрлері». дои:10.17487 / rfc7291. Журналға сілтеме жасау қажет | журнал = (Көмектесіңдер)
  6. ^ Букадаир, М .; Пенно, Р .; Қанат, Д .; Патил, П .; Редди, Т. (наурыз 2015). «Портты басқару протоколы (PCP) серверін таңдау». дои:10.17487 / rfc7488. Журналға сілтеме жасау қажет | журнал = (Көмектесіңдер)
  7. ^ а б С.Чешир; M. Krochmal (сәуір, 2013). «RFC 6886: NAT портын салыстыру хаттамасы (NAT-PMP)». Интернет-инженерлік жұмыс тобы (IETF). Алынған 8 тамыз, 2014.
  8. ^ М.Каллен; С.Хартман; Д. Чжан; Т. Редди (қыркүйек 2015). «RFC 7652: портты басқару хаттамасы (PCP) аутентификация механизмі». Интернет-инженерлік жұмыс тобы (IETF). Алынған 29 сәуір, 2016.

Сыртқы сілтемелер