Поскольку мой IP-адрес не будет часто меняться, я хочу, чтобы только мой IP-адрес мог получить доступ по SSH к моему VPS-серверу CentOS7 4-го поколения.
Это содержимое файла конфигурации (без закомментированных строк): /etc/ssh/sshd_config
HostKey /etc/ssh/ssh_host_rsa_key
HostKey /etc/ssh/ssh_host_ecdsa_key
HostKey /etc/ssh/ssh_host_ed25519_key
SyslogFacility AUTHPRIV
PermitRootLogin no
AuthorizedKeysFile .ssh/authorized_keys
PasswordAuthentication no
PermitEmptyPasswords no
Match Address xx.xxx.xxx.xxx #here is my real ip address
PasswordAuthentication yes
ChallengeResponseAuthentication no
GSSAPIAuthentication yes
GSSAPICleanupCredentials no
UsePAM yes
X11Forwarding yes
AcceptEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES
AcceptEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT
AcceptEnv LC_IDENTIFICATION LC_ALL LANGUAGE
AcceptEnv XMODIFIERS
Subsystem sftp /usr/libexec/openssh/sftp-server
После бега
sudo systemctl restart sshd.service
, я получил следующую ошибку:
Задание для sshd.service не удалось, так как процесс управления завершился с кодом ошибки. Подробности см. в "systemctl status sshd.service" и "journalctl -xe".
После запуска:
systemctl status sshd.service
Результат следующий:
sshd.service - OpenSSH server daemon
Loaded: loaded (/usr/lib/systemd/system/sshd.service; enabled; vendor preset: enabled)
Active: activating (auto-restart) (Result: exit-code) since Fri 2020-08-21 21:34:52 MST; 40s ago
Docs: man:sshd(8)
man:sshd_config(5)
Process: 15994 ExecStart=/usr/sbin/sshd -D $OPTIONS (code=exited, status=255)
Main PID: 15994 (code=exited, status=255)
Я не могу понять, что не так. Любая помощь будет оценена по достоинству.
решение1
Я выполнил команду:
sudo /usr/sbin/sshd -T
Я получил следующее сообщение об ошибке:
Directive 'ChallengeResponseAuthentication' is not allowed within a Match block
Поэтому я переместил блок Match в последнюю часть файла, и это решило мою проблему.
Спасибо всем за инструкции.