Я пытаюсь проверить, может ли машина A подключаться к машине B через определенные порты. Системные администраторы машины A посчитали нужным удалить telnet
команду. Что будет удобной заменой? Машина А это CentOS.
Я пытаюсь проверить, может ли машина A подключаться к машине B через определенные порты. Системные администраторы машины A посчитали нужным удалить telnet
команду. Что будет удобной заменой? Машина А это CentOS.
Ответы:
iirc, telnet больше не устанавливается по умолчанию на машинах centos 6. если у вас нет таких инструментов, как telnet
или nc
доступных, вы всегда можете поговорить с сетевым сокетом, используя python. (хотя не уверен, что это соответствует вашему «удобному» требованию ...)
просто проверить, можно ли установить соединение:
[gryphius@ut ~]$ python
Python 2.6.6 (r266:84292, Feb 22 2013, 00:00:18)
[GCC 4.4.7 20120313 (Red Hat 4.4.7-3)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import socket
>>> conn=socket.create_connection(('gmail-smtp-in.l.google.com',25))
Если это не выдало ошибку, то соединение в порядке. Если вы также хотите проверить получение / отправку данных, вы можете продолжить так:
>>> input=conn.makefile()
>>> print input.readline()
220 mx.google.com ESMTP p2si6911139eeg.7 - gsmtp
>>> conn.sendall('HELO example.com\r\n')
>>> print input.readline()
250 mx.google.com at your service
>>> conn.sendall('QUIT')
>>> conn.close()
>>>
Любой из: nc (netcat), nmap, hping.
http://linux.byexamples.com/archives/258/when-netcat-act-as-telnet-client-it-becomes-better/
Метод, который я придумал:
$ ssh -f -N machineA -L 10123:machineB:123
$ telnet localhost 10123
Это не удалось, но я не был уверен, было ли это на самом деле диагностическим или нет. Проверив дальше, это действительно диагностическое.