Предыдущая версия данного обучающего руководства была написана Джастином Эллингвудом (Justin Ellingwood) и Намо (Namo)
Виртуальная частная сеть (VPN) позволяет выполнять защищенное шифрование трафика, передаваемого через незащищенные сети, например, в кафе, на конференции или в аэропорту.
Internet Key Exchange v2 или IKEv2 — это протокол, который позволяет создавать прямые туннели IPSec между сервером и клиентом. IPSec обеспечивает шифрование сетевого трафика в виртуальных частных сетях IKEv2. IKEv2 изначально поддерживается на ряде платформ (OS X 10.11+, iOS 9.1+, Windows 10) без дополнительных приложений и легко решает проблемы с подключением клиентов.
В этом обучающем руководстве мы настроим сервер IKEv2 VPN с помощью StrongSwan на сервере Ubuntu 20.04. Затем вы узнаете, как подключиться к нему с помощью клиентов Windows, macOS, Ubuntu, iOS и Android.
Для данного обучающего руководства вам потребуется следующее:
sudo
и брандмауэром.Вначале мы установим StrongSwan, демона IPSec с открытым исходным кодом, а затем настроим его как наш сервер VPN. Также мы установим компонент инфраструктуры открытых ключей (PKI), чтобы создать центр сертификации (СА), который будет предоставлять учетные данные для нашей инфраструктуры.
Начните с обновления кэша локальных пакетов:
- sudo apt update
Затем установите программное обеспечение с помощью следующей команды:
- sudo apt install strongswan strongswan-pki libcharon-extra-plugins libcharon-extauth-plugins
Дополнительный пакет libcharon-extauth-plugins
используется для обеспечения возможности аутентификации различных клиентов для вашего сервера с помощью общего имени пользователя и кодовой фразы.
После завершения установки перейдем к созданию сертификатов.
Для идентификации на клиентских системах серверу IKEv2 требуется сертификат. Для упрощения формирования требуемого сертификата пакет strongswan-pki
включает утилиту pki
, которая может сгенерировать центр сертификации и сертификаты сервера.
Для начала создадим несколько каталогов для хранения всех активо, с которыми мы будем работать. Структура каталогов соответствует некоторым каталогам в /etc/ipsec.d
, куда мы постепенно переместим все создаваемые элементы:
- mkdir -p ~/pki/{cacerts,certs,private}
Затем мы заблокируем разрешения, чтобы другие пользователи не могли видеть наши частные файлы:
- chmod 700 ~/pki
Располагая структурой каталогов для хранения всех элементов, мы можем сгенерировать ключ root. Это будет 4096-битный ключ RSA, который будет использоваться для подписи корневого центра сертификации.
Запустите следующие команды, чтобы сгенерировать ключ:
- pki --gen --type rsa --size 4096 --outform pem > ~/pki/private/ca-key.pem
После этого мы можем переходить к созданию корневого центра сертификации, используя ключ, который мы только что сгенерировали для подписания корневого сертификата:
- pki --self --ca --lifetime 3650 --in ~/pki/private/ca-key.pem \
- --type rsa --dn "CN=VPN root CA" --outform pem > ~/pki/cacerts/ca-cert.pem
Флаг --lifetime 3650
используется для обеспечения действительности корневого сертификата центра сертификации на протяжении 10 лет. Корневой сертификат центра обычно не меняется, поскольку его необходимо перераспределять на каждый использующий его сервер и клиент. Исходя из этого, 10 лет — это безопасный срок действия по умолчанию.
Вы можете изменить значение различимого имени distinguished name (DN) на любое другое имя по своему желанию. Обычное имя (поле CN) здесь используется только как индикатор, поэтому оно не обязательно должно совпадать с чем-либо в вашей инфраструктуре.
Настроив и запустив корневой центр сертификации, мы можем создать сертификат, который будет использоваться сервером VPN.
Теперь мы создадим сертификат и ключ для сервера VPN. Этот сертификат позволит клиентам проверять подлинность сервера, используя только что сгенерированный нами сертификат CA.
Вначале создайте закрытый ключ сервера VPN с помощью следующей команды:
- pki --gen --type rsa --size 4096 --outform pem > ~/pki/private/server-key.pem
Затем создайте и подпишите сертификат сервера VPN, используя ключ центра сертификации, созданный на предыдущем шаге. Запустите следующую команду, но измените поля Common Name (CN) и Subject Alternate Name (SAN) на имя DNS или IP-адрес вашего сервера VPN:
- pki --pub --in ~/pki/private/server-key.pem --type rsa \
- | pki --issue --lifetime 1825 \
- --cacert ~/pki/cacerts/ca-cert.pem \
- --cakey ~/pki/private/ca-key.pem \
- --dn "CN=server_domain_or_IP" --san server_domain_or_IP \
- --flag serverAuth --flag ikeIntermediate --outform pem \
- > ~/pki/certs/server-cert.pem
Примечание. Если вы используете IP-адрес вместо имени DNS, вам потребуется указать несколько входов --san
. Строка в предыдущем блоке команд, где вы указываете distinguished name (--dn ...
), должна быть дополнена еще одной строкой, например следующей:
--dn "CN=IP address --san @IP_address --san IP_address \
Дополнение --san @IP_address
необходимо, так как некоторые клиенты буду проверять наличие в сертификате TLS как записи DNS, так и записи IP-адреса для сервера при проверке его подлинности.
Опция --flag serverAuth
используется для указания того, что сертификат будет использоваться для аутентификации сервера, прежде чем будет установлен зашифрованный туннель. Опция --flag ikeIntermediate
используется для поддержки более старых клиентов macOS.
Теперь мы сгенерировали все файлы TLS/SSL, необходимые StrongSwan, и можем переместить их в каталог /etc/ipsec.d
следующим образом:
- sudo cp -r ~/pki/* /etc/ipsec.d/
На этом шаге мы создали пару сертификатов, которые будут использоваться для защиты связи между клиентом и сервером. Также мы подписали сертификаты ключом CA, и теперь клиент сможет проверять подлинность сервера VPN, используя сертификат CA. После подготовки всех этих сертификатов мы переходим к настройке программного обеспечения.
StrongSwan имеет файл конфигурации по умолчанию с несколькими образцами, но большинство настроек нужно будет выполнить самостоятельно. Прежде чем начинать, создадим резервную копию файла для справки:
- sudo mv /etc/ipsec.conf{,.original}
Создайте и откройте новый пустой файл конфигурации с помощью предпочитаемого текстового редактора. Мы будем использовать nano
:
- sudo nano /etc/ipsec.conf
Примечание. По мере выполнения данного раздела по конфигурации серверной части VPN вы столкнетесь с настройками, которые относятся к левой и правой сторонам соединения. При работе с VPN IPSec левая сторона, по правилам, обращается к локальной системе, которую вы настраиваете. В данном случае — это сервер. Директивы правой стороны в данных настройках будут обращаться к удаленным клиентам, таким как телефоны или компьютеры.
Когда вы позже перейдете к настройке клиентов в этом обучающем руководстве, файлы конфигурации клиентов будут обращаться к самим себе, используя различные директивы левой стороны, а к серверу будут обращаться, используя терминологию правой стороны.
Вначале мы укажем StrongSwan регистрировать состояния демонов для целей отладки и разрешить дублирующиеся соединения. Добавьте в файл следующие строки:
config setup
charondebug="ike 1, knl 1, cfg 0"
uniqueids=no
Затем мы создадим раздел конфигурации для сервера VPN. Также мы укажем StrongSwan создать туннели IKEv2 VPN и автоматически загружать этот раздел конфигурации при запуске. Добавьте в файл следующие строки:
. . .
conn ikev2-vpn
auto=add
compress=no
type=tunnel
keyexchange=ikev2
fragmentation=yes
forceencaps=yes
Также мы настроем обнаружение отсутствующих узлов, чтобы закрывать неиспользуемые соединения при непредвиденном отключении клиента. Добавьте следующие строки:
. . .
conn ikev2-vpn
. . .
dpdaction=clear
dpddelay=300s
rekey=no
Затем мы настроим параметры IPSec «левой» стороны сервера. Каждый из следующих параметров обеспечивает конфигурацию сервера для приема соединений от клиентов и корректной идентификации себя. Вы добавите каждую из этих настроек в файл /etc/ipsec.conf
после того, как вы изучите их и поймете, для чего они используются:
left=%any
Значение %any
гарантирует использование сервером сетевого интерфейса при получении входящих соединений для последующей связи с клиентами. Например, если вы подключаете клиента через частную сеть, сервер будет использовать частный IP-адрес, где он получает трафик для остальной части подключения.leftid=@server_domain_or_IP
Эта опция контролирует имя, которое сервер показывает клиентам. При совмещении со следующей опцией leftcert
, опция leftid
обеспечивает совпадение настроенного имени сервера и различимого имени (DN), содержащегося в публичном сертификате.leftcert=server-cert.pem
Эта опция — это путь к публичному сертификату для сервера, который вы настроили на шаге 3. Без него сервер не сможет аутентифицировать себя с клиентами или завершить переговоры по настройке IKEv2.leftsendcert=always
Значение always
гарантирует, что любой клиент, который подключается к серверу, всегда будет получать копию публичного сертификата сервера в рамках настроек первоначального соединения.leftsubnet=0.0.0.0/0
Последняя опция «слева», которую вы добавите, указывает клиентам на подсети, которые доступны за сервером. В этом случае 0.0.0.0/0
используется для представления всего набора адресов IPv4, что означает, что сервер будет указывать клиентам передавать весь свой трафик через VPN по умолчанию.Теперь, когда вы ознакомились с каждой из соответствующих опций «слева», добавьте их в файл следующим образом:
. . .
conn ikev2-vpn
. . .
left=%any
leftid=@server_domain_or_IP
leftcert=server-cert.pem
leftsendcert=always
leftsubnet=0.0.0.0/0
Примечание. При настройке идентификатора сервера (leftid
) символ @
нужно указывать только в случае, если ваш сервер VPN будет идентифицироваться по доменному имени:
. . . leftid=@vpn.example.com
. . .
Если сервер будет идентифицироваться по IP-адресу, просто укажите IP-адрес:
. . .
leftid=your_server_ip
. . .
Далее мы можем настроить параметры IPSec клиента «справа». Каждый из следующих параметров указывает серверу, как принимать соединения от клиентов, как клиенты должны аутентифицироваться на сервере, а также сообщает диапазоны частных IP-адресов и серверы которые будут использовать клиенты. Добавьте каждую из этих настроек в файл /etc/ipsec.conf
после того, как изучите их и поймете, для чего они используются:
right=%any
Опция %any
для стороны соединения right
предписывает серверу принимать входящие соединения от удаленных клиентов.rightid=%any
Эта опция гарантирует, что сервер не будет отклонять соединения от клиентов, которые предоставляют идентификатор до создания зашифрованного туннеля.rightauth=eap-mschapv2
Эта опция настраивает метод аутентификации, который будут использовать клиенты для аутентификации на сервере. eap-mschapv2
используется здесь для расширения возможностей совместимости и поддержки таких клиентов, как устройства на базе Windows, macOS и Android.rightsourceip=10.10.10.0/24
Эта опция предписывает серверу назначать частные IP-адреса клиентам из указанного пула IP-адресов 10.10.10.0/24
.rightdns=8.8.8.8,8.8.4.4
Эти IP-адреса являются публичными интерпретаторами DNS Google. Вместо них можно использовать другие публичные интерпретаторы, интерпретаторы сервера VPN или любые другие, к которым у клиента есть доступ.rightsendcert=never
Эта опция сообщает серверу, что клиентам не нужно отправлять сертификат для аутентификации себя.Теперь, когда вы ознакомились с необходимыми опциями «справа», добавьте следующие строки в /etc/ipsec.conf
:
. . .
conn ikev2-vpn
. . .
right=%any
rightid=%any
rightauth=eap-mschapv2
rightsourceip=10.10.10.0/24
rightdns=8.8.8.8,8.8.4.4
rightsendcert=never
Теперь мы укажем StrongSwan запрашивать у клиента учетные данные пользователя при подключении:
. . .
conn ikev2-vpn
. . .
eap_identity=%identity
И наконец, добавьте следующие строки для поддержки клиентов на базе Linux, Windows, macOS, iOS и Android. Эти строки определяют различные алгоритмы обмена ключами, хэширования, аутентификации и шифрования (обычно их называют набор шифров), которые StrongSwan разрешит использовать разным клиентам.
. . .
conn ikev2-vpn
. . .
ike=chacha20poly1305-sha512-curve25519-prfsha512,aes256gcm16-sha384-prfsha384-ecp384,aes256-sha1-modp1024,aes128-sha1-modp1024,3des-sha1-modp1024!
esp=chacha20poly1305-sha512,aes256gcm16-ecp384,aes256-sha256,aes256-sha1,3des-sha1!
Каждый поддерживаемый набор шифров отделяется от других запятой. Например, chacha20poly1305-sha512-curve25519-prfsha512
— это один набор, а aes256gcm16-sha384-prfsha384-ecp384
— другой. Перечисленные здесь наборы шифров выбраны для обеспечения самых широких возможностей совместимости с клиентами на базе Windows, macOS, iOS, Android и Linux.
Полный файл конфигурации должен выглядеть следующим образом:
config setup
charondebug="ike 1, knl 1, cfg 0"
uniqueids=no
conn ikev2-vpn
auto=add
compress=no
type=tunnel
keyexchange=ikev2
fragmentation=yes
forceencaps=yes
dpdaction=clear
dpddelay=300s
rekey=no
left=%any
leftid=@server_domain_or_IP
leftcert=server-cert.pem
leftsendcert=always
leftsubnet=0.0.0.0/0
right=%any
rightid=%any
rightauth=eap-mschapv2
rightsourceip=10.10.10.0/24
rightdns=8.8.8.8,8.8.4.4
rightsendcert=never
eap_identity=%identity
ike=chacha20poly1305-sha512-curve25519-prfsha512,aes256gcm16-sha384-prfsha384-ecp384,aes256-sha1-modp1024,aes128-sha1-modp1024,3des-sha1-modp1024!
esp=chacha20poly1305-sha512,aes256gcm16-ecp384,aes256-sha256,aes256-sha1,3des-sha1!
Сохраните и закройте файл после того, как проверите, что все строки добавлены корректно. Если вы используете nano
, нажмите CTRL+X
, Y
, затем ENTER
.
Теперь мы настроили параметры VPN и можем перейти к созданию учетной записи, чтобы наши пользователи могли подключаться к серверу.
Теперь наш сервер VPN настроен на принятие подключений клиентов, но мы еще не настроили учетные данные. Нам нужно задать пару настроек в специальном файле конфигурации с именем ipsec.secrets
:
Откроем для редактирования файл secrets
- sudo nano /etc/ipsec.secrets
Вначале мы укажем StrongSwan, где можно найти закрытый ключ:
: RSA "server-key.pem"
Затем мы зададим учетные данные пользователя. Вы можете создать любую комбинацию имени пользователя и пароля:
your_username : EAP "your_password"
Сохраните и закройте файл. Мы завершили настройку параметров VPN и теперь можем перезапустить службу VPN, чтобы применить новую конфигурацию:
- sudo systemctl restart strongswan-starter
Мы полностью настроили параметры сервера и учетные данные пользователя на сервере VPN и теперь можем перейти к самой важной части: настройке брандмауэра.
После завершения настройки StrongSwan нам нужно настроить брандмауэр, чтобы разрешить прохождение и перенаправление трафика VPN.
Если вы следовали указаниям модуля по начальной настройке сервера, у вас должен быть включен брандмауэр UFW. Если вы еще не настроили UFW, вам следует начать с добавления правила, разрешающего соединения SSH через брандмауэр, чтобы ваш текущий сеанс не был прерван при активации UFW:
- sudo ufw allow OpenSSH
Затем активируйте брандмауэр с помощью следующей команды:
- sudo ufw enable
Теперь добавьте правило, которое будет разрешать трафик UDP на стандартных портах IPSec 500
и 4500
:
- sudo ufw allow 500,4500/udp
Затем мы откроем один из файлов конфигурации UFW, чтобы добавить несколько политик нижнего уровня для маршрутизации и перенаправления пакетов IPSec. Но прежде чем мы сможем сделать это, нам нужно определить, какой сетевой интерфейс на нашем сервере используется для доступа в Интернет. Определите этот интерфейс с помощью запроса устройства, связанного с маршрутом по умолчанию:
- ip route show default
Ваш публичный интерфейс должен содержать слово «dev». Например, в этом результате показан интерфейс с именем eth0
, который выделен ниже:
Outputdefault via your_server_ip dev eth0 proto static
Определив интерфейс публичной сети, откройте файл /etc/ufw/before.rules
в своем текстовом редакторе: Правила из этого файла добавляются в брандмауэр перед остальными правилами ввода и вывода. Они используются для настройки перевода сетевых адресов (NAT), чтобы сервер мог корректно настраивать соединения между клиентами и сетью Интернет.
- sudo nano /etc/ufw/before.rules
Добавьте в верхнюю часть файла (перед строкой *filter
) следующий блок конфигурации: Измените каждый экземпляр eth0
в конфигурации выше для соответствия имени интерфейса, которое вы определили с помощью ip route
. Строки *nat
создают правила, благодаря которым брандмауэр может обеспечивать маршрутизацию и управление трафиком между клиентами VPN и интернетом. Строка *mangle
позволяет настроить максимальный размер сегмента пакета, чтобы предотвратить возможные проблемы с некоторыми клиентами VPN:
*nat
-A POSTROUTING -s 10.10.10.0/24 -o eth0 -m policy --pol ipsec --dir out -j ACCEPT
-A POSTROUTING -s 10.10.10.0/24 -o eth0 -j MASQUERADE
COMMIT
*mangle
-A FORWARD --match policy --pol ipsec --dir in -s 10.10.10.0/24 -o eth0 -p tcp -m tcp --tcp-flags SYN,RST SYN -m tcpmss --mss 1361:1536 -j TCPMSS --set-mss 1360
COMMIT
*filter
:ufw-before-input - [0:0]
:ufw-before-output - [0:0]
:ufw-before-forward - [0:0]
:ufw-not-local - [0:0]
. . .
После строки *filter
и строк определения цепочки нужно добавить еще один блок конфигурации:
. . .
*filter
:ufw-before-input - [0:0]
:ufw-before-output - [0:0]
:ufw-before-forward - [0:0]
:ufw-not-local - [0:0]
-A ufw-before-forward --match policy --pol ipsec --dir in --proto esp -s 10.10.10.0/24 -j ACCEPT
-A ufw-before-forward --match policy --pol ipsec --dir out --proto esp -d 10.10.10.0/24 -j ACCEPT
Эти строки указывают брандмауэру перенаправлять трафик ESP (защищенная инкапсуляция полезной нагрузки), чтобы дать клиентам VPN возможность подключения. ESP обеспечивает дополнительную защиту пакетов VPN, когда они проходят через ненадежные сети.
Сохраните и закройте файл после того, как проверите, что все строки добавлены корректно. Если вы используете nano
, нажмите CTRL+X
, Y
, затем ENTER
.
Прежде чем перезапустить брандмауэр, нам нужно изменить некоторые параметры ядра сети, чтобы разрешить маршрутизацию с одного интерфейса на другой. Файл, который контролирует эти настройки, называется /etc/ufw/sysctl.conf
. Нам потребуется настроить в файле несколько вещей.
Для начала необходимо активировать перенаправление пакетов IPv4, чтобы трафик мог перемещаться между VPN и публичными сетями на сервере. Далее мы отключим обнаружение путей MTU, чтобы предотвратить проблемы с фрагментацией пакетов. И наконец, мы запретим перенаправление ICMP и отправку перенаправлений ICMP, чтобы предотвратить атаки через посредников.
Откройте файл конфигурации параметров ядра UFW, используя nano
или предпочитаемый текстовый редактор:
- sudo nano /etc/ufw/sysctl.conf
Теперь добавьте следующую настройку net/ipv4/ip_forward=1
в конце файла, чтобы активировать перенаправление пакетов между интерфейсами:
. . .
net/ipv4/ip_forward=1
Следующий блок, отправляющий и принимающий ICMP , перенаправляет пакеты путем добавления следующих строк в конец файла:
. . .
net/ipv4/conf/all/accept_redirects=0
net/ipv4/conf/all/send_redirects=0
И наконец, отключите обнаружение путей MTU, добавив следующую строку в конец файла:
. . .
net/ipv4/ip_no_pmtu_disc=1
Завершив изменения, сохраните файл. Теперь мы можем активировать все изменения путем отключения и повторного подключения брандмауэра, поскольку UFW применяет эти настройки во время каждой перезагрузки.
- sudo ufw disable
- sudo ufw enable
Вам будет предложено подтвердить процесс. Введите Y
, чтобы активировать UFW с новыми настройками.
Мы завершили подготовку, и пришло время для тестирования. Вначале нужно скопировать созданный вами сертификат CA и установить его на клиентские устройства, которые будут подключаться к VPN. Для этого удобнее всего выполнить вход на ваш сервер и вывести содержимое файла сертификата:
- cat /etc/ipsec.d/cacerts/ca-cert.pem
Вывод будет выглядеть следующим образом:
Output-----BEGIN CERTIFICATE-----
MIIFNDCCAxygAwIBAgIIHCsidG5mXzgwDQYJKoZIhvcNAQEMBQAwODELMAkGA1UE
. . .
H2YUdz8XNHrJHvMQKWFpi0rlEcMs+MSXPFWE3Q7UbaZJ/h8wpSldSUbQRUlphExJ
dJ4PX+MUJO/vjG1/ie6Kh25xbBAc3qNq8siiJZDwrg6vjEK7eiZ1rA==
-----END CERTIFICATE-----
Скопируйте эти данные на свой компьютер, включая строки -----BEGIN CERTIFICATE-----
и -----END CERTIFICATE-----
, и сохраните их в файл с понятным именем, например, ca-cert.pem
. Созданный файл должен иметь расширение .pem
.
Также вы можете использовать SFTP, чтобы перенести файл на свой компьютер.
Когда файл ca-cert.pem
будет загружен на ваш компьютер, вы можете настроить подключение к VPN.
Существует множество способов импорта корневого сертификата и настройки Windows для подключения к VPN. Первый метод использует графические инструменты для каждого шага. Второй метод использует команды PowerShell, которые могут выполняться с помощью скриптов и меняться в зависимости от конфигурации VPN.
Примечание. Эти инструкции протестированы на установках Windows 10, использующих версии 1903 и 1909.
Вначале импортировать сертификат root, выполнив следующие шаги:
Нажмите WINDOWS+R
, чтобы открыть диалоговое окно Выполнить и введите mmc.exe
, чтобы открыть консоль управления Windows.
Из меню Файл перейдите в раздел Добавить или удалить оснастку, выберите Сертификаты из списка доступных оснасток и нажмите Добавить.
Чтобы разрешить VPN работать для любых пользователей, выберите Учетная запись компьютера и нажмите Далее.
Поскольку мы выполняем настройку на локальном компьютере, выберите пункт Локальный компьютер и нажмите Готово.
Под узлом Корень консоли откройте запись Сертификаты (локальный компьютер), раскройте Доверенные корневые центры сертификации и выберите запись Сертификаты:
В меню Действие выберите пункт Все задачи и нажмите Импорт, чтобы открыть мастер импорта сертификатов. Нажмите Далее, чтобы пролистать вводное окно.
На экране Импортируемый файл нажмите кнопку Обзор, убедитесь, что вы изменили тип файла с “X.509 Certificate (.cer;.crt)” на “All Files (.) и выберите сохраненный ранее файл ca-cert.pem
. Затем нажмите Далее.
Убедитесь, что Хранилище сертификатов имеет значение Доверенные корневые центры сертификации и нажмите Далее.
Нажмите Готово, чтобы импортировать сертификат.
Затем выполните следующие шаги по настройке VPN:
Для импорта корневого сертификата СА с помощью PowerShell сначала откройте командную строку PowerShell с правами администратора. Для этого нажмите правой кнопкой мыши значок Пуск и выберите Windows PowerShell (Admin)
. Также вы можете открыть командную строку как администратор и ввести powershell
.
Затем мы импортируем сертификат, используя командлет PowerShell Import-Certificate
. В следующей команде первый аргумент -CertStoreLocation
гарантирует, что сертификат импортируется в хранилище доверенных корневых центров сертификации компьютера, чтобы все программы и пользователи могли проверить сертификат сервера VPN. Аргумент -FilePath
должен указать расположение, куда вы скопировали сертификат. В следующем примере путь — это C:\Users\sammy\Documents\ca-cert.pem
. Убедитесь, что вы отредактировали команду в соответствии с используемым расположением.
- Import-Certificate `
- -CertStoreLocation cert:\LocalMachine\Root\ `
- -FilePath C:\users\sammy\Documents\ca-cert.pem
Команда выведет примерно следующее:
Output PSParentPath: Microsoft.PowerShell.Security\Certificate::LocalMachine\Root
Thumbprint Subject
---------- -------
DB00813B4087E9367861E8463A60CEA0ADC5F002 CN=VPN root CA
Теперь для настройки VPN с помощью PowerShell запустите следующую команду. Подставьте имя DNS или IP-адрес вашего сервера в строку -ServerAddress
. Различные флаги обеспечат корректную настройку Windows с необходимыми параметрами безопасности, которые соответствуют опциям, заданным в /etc/ipsec.conf
.
- Add-VpnConnection -Name "VPN Connection" `
- -ServerAddress "server_domain_or_IP" `
- -TunnelType "IKEv2" `
- -AuthenticationMethod "EAP" `
- -EncryptionLevel "Maximum" `
- -RememberCredential `
Если команда выполнена успешно, вы не увидите никакого вывода. Чтобы убедиться, что VPN настроен корректно, используйте командлет Get-VPNConnection
:
- Get-VpnConnection -Name "VPN Connection"
Вывод будет выглядеть следующим образом:
OutputName : VPN Connection
ServerAddress : your_server_ip
AllUserConnection : False
Guid : {B055A1AB-175C-4028-B4A8-D34309A2B20E}
TunnelType : Ikev2
AuthenticationMethod : {Eap}
EncryptionLevel : Maximum
L2tpIPsecAuth :
UseWinlogonCredential : False
EapConfigXmlStream : #document
ConnectionStatus : Disconnected
RememberCredential : True
SplitTunneling : False
DnsSuffix :
IdleDisconnectSeconds : 0
По умолчанию Windows выбирает более старые и медленные алгоритмы. Запустите командлет Set-VpnConnectionIPsecConfiguration
для обновления параметров шифрования, которые будет использовать Windows для обмена ключами IKEv2, а также чтобы провести шифрование пакетов:
- Set-VpnConnectionIPsecConfiguration -Name "VPN Connection" `
- -AuthenticationTransformConstants GCMAES256 `
- -CipherTransformConstants GCMAES256 `
- -DHGroup ECP384 `
- -IntegrityCheckMethod SHA384 `
- -PfsGroup ECP384 `
- -EncryptionMethod GCMAES256
Примечание. Если вы хотите удалить соединение VPN и перенастроить его с другими опциями, вы можете запустить командлет Remove-VpnConnection
.
- Remove-VpnConnection -Name "VPN Connection" -Force
С помощью флага -Force
можно пропустить предложение подтвердить удаление. Вы должны быть отключены от VPN, если хотите удалить его с помощью данной команды.
После того, как вы импортировали сертификат и настроили VPN любым методом, ваше новое подключение к VPN будет отображаться в списке сетей. Выберите VPN и нажмите Подключиться. Вам будет предложено ввести свои имя пользователя и пароль. Введите эти данные, нажмите OK, и подключение будет установлено.
Выполните следующие шаги по импорту сертификата:
После импорта и подтверждения надежности сертификата настройте подключение к VPN, выполнив следующие шаги:
Наконец, нажмите кнопку Connect (подключение) для подключения к VPN. Теперь вы должны быть подключены к VPN.
Чтобы подключиться с компьютера под управлением Ubuntu, вы должны настроить и управлять StrongSwan как службой или использовать разовую команду при каждой попытке подключения. Далее приводятся инструкции для обоих случаев.
Чтобы управлять StrongSwan как службой, вам нужно выполнить следующие шаги по настройке.
Сначала обновите свой локальный кэш пакетов с помощью apt
- sudo apt update
Затем установите StrongSwan и необходимые плагины для аутентификации:
- sudo apt install strongswan libcharon-extra-plugins
Теперь вам потребуется копия сертификата СА в каталоге /etc/ipsec.d/cacerts
, чтобы ваш клиент мог проверить подлинность сервера. Запустите следующую команду, чтобы скопировать файл ca-cert.pem
в каталог:
- sudo cp /tmp/ca-cert.pem /etc/ipsec.d/cacerts
Чтобы убедиться, что VPN работает только по запросу, используйте systemctl
для автоматического отключения StrongSwan:
- sudo systemctl disable --now strongswan-starter
Затем настройте имя пользователя и пароль, которые вы будете использовать для аутентификации на сервере VPN. Отредактируйте /etc/ipsec.secrets
с помощью nano или любого предпочитаемого редактора:
- sudo nano /etc/ipsec.conf
Добавьте следующую строку, редактируя выделенные значения имени пользователя и пароля, чтобы они соответствовали настроенным на сервере:
your_username : EAP "your_password"
А теперь отредактируйте файл /etc/ipsec.conf
для настройки вашего клиента в соответствии с конфигурацией сервера:
config setup
conn ikev2-rw
right=server_domain_or_IP
# This should match the `leftid` value on your server's configuration
rightid=server_domain_or_IP
rightsubnet=0.0.0.0/0
rightauth=pubkey
leftsourceip=%config
leftid=username
leftauth=eap-mschapv2
eap_identity=%identity
auto=start
Чтобы подключиться к VPN, введите:
- sudo systemctl start strongswan-starter
Чтобы снова отключиться, введите:
- sudo systemctl stop strongswan-starter
charon-cmd
для разовых подключенийЧтобы управлять StrongSwan как службой, вам нужно выполнить следующие шаги по настройке.
Сначала обновите свой локальный кэш пакетов с помощью apt
- sudo apt update
Затем установите StrongSwan и необходимые плагины для аутентификации:
- sudo apt install strongswan libcharon-extra-plugins
Теперь вам потребуется копия сертификата СА в каталоге /etc/ipsec.d/cacerts
, чтобы ваш клиент мог проверить подлинность сервера. Запустите следующую команду, чтобы скопировать файл ca-cert.pem
в каталог:
- sudo cp /tmp/ca-cert.pem /etc/ipsec.d/cacerts
На этом этапе вы можете подключиться к серверу VPN с помощью charon-cmd
, используя сертификат СА сервера, IP-адрес сервера VPN и настроенное имя пользователя.
Запустите следующую команду для подключения к VPN в любое время:
- sudo charon-cmd --cert ca-cert.pem --host vpn_domain_or_IP --identity your_username
При запросе укажите пароль пользователя VPN. После этого вы подключитесь к VPN. Чтобы отключиться, нажмите CTRL+C
в терминале и дождитесь, пока соединение не будет закрыто.
Чтобы настроить соединение VPN на устройстве iOS, выполните следующие действия:
Выполните следующие шаги по импорту сертификата:
Теперь сертификат импортирован в приложение StrongSwan, и вы можете настроить соединение VPN следующим образом:
Когда вы захотите подключится к VPN, нажмите на профиль, созданный в приложении StrongSwan.
Если вы не сможете импортировать сертификат, убедитесь, что файл имеет расширение .pem
, а не .pem.txt
.
Если вы не можете подключиться к VPN, проверьте используемые имя сервера и IP-адрес. Доменное имя или IP-адрес сервера должны соответствовать настроенным как общее имя (CN) при создании сертификата. Если они не совпадают, соединение VPN не будет работать. Например, если вы настроили сертификат с CN vpn.example.com
, вы должны использовать vpn.example.com
при вводе данных сервера VPN. Еще раз проверьте команду, которую вы использовали для генерирования сертификата и значения, которые использовали при создании соединения VPN.
Наконец, проверьте конфигурацию VPN и убедитесь, что значение leftid
настроено с символом @
, если вы используете доменное имя:
leftid=@vpn.example.com
Если вы используете IP-адрес, убедитесь, что символ @
опущен. Также убедитесь, что при генерировании файла server-cert.pem
вы включили флаги --san @IP_address
и --san IP_address
.
В этом обучающем модуле вы создали сервер VPN, использующий протокол IKEv2. Вы узнали о директивах, которые контролируют левую
и правую
стороны подключения как на сервере, так и на клиентах. Также вы настроили клиент Windows, macOS, iOS, Android или Linux для подключения к VPN.
Чтобы добавить или удалить пользователей, снова перейдите на Шаг 5. Каждая строка в /etc/ipsec.secrets
предназначена для одного пользователя, поэтому добавление или удаление пользователей или изменение паролей требует редактирования файла.
Теперь вы можете быть уверены, что ваша деятельность онлайн будет защищена, куда бы вы ни зашли, независимо от устройства, которое вы используете для входа в Интернет.
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
I have a trouble. My hosting provider blocks ufw and I can’t use it. Is it possible to create VPN server without ufw firewall, maybe using iptables for example?
some mistakes - STEP3 –dn “CN=server_domain_or_IP” --san server_domain_or_IP
–flag serverAuth --flag ikeIntermediate --outform pem > ~/pki/certs/server-cert.pem
–dn "CN=IP address" --san @IP_address --san IP_address \
STEP7 -EncryptionLevel “Maximum” ` -RememberCredential
Hi! Thenk for article. Why does my windows 10 VPN hang after 1 minute of use? But my VPN on Android is Ок.
Хотелось бы отметить, что у некоторых пользователей win 7/8/10 может возникнуть ошибка при подключение в серверу: “ошибка сопоставления групповой политики”. Причина её возникновения мне не известна, буду рад если кто-нибудь подскажет причину. Решается эта проблем довольно просто. Нужно отредактировать ключ реестра — HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\RasMan\Parameter\NegotiateDH2048_AES256, нужно сменить “1”, на “0”.
Thank you very much for this arcticle! It’s wonderful! Everything working perfectly, I’m noob at such things and i understood everything! You’re great! Также спасибо тем кто безупречно перевёл эту статью! Вы мой спаситель!
macOS Ventura 13.3.1 client doesn’t connect.
I added the “aes256-sha256-modp2048” cipher to /etc/ipsec.conf:
and it works fine.
РКН начал блокировать авторизацию клиентов сотовой связи по eap-mschav2 (могу ошибаться в каком моменте идет блокирование). При этом от домашнего интернета работает. Есть решение?
Спасибо за отличное пособие по настройке IKEv2 на сервере, ПК, смартфоне. В моей домашней локальной сети имеется роутер и IP-камеры. Как настроть роутер в качестве клиента?
ios17. does not connect. Linux, windows, android are ok. even with the added line “aes256-sha256-modp2048” cipher to /etc/ipsec.conf.
Everything works great. At first nothing worked, but I tested the DH group IKE and ESP. It worked on iOS and Mac, even through the mobile network. It took a long time to figure out Windows, but once again I selected the right group, everything started working, when I added connections for Windows, I didn’t specify
“Set-VpnConnectionIPsecConfiguration”
and everything worked. Thanks for the good tutorial