Linux Modem sharing
Серверная сторона
Предполагается, что сервер - это Linux машина с одним из двух устройств:
модемом, включенным как устройство /dev/ttySx
модемом, эмулирующим 'isdn4linux', включенным как устройство /dev/ttyIx
Наиболее простая настройка, как мне кажется, это 'модем-демон' - пять строчек на perl.
$ cat /usr/sbin/modemd
#!/usr/bin/perl
select((select(STDOUT), $| = 1)[$[]);
select((select(STDIN), $| = 1)[$[]);
exec 'cu -s 115200 -l /dev/ttyS1';
die '$0: Cant exec cu: $!\n';
Модем-демон запускается процессом INETD, если клиент подключается к соответствующему порту, как описано ниже. 'modemd' просто соединяет обработчик сокета с потоками STDIN и STDOUT команды 'cu' и разрешает 'cu' работать с модемом. если у вас нет 'cu', инсталлируйте пакет 'UUCP', 'cu' обычно входит в пакет 'UUCP'. Процессу INETD надо дать знать о существовании modemd. Отредактируйте файл настроек, обычно это /etc/inetd.conf :
#
# modem daemon
#
modem stream tcp nowait root /usr/sbin/tcpd /usr/sbin/modemd /dev/ttyS1
Чтобы это заработало, нужно добавить в '/etc/services' :
modem 2006/tcp modemd
Эта запись связывает символическую ссылку с указанным портом (2006) Номер порта должен быть любым незанятым другим сервисом. После этих изменений надо перезапустить inetd, чтобы он перечитал сви настройки.
$ ps |grep inetd
194 ? S 0:00 /usr/sbin/inetd
$ kill -HUP 194
Серверная сторона готова к приему клиентов. Правильность настроек можно проверить:
$ telnet localhost modem
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
Сейчас вы подключены к модему. Вы можете ввести команду 'AT' для проверки настройки:
atz
atz
OK
ati1
ati1
Linux ISDN
OK
^]
telnet>quit
$
Вместо использования Perl-скрипта в качестве модемного сервера можно также использовать программу 'mserver'. Ее можно взять на ftp://ftp.innet.be/pub/staff/carl/. Если ссылка не работает, воспользуйтесь 'archie' или другим средством поиска. Пока что я не имел удовольствия ставить и использовать mserver.
Клиентская сторона
В настоящее время ниже описываются только Windows-клиенты. На клиентской машине нужно перенаправить COM-порт на TCP/IP. Лучшая программа, какая мне попадалась - 'DialOut/IP' от 'Tactical Software' для Windows 3.1 и Windows 95. (Версия для Windows 3.1 может быть использована под Windows NT только для 16-битных приложений. 32-битная версия для Windows NT вышла летом 1997.)
DialOut/IP представляет совместно используемый модем на новом виртуальном COM-порту. Программы видят этот виртуальный COM-порт как обычный модем. Большинство программ успешно работают с виртуальным COM-портом, за исключением тех, кому требуется доступ к UART и факс-приложений. DialOut/IP можно настроить для работы с telnet потоколом, но это применимо к конкретным модемным пуллам, но не к описываемой установке Linux. Заметьте, что не смотря на свое имя DialOut/IP можно использовать для приема входящих звонков.
На http://www.tactical-sw.com есть страница для скачивания полнофункциональной evaluation версии, которая работает 1-2 недели. Установка и настройка осуществляется программой setup, подробности читайте в файле README.TXT . При запуске DialOut/IP вам понадобится ввести IP адрес и номер порта совместно используемого модема.
DialOut/IP - коммерческий продукт, цена на который определяется в зависимости от количества модемов. По лицензии вы можете установить ПО на любое количество компьютеров, которые используют такие модемы.
Защита
Если у вас только один модем для всех хостов вашей LAN, то оснований для беспокойства нет. Однако если один или несколько хостов подключено к Internet через другие каналы связи, чем описываемый модемный сервер, тогда вам придется позаботиться о защите, потому что кто-нибудь может сделать 'telnet ваш_хост modem' и позвонить по междугородке или даже международке.
Чтобы защитить модемный сервер от несанкционированного вторжения я предлагаю использовать tcp-врапперы.