* add Russian lang support --------- Co-authored-by: 风扇滑翔翼 <Fangliding.fshxy@outlook.com>
12 KiB
【Глава 5】 Создание веб-сайта
5.1 Зачем нужен веб-сайт?
Начинающие пользователи могут задаться вопросом: зачем создавать веб-сайт для обхода блокировок? Я не программист, это же сложно?
Начнём с первого вопроса. Веб-сайт нужен для того, чтобы:
- Получить действующий SSL-сертификат (это очень важно).
- Обеспечить маскировку трафика (fallback) и защититься от атак, направленных на выявление VPN-серверов.
- Создать сайт-прикрытие (например, блог, облачное хранилище, медиа-портал, игровой сайт), который будет отображаться при прямом доступе к серверу, делая использование VPN менее заметным.
Теперь ответим на второй вопрос:
- В этой статье мы создадим максимально простой веб-сайт, состоящий из одного HTML-файла и работающий на веб-сервере Nginx, чтобы решить поставленные выше задачи. Это очень просто.
- Этот веб-сайт не обязательно должен быть просто прикрытием. Вы можете развивать его и превратить в полноценный проект. Всё зависит от ваших желаний и возможностей.
- Создание сайта-прикрытия и его продвижение — это отдельная большая тема, которая выходит за рамки этой статьи. Если вам интересно, вы можете найти информацию об этом в интернете.
5.2 Подключение к VPS и установка Nginx
-
В этом разделе мы будем использовать команды, которые уже были подробно рассмотрены ранее. Если вы что-то не понимаете, вернитесь и перечитайте предыдущие главы.
sudo apt update && sudo apt install nginx
-
После завершения установки Nginx запустится автоматически. Откройте браузер на своём компьютере и введите адрес
http://100.200.300.400:80
. Если вы увидите страницу, как на скриншоте ниже, значит, Nginx работает. -
Если вы не видите страницу Nginx, возможно, вам нужно настроить Uncomplicated Firewall (UFW), стандартный брандмауэр в Debian, чтобы разрешить трафик на портах HTTP (80) и HTTPS (443).
a. Чтобы проверить, введите:
sudo ufw status
b. Если вывод команды такой, как показано ниже, это означает, что порты 80 и 443 закрыты. Выполните действия, описанные в пункте c.
Status: active To Action From -- ------ ---- 22/tcp ALLOW Anywhere 22/tcp (v6) ALLOW Anywhere (v6)
c. Чтобы открыть порты 80 и 443 для Nginx в UFW, выполните команду:
sudo ufw allow 'Nginx Full'
d. Снова проверьте статус UFW, выполнив команду из пункта a. Если вы видите вывод, как показано ниже, значит, трафик для Nginx разрешён, и вы должны увидеть стандартную страницу Nginx.
Status: active To Action From -- ------ ---- 22/tcp ALLOW Anywhere Nginx Full ALLOW Anywhere 22/tcp (v6) ALLOW Anywhere (v6) Nginx Full (v6) ALLOW Anywhere (v6)
5.3 Создание простой веб-страницы
-
Базовые команды Linux:
Номер Команда Описание cmd-10
mkdir
Создание папки cmd-11
systemctl reload
Перезагрузка службы -
Важные файлы конфигурации Linux:
Номер Путь к файлу Описание conf-02
/etc/nginx/nginx.conf
Настройки Nginx -
Создайте папку
/home/vpsadmin/www/webpage/
для вашего сайта и файлindex.html
внутри неё:mkdir -p ~/www/webpage/ && nano ~/www/webpage/index.html
::: warning
Если вы используете имя пользователя, отличное от vpsadmin
, обратите внимание на символ ~
в этой команде (это важно для 5-го шага):
- Для пользователей, отличных от
root
:~
эквивалентно/home/имя_пользователя
. - Для пользователя
root
:~
эквивалентно/root
. :::
-
Скопируйте следующий код в файл
index.html
и сохраните его (Ctrl+O
,Enter
), затем выйдите из редактора (Ctrl+X
):<html lang=""> <!-- Text between angle brackets is an HTML tag and is not displayed. Most tags, such as the HTML and /HTML tags that surround the contents of a page, come in pairs; some tags, like HR, for a horizontal rule, stand alone. Comments, such as the text you're reading, are not displayed when the Web page is shown. The information between the HEAD and /HEAD tags is not displayed. The information between the BODY and /BODY tags is displayed.--> <head> <title>Enter a title, displayed at the top of the window.</title> </head> <!-- The information between the BODY and /BODY tags is displayed.--> <body> <h1>Enter the main heading, usually the same as the title.</h1> <p>Be <b>bold</b> in stating your key points. Put them in a list:</p> <ul> <li>The first item in your list</li> <li>The second item; <i>italicize</i> key words</li> </ul> <p>Improve your image by including an image.</p> <p> <img src="https://i.imgur.com/SEBww.jpg" alt="A Great HTML Resource" /> </p> <p> Add a link to your favorite <a href="https://www.dummies.com/">Web site</a>. Break up your page with a horizontal rule or two. </p> <hr /> <p> Finally, link to <a href="page2.html">another page</a> in your own Web site. </p> <!-- And add a copyright notice.--> <p>© Wiley Publishing, 2011</p> </body> </html>
-
Дайте другим пользователям право на чтение этого файла:
chmod -R a+r .
-
Отредактируйте файл
nginx.conf
и перезапустите Nginx, чтобы он открывал созданную нами страницуindex.html
при обращении к порту80
.-
Отредактируйте файл
nginx.conf
.sudo nano /etc/nginx/nginx.conf
-
Добавьте следующий блок кода внутрь блока
http{}
и сохраните изменения (Ctrl+O
,Enter
), затем выйдите из редактора (Ctrl+X
). (Не забудьте заменить доменное имя на ваше реальное доменное имя, включая поддомен).server { listen 80; server_name поддомен.ваш_домен.com; root /home/vpsadmin/www/webpage; index index.html; }
::: warning Важно! Как уже говорилось в 3-м шаге, убедитесь, что путь
/home/vpsadmin/www/webpage
соответствует реальному пути к вашему файлу. ::: -
Перезагрузите Nginx, чтобы применить изменения.
sudo systemctl reload nginx
-
Весь процесс настройки показан на гифке ниже:
-
Теперь, если вы откроете в браузере адрес
http://поддомен.ваш_домен.com
, вы должны увидеть созданную нами страницу:
-
5.4 Распространённые ошибки
Вообще, если вы внимательно следовали инструкциям, ошибок быть не должно. Однако на этом этапе многие пользователи сталкиваются с проблемами. В чём же дело? Ответ прост: невнимательность. Здесь возможны только две ошибки, и обе они связаны с невнимательностью.
Ошибки:
- Путь
/home/vpsadmin/www/webpage
в файлеnginx.conf
не соответствует реальному пути к файлуindex.html
. Nginx не может найти файл. - Путь указан верно, но у Nginx нет прав на чтение файла.
Причины:
- Вы работаете не под пользователем
root
, но скопировали команды из статьи без изменений (как будто списали домашнее задание вместе с именем одноклассника). - Вы работаете под пользователем
root
.
Если у вас возникли проблемы, вернитесь к разделу 5.3 и внимательно перечитайте пункты 3 и 6.2.
::: warning
В предыдущих главах мы много говорили о важности использования пользователя, отличного от root
, и вся статья написана с учётом этого. Поэтому проблемы, связанные с использованием root
, не рассматриваются в рамках этой статьи.
Однако я уверен, что те, кто всё-таки работает под root
, достаточно опытны и смогут решить эти проблемы самостоятельно.
:::
5.5 Ваш прогресс
Первый компонент Xray — веб-сайт — готов. Давайте перейдём ко второму компоненту — SSL-сертификату!
⬛⬛⬛⬛⬛⬜⬜⬜ 62.5%