как автоматически запустить скрипт на сервере вскоре после того, как клиентская система установит ssh-соединение с сервером
, например: предположим, что пользователь войдет в мой компьютер из другой системы (подключенной через lan) с использованием ssh-соединения. В то время сценарий (python или shell) должен автоматически запускаться в моей системе для выполнения какой-либо проверки?
Как автоматически запустить сценарий в серверной системе?
Вы можете сделать это, добавив следующий параметр в свой файл конфигурации (/etc/ssh/sshd_config).
ForceCommand Forces the execution of the command specified by ForceCommand, ignoring any command supplied by the client and ~/.ssh/rc if present. The command is invoked by using the user's login shell with the -c option. This applies to shell, command, or subsystem execution. It is most useful inside a Match block. The command originally supplied by the client is available in the SSH_ORIGINAL_COMMAND environment variable. Specifying a command of “internal-sftp” will force the use of an in-process sftp server that requires no support files when used with ChrootDirectory.
Другой вариант - использовать файлы .ssh / rc для каждого пользователя.
Для использования метода ForceCommand вы просто добавляете ForceCommand /usr/bin/ownscript
внизу файла /etc/ssh/sshd_config
(на сервере).
Сценарий выглядит следующим образом:
#!/bin/bash
#Script file for ssh
#
#put your commands here
echo "test" > /tmp/test.txt
#
#exit by calling a shell to open for the ssh session
/bin/bash
Не забудьте chmod скрипт sudo chmod +x /usr/bin/ownscript
Для выполнения скрипта во время входа в систему добавьте его как вызов из скрипта / etc / profile. Это выполняется для каждого входа в систему, а не только для входа в систему SSH.
Можно создать a /etc/ssh/sshrc
файл. Посмотрите man 8 ssh
. Если Вы хотите это для отдельного пользователя, использовать ~/.ssh/rc
.
Вот образец /etc/ssh/sshrc
это уведомит Вас через dbus, когда кто-то войдет в систему на Вашей машине. Не забывайте chmod +x
:
#!/bin/bash
ip=`echo $SSH_CONNECTION | cut -d " " -f 1`
notify-send -u CRITICAL "SSH connection from ${ip}" "User $USER just logged in from $ip"