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

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' &
einstiien
источник
Да, вот как я это делаю, за исключением того, что у меня обычно открыто несколько терминалов 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
jbochi
источник
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 для отображения вывода.

bjcullinan
источник
5

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

Marcin
источник
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, чтобы многое из того, что я описал, можно было автоматизировать при первом входе в экран.

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

кило
источник