База знаний (wiki)

Онлайн бибилиотека с инструкциями по использованию и настройке хостинговых услуг

Loading...

SSH

Loading...
0

SSH (Secure Shell) - это безопасный протокол удаленного доступа, который позволяет клиентскому компьютеру подключаться к удаленному серверу и выполнять операции удаленного управления и передачи данных.

Принцип работы SSH основан на использовании криптографии для обеспечения безопасности передаваемых данных. Когда устанавливается SSH-соединение, клиент и сервер устанавливают защищенный канал связи.

Компьютер, с которого осуществляется подключение SSH, является клиентом, а удаленный компьютер-сервер, к которому осуществляется подключение, называется хостом.

При подключении по SSH используется логин на сервере, и SSH-пароль является паролем этого пользователя. Обычно SSH-сервер прослушивает входящие соединения на 22-м порту TCP, хотя администратор сервера может настроить другой порт для безопасности.

Шифрование данных в SSH осуществляется с использованием ключей. Существуют три различных метода шифрования в протоколе SSH: симметричное, асимметричное и хэширование. Ключи используются для кодирования и декодирования передаваемых данных между клиентом и хостом.

Протокол SSH является важным инструментом для удаленного управления серверами и обеспечения безопасной передачи данных. Он широко применяется в области веб-хостинга и управления виртуальными и выделенными серверами. Однако для использования SSH рекомендуется иметь навыки системного администрирования и соответствующие меры безопасности.

Симметричное шифрование в SSH означает, что один и тот же секретный ключ используется как для шифрования, так и для дешифрования данных между клиентом и хостом. При установке соединения, специальный алгоритм обмена ключами согласовывает секретный ключ, который затем используется для шифрования и расшифровки данных на протяжении всей сессии.

Асимметричное шифрование в SSH используется при использовании пары публичного и приватного ключей для авторизации. В этом случае, на этапе установки соединения, SSH применяет асимметричное шифрование. Публичный ключ используется для шифрования данных, а приватный ключ - для их расшифровки. Публичный ключ может быть свободно распространен, в то время как приватный ключ должен оставаться в безопасности и не передаваться другим лицам.

Процесс подключения с использованием асимметричных ключей работает следующим образом:

  1. Хост и клиент используют свои публичные ключи для генерации общего секретного ключа шифрования сессии.
  2. Хост шифрует данные публичным ключом и предлагает клиенту расшифровать их с помощью его приватного ключа.
  3. Если операция успешна, клиент авторизуется на хосте с соответствующим именем пользователя.
  4. Дальнейшая сессия продолжается с использованием симметричного шифрования.

Хэширование в SSH используется для создания уникальных шифрованных ключей (хэшей) для подтверждения аутентификации и обеспечения целостности сообщений. Хэши используются в механизме симметричного шифрования SSH-сессии.

На виртуальном хостинге SSH-доступ используется реже, чем на VPS/VDS и выделенных серверах. Некоторые провайдеры, такие как Beget, предоставляют возможность использования SSH-доступа на виртуальном хостинге. Чтобы использовать SSH на виртуальном хостинге Beget, необходимо включить соответствующую опцию в панели управления и подключиться к серверу с использованием SSH-клиента, используя логин и пароль от личного кабинета.

На платформе Linux, SSH-клиент предустановлен на всех версиях операционной системы. Чтобы использовать SSH, пользователю достаточно открыть терминал (командную строку) и ввести команду "ssh user@host", где "user" - имя пользователя на удаленном сервере, а "host" - адрес сервера. Пользователю будет предложено ввести пароль, после чего установится соединение с удаленным сервером и пользователь сможет начать работу.

В случае использования ассиметричного шифрования, пароль не требуется, так как аутентификация происходит посредством уникальных ключей между клиентом и сервером.

На платформе Windows для использования протокола SSH разработаны специальные программы - SSH-клиенты. Один из наиболее популярных SSH-клиентов для Windows - PuTTY. После скачивания и запуска PuTTY, пользователю будет предложено ввести IP-адрес хоста для подключения. Затем откроется окно терминала, где пользователю нужно будет ввести имя пользователя и пароль для соединения с удаленным сервером.

Важно отметить, что подключение по паролю является простым способом соединения по SSH, но менее безопасным. Рекомендуется использовать аутентификацию с помощью ключей для повышения безопасности.

Подключение по ключам является безопасным способом соединения по SSH, который позволяет подключаться без ввода пароля. Для использования подключения по ключам, необходимо создать пару приватный+публичный ключ и сохранить публичный ключ на хостинге.

Для Linux:

  1. В терминале выполните команду "ssh-keygen".
  2. Укажите место сохранения ключей. По умолчанию они сохраняются в директорию ~/.ssh/id_rsa.
  3. Для пропуска пароля для ключа, нажмите Enter. В противном случае, введите пароль и подтвердите его.
  4. Пара приватный и публичный ключи будут созданы в директории ~/.ssh.
  5. Чтобы загрузить публичный ключ на сервер в файл ~/.ssh/authorized_keys, используйте команду "ssh-copy-id -i /home/demo/.ssh/id_rsa.pub Адрес электронной почты защищен от спам-ботов. Для просмотра адреса в браузере должен быть включен Javascript.".

Для Windows с использованием PuTTY:

  1. Запустите программу PuTTYgen.
  2. Нажмите кнопку "Generate" и перемещайте мышью для создания случайной последовательности данных.
  3. Сгенерированные ключи будут отображены.
  4. Сохраните приватный и публичный ключи на ваш компьютер в виде текстовых файлов.
  5. Создайте на сервере папку "~/.ssh" и внутри нее файл "authorized_keys".
  6. Отредактируйте файл "authorized_keys" и добавьте в него публичный ключ.
  7. В программе PuTTY укажите имя пользователя и подключите приватный ключ.
  8. После этого, соединение с сервером по протоколу SSH будет установлено без ввода пароля.

Рекомендуется использовать пару приватный+публичный ключ как самый безопасный способ соединения по SSH.

Настройка SSH на сервере является важной для обеспечения безопасности и контроля доступа. Вот некоторые рекомендации по настройке SSH на сервере:

  1. Отредактируйте файл конфигурации SSH (sshd_config), который обычно находится в директории /etc/ssh/.
  2. Установите ограничение на количество попыток входа, чтобы предотвратить атаки перебора паролей. Найдите параметр "MaxAuthTries" и установите значение, например, 3-5.
  3. Запретите вход по SSH для пользователя root, заменив параметр "PermitRootLogin" на "no". Это поможет предотвратить попытки взлома с использованием учетной записи root.
  4. Измените порт SSH на сервере с порта 22 на другое значение. Это может помочь снизить количество неудачных попыток подключения от автоматизированных сканеров.
  5. Включите использование только протокола SSH версии 2, установив параметр "Protocol" на "2".
  6. Если вы используете ключи SSH для аутентификации, установите параметр "PasswordAuthentication" на "no", чтобы запретить вход по паролю.
  7. Ограничьте список пользователей, которым разрешен вход по SSH, с помощью параметра "AllowUsers". Укажите имена пользователей, разделяя их пробелом.
  8. При необходимости настройте доступ по SSH через определенные сетевые интерфейсы с помощью параметра "ListenAddress".
  9. Регулярно проверяйте журналы (logs) SSH-сервера для обнаружения подозрительной активности и попыток несанкционированного доступа.

Обратите внимание, что после внесения изменений в файл конфигурации SSH требуется перезапустить службу SSH для применения настроек.

Установка этих мер безопасности поможет защитить ваш сервер SSH от несанкционированного доступа и повысит уровень безопасности.

Опубликовано 1 год назад
#100218 просмотрыОтредактировано 1 год назад