Хвост несколько удаленных файлов


41

Есть ли способ удаленного хвоста 2 файла?

У меня есть два сервера (a и b) за балансировщиком нагрузки, и я хотел бы сделать что-то вроде этого, если это возможно:

tail -f admin@serverA:~/mylogs/log admin@serverB:~/mylogs/log

Благодарность!


Почему вы удалили ответ?
Пабло Фернандес

в основном потому, что это не сработало :-)
мат

@mat О, я как раз собирался попробовать :). В любом случае спасибо!
Пабло Фернандес

она не работает , потому что <(Foo) конструкция будет ждать внутренней команды , чтобы закончить , прежде чем заменить трубы в исходной командной строке , с которой программное обеспечение будет иметь возможность читать, и, хвост никогда не закончить бы :-)
коврик

Ответы:


31

Это сработало для меня:

ssh -n user@hostname1 'tail -f /mylogs/log' &
ssh -n user@hostname2 'tail -f /mylogs/log' &

Да, вот как я это делаю, за исключением того, что у меня обычно открыто несколько терминалов gnome, каждый с одним сеансом внутри
Том О'Коннор

1
Есть ли способ сделать это, не открывая несколько независимых сессий SSH?
tgies

8
Но это не позволяет вам прекратить хвост Ctrl+C.
Сорин

@sorin, чтобы завершить процессы, просто верните каждый из них на первый план fg; тогда вы можете ctrl+cэто. Вы сделали бы это один раз для каждого бегущего хвоста. Или вы можете pkill -f sshнацелить их всех одновременно.
Дейл Андерсон

34

Мой предпочтительный вариант - пойти с мультитейлом. Я бы запустил что-то вроде:

multitail -l 'ssh user@host1 "tail -f /some/log/file"' -l 'ssh user@host2 "tail -f /some/log/file"'

1
Благодарность! Я искал пример того, как использовать multitail через ssh / на удаленных хостах!
Ноа Суссман

Multitail - гораздо более надежное решение.
Обфк

наш веб-сайт имеет более 10 веб-узлов, и при первой попытке происходит сбой многоадресной системы с ошибкой Operation not permitted, с 2 3 веб-узлами все нормально
Hieu Vo

Я также понимаю Operation not permitted, какие-либо подсказки?
Эрик Эйгнер

7

Вы можете использовать fabric для отслеживания нескольких хостов (а также, если нужно, результатов grep):

$ fab -P -u 'USER' -p 'PASSWORD' --linewise -H host1,host2,host3 -- tail -f /path/to/my/log.log | grep ERROR

6

Я думал, что это также может быть возможно использовать:

ssh -f user@hostname1 "tail -f /var/log/file" > /tmp/somefile &
ssh -f user@hostname2 "tail -f /var/log/file" > /tmp/somefile &

Параметр -f после ssh позволяет вам ввести пароль до его запуска в фоновом режиме. Тогда вы можете получить построчные результаты в одном файле и выполнить:

tail -f /tmp/somefile

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



5

Взгляните на мультитэйл . Как и в приведенных выше примерах, вы можете передать его в качестве команды для ssh, и тогда у вас будет один экран, отображающий (и буферизующий для простых прокруток) несколько журналов. Это также делает окраску, которая очень полезна для обнаружения аномалий.


2

Parallels SSH имеет хорошее решение для этого:

pssh -t0 -H 'host-01 host-02 host-03 host-04' -P tail -f /var/log/app.log
  • -t0 отключает тайм-аут соединения, иначе pssh закрыл соединение
  • -H '<host>...' список хостов для запуска команды
  • -P включить печать стандартного вывода каждого хоста
  • tail -f /var/log/app.log может быть любой командой, которую может запустить ваша удаленная оболочка


1

Просто странное решение, но оно работает!

Экран 1

ssh user@hostname1 "tail -f /var/log/file" > /dev/pts/6

Экран 2

ssh user@hostname2 "tail -f /var/log/file" > /dev/pts/6

это будет работать, выводя строки на терминал / dev / pts / 6 (чтобы узнать свой собственный терминал: выполните: who am i и он покажет его вам.)
Оливье Дюлак

1

Вы можете оформить заказ.

Я создал инструмент Java, способный читать локальные и удаленные файлы журналов, используя SSH. Это довольно просто в использовании.

Еще несколько объяснений: https://github.com/pschweitz/DBITail/wiki

Просто загрузите версию, соответствующую вашей операционной системе, с собственным исполняемым файлом jar release в вашей среде выполнения Java (требуется java 8_40 или выше):

https://github.com/pschweitz/DBITail/releases

Вы можете найти полную документацию (встроенную вместе со страницей Github)

Philippe


0

или вы можете использовать экран, чтобы создать два терминала, а затем разделить их.

SSH на первом хосте, к которому вы хотите подключить файл журнала, и перед запуском tail войдите в экран.

Затем подключите файл на этом хосте.

CTRL + A, c создаст новый экран или окно. Из этого нового окна ssh во 2-й хост и подключите туда файл.

Теперь, чтобы создать разделенный экран

CTRL + A, SHIFT + S, это создаст разделенный экран с текущей оболочкой в ​​верхней части и нижней частью пустой. Чтобы переключиться на нижнюю часть и поместить в нее первый экран,

CTRL + A, TAB, это переместит вас в нижнюю часть. Теперь, чтобы перенести ваш первый сеанс SSH в эту область:

CTRL + A, "(символ кавычки) и выберите первую сессию и нажмите ввод.

Я понимаю, что это может выглядеть как большая гимнастика, и это так, но вы привыкнете к этому, если будете использовать ее несколько раз.

Вот действительно хороший учебник или краткий справочник по командам экрана: http://www.pixelbeat.org/lkdb/screen.html

Кроме того, вы можете создать файл .screenrc, чтобы многое из того, что я описал, можно было автоматизировать при первом входе в экран.

Еще одна приятная вещь - это то, что вы можете просто закрыть сеанс и возобновить его в другом месте. Например, вы на работе, и у вас есть какой-то мониторинг. Вы можете просто закрыть сеанс, не выходя из системы, и возобновить работу, когда вернетесь домой или в другое место.


Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.