Назад | Перейти на главную страницу

Solaris: сокет, прослушивающий порт (эквивалент /etc/xinetd.d в Linux)

Я подготовил сценарий, который принимает запрос на порт сервера, затем обрабатывает ввод пользователя, обеспечивает вывод через тот же порт и затем умирает. Сценарий не всегда выполняется, но запускается, когда клиент открывает определенный порт. (Рабочая) конфигурация на моем компьютере с Linux такова:

/etc/services
    test_socket   9876/tcp    # TestSocket

/etc/xinetd.d/test_socket
    # default: on
    # description: blah blah blah
   service test_socket
   {
      port        = 9876
      socket_type = stream
      protocol    = tcp
      wait        = no
      user        = root
      server      = /export/home/stefano/do_something.php
      instances   = 20
   }

Как только клиент открывает порт: 9876, сценарий do_something.php начинает принимать входящее сообщение, обрабатывать его и выдавать результат в качестве вывода, прежде чем прекратить и закрыть связь.

Я хотел бы перенести / реплицировать указанную выше архитектуру на машину Solaris 10.

Для этой цели я настроил то же значение в том же файле служб:

/etc/services
    test_socket   9876/tcp    # TestSocket

Но тогда ... поскольку inetd.d отклонен в Solaris10 и заменен на svc, как я могу создать манифест для воспроизведения того же поведения?

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

Кто-нибудь может мне помочь?

Сначала вам нужно создать inetd.conf style с вашей конфигурацией. Это должно быть довольно просто, например:

test_socket stream tcp nowait root /export/.../do_something.php do_something.php

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

inetconv -i inetd.conf-style-file

Если вы хотите сначала посмотреть, что будет создано без импорта, вы можете запустить:

inetconv -n -i inetd.conf-style-file -o /tmp

Обратите внимание, что после импорта в smf, вы администрируете сервис через inetadm команда, например:

inetadm -e svc:/network/test_socket/tcp:default # enable the service
inetadm -d svc:/network/test_socket/tcp:default # disable the service
inetadm -l svc:/network/test_socket/tcp:default # list the service properties