Я хотел бы знать, возможно ли запустить локальное приложение на удаленном сервере с помощью протокола SSH?
Для выполнения локально установленных приложений с помощью ЦП другого компьютера и памяти Вы могли — предполагающий, что процессоры совместимы — пробуют это. Я не уверен, как хорошо это будет работать, но теория кажется звуковой :) Вам, вероятно, будет нужен доступ суперпользователя на удаленном сервере для этого для работы.
ssh в к удаленному серверу
Смонтируйте локальную корневую файловую систему где-нибудь. Вы не должны делать этого вообще, если Вы не совершенно уверены, что можно доверять администраторам удаленной системы.
scp
луг id_?sa.pub
файл назад к локальному для добавления его к Вашему ~/.ssh/authorized_keys
. Ограничение IP-адресов, которые могут ssh в к Вашей машине, является другой хорошей идеей. И так далее.После того как Вам смонтировали файловую систему и все еще ssh в редакторе к серверу, сделать
chroot/path/to/mount/of/local/filesystem УПРАВЛЯЮТ ARGS
Или Вы можете просто cd
к каталогу и выполненный chroot
, и затем Вы отсортируете, имеют корневую оболочку в Вашей собственной системе, при этом обработка сделана сервером. Первая форма имеет преимущество разрешения Вам удобно сохранить вывод к системе сервера, так как любые перенаправления будут сделаны на сервер. НАПРИМЕР.
chroot /path/to/mount/of/local/filesystem find -iname "somefile" > ~/tmp/somefile.find.out
сохранит список файлов, названных "somefile" в Вашем домашнем временном каталоге на сервере.
Это, по крайней мере, с моей точки зрения, довольно экспериментальной. Я не уверен, что могло пойти не так, как надо, но я не попробую его, если несколько человек не будут ручаться за него. Даже затем я не попробовал бы его в производственной системе. Если бы я делал сериал IT, то этот сегмент был бы снабжен субтитрами со словами, "не ПРОБУЮТ ЭТО ДОМА".
Определенно у Вас должны будут быть совместимые процессоры на этих двух машинах: если локальная система является i386, сервер должен будет быть i386 или amd64. Кроме того, так как ядро сервера будет выполнением работы, Вы только сможете запустить локальные приложения, которые работают с версией ядра, это работает на сервере. Вероятно, было бы лучше, если бы они были той же версией. Таким образом, если и Ваше локальное поле и удаленный сервер работают, 32-разрядные Debian Сжимают, то это могло бы работать без проблем.
Как дальнейшее примечание: может быть очень ограниченное преимущество для выполнения вещей этот путь, начиная с любых данных, которые должны быть переданы назад и вперед — включая оба файла, которые будут обработаны, и сами приложения — должны будут быть зашифрованы и переданы по Вашему удаленному соединению. Таким образом, если Вы надеетесь делать это для использования максимальной вычислительной мощности сервера, Вы не можете получить очень много в конце и можете потерять некоторых.
Это во многом зависит от того, как Вы определяете термины, которые Вы используете:
'Запуск приложения' обычно означает 'позволять ЦП обработать инструкции двоичного файла (".exe")'.
'Локально' обычно означает 'ЦП машины, перед которой я сижу, выполняет код'
ssh используется для шифрования потоков информации
Так, каково это должно быть?
Вы хотите запустить свое локальное приложение локально (Вашим ЦП), но Вы хотите взаимодействовать с ним с сервера? Да, это может быть сделано через ssh, искать 'ssh туннелирование'.
Вы хотите, чтобы Ваше локальное приложение было обработано ЦП сервера? Затем необходимо скопировать двоичный файл / локальное приложение на сервер, и затем Вы запускаете его на сервере. Вы могли использовать ssh, чтобы сделать копирование. Но Ваше 'локальное приложение' не то, что локально больше после копирования.
Вы не можете выполнить код на ЦП, не делая этого доступным для ЦП прежде.
Вы можете от одной машины (машина A) запрашивают, чтобы другая машина (машина B) уже запустила программу на машине B. ssh, позволил бы Вам сделать это.
И я думаю, что Вы можете от машины, доступ говорит, что файл установки от машины B, и выполняет его на машине A, который передал бы файл в RAM A машины. Я думаю, что совместный доступ к файлам окон делает это. (который не перемещает или копирует файл между прочим, никакой файл не исчезает или появляется где угодно в выполнении этого. Лучшая терминология могла бы быть то, что файл копируется в RAM и становится процессом, это происходит любое время, программа запущена даже когда локальный),
В теории я предполагаю очень прохладный ЦП, и инструкции могли читать из RAM на другом компьютере. Вы хотели бы по сети также. Возможно, технология буквально там, но я не знал бы где/какой.