Difference between revisions of "Serve-control.xml:info"

From EjudgeWiki
 
 
(One intermediate revision by the same user not shown)
Line 1: Line 1:
Навигация: [[Main Page|Главная страница]]/[[Система ejudge]]/[[Использование]]/[[Конфигурационные файлы]]/[[serve-control.xml:info|Общая информация]]
+
Навигация: [[Main Page|Главная страница]]/[[Система ejudge]]/[[Использование]]/[[Конфигурационные файлы]]/[[serve-control.xml]]/[[serve-control.xml:info|Общая информация]]
 +
 
 +
Данный конфигурационный файл используется CGI-программой <tt>[[serve-control]]</tt>. Содержимое файла прочитывается один раз при старте CGI-программы, то есть каждый раз, когда
 +
кто-либо посылает HTTP/HTTPS-запрос к серверу, приводящий к запуску программы <tt>serve-control</tt>.
 +
 
 +
Местоположение конфигурационного файла определяется на этапе компиляции системы
 +
<tt>ejudge</tt> с помощью опции <tt>--enable-cgi-conf-dir</tt> скрипта <tt>[[configure]]</tt>. Эта опция позволяет установить каталог, в котором находятся конфигурационные файлы всех CGI-программ.
 +
 
 +
Если опция не была указана в командной строке <tt>configure</tt>, предполагается значение по
 +
умолчанию, равное <tt>../cgi-data</tt>. Местоположение каталога конфигурационных файлов,
 +
задаваемого опцией <tt>--enable-cgi-conf-dir</tt> может быть как абсолютным, так и относительным путём. В случае относительного пути точкой отсчёта является каталог, в котором
 +
находится сама CGI-программа <tt>serve-control</tt>. Для этого используется переменная окружения
 +
<tt>SCRIPT_FILENAME</tt>, устанавливаемая веб-сервером при запуске CGI-программы.
 +
 
 +
Таким образом, если, например, CGI-программы располагаются в каталоге
 +
<tt>/home/httpd/cgi-bin</tt>, то при значении пути к конфигурационным файлам
 +
<tt>../cgi-data</tt>, конфигурационные файлы CGI-программ должны располагаться в каталоге
 +
<tt>/home/httpd/cgi-data</tt>.
 +
 
 +
Конфигурационный файл программы <tt>serve-control</tt> называется <tt>serve-control.xml</tt>,
 +
но и конфигурационный файл вообще может отсутствовать. Для этого необходимо, чтобы
 +
все настройки, которые считываются из конфигурационного файла, были установлены при
 +
компиляции системы с помощью опций скрипта <tt>[[configure]]</tt>.
 +
 
 +
Чтобы конфигурационный файл программы <tt>serve-control</tt> был необязательным, необходимо, чтобы программа <tt>serve-control</tt> была открыта для доступа со всех IP-адресов (дополнительные ограничения, конечно, могут задаваться для каждого турнира в конфигурационном
 +
файле турнира). Кроме того, при компиляции системы <tt>ejudge</tt> необходимо указание опций -
 +
<tt>-enable-charset</tt>, <tt>--enable-socket-path</tt>, <tt>--enable-super-serve-socket</tt> и <tt>--enable-conf-dir</tt>. Тем не менее, рекомендуется создавать этот конфигурационный файл
 +
и устанавливать жёсткие ограничения на разрешенные IP-адреса для доступа к <tt>serve-control</tt>.
 +
 
 +
Если конфигурационный файл не найден или не может быть открыт, используется следующий встроенный конфигурационный файл по умолчанию:
 +
<?xml version="1.0" ?>
 +
<serve_control_config>
 +
  <serve_control_access default="allow"/>
 +
</serve_control_config>
 +
Опции <tt>--enable-charset, --enable-socket-path, --enable-super-serve-
 +
socket</tt> и <tt>--enable-conf-dir</tt> скрипта <tt>[[configure]]</tt> позволяют в этом случае установить
 +
значения по умолчанию для остальных необходимых элементов конфигурационного файла.

Latest revision as of 10:25, 22 February 2012

Навигация: Главная страница/Система ejudge/Использование/Конфигурационные файлы/serve-control.xml/Общая информация

Данный конфигурационный файл используется CGI-программой serve-control. Содержимое файла прочитывается один раз при старте CGI-программы, то есть каждый раз, когда кто-либо посылает HTTP/HTTPS-запрос к серверу, приводящий к запуску программы serve-control.

Местоположение конфигурационного файла определяется на этапе компиляции системы ejudge с помощью опции --enable-cgi-conf-dir скрипта configure. Эта опция позволяет установить каталог, в котором находятся конфигурационные файлы всех CGI-программ.

Если опция не была указана в командной строке configure, предполагается значение по умолчанию, равное ../cgi-data. Местоположение каталога конфигурационных файлов, задаваемого опцией --enable-cgi-conf-dir может быть как абсолютным, так и относительным путём. В случае относительного пути точкой отсчёта является каталог, в котором находится сама CGI-программа serve-control. Для этого используется переменная окружения SCRIPT_FILENAME, устанавливаемая веб-сервером при запуске CGI-программы.

Таким образом, если, например, CGI-программы располагаются в каталоге /home/httpd/cgi-bin, то при значении пути к конфигурационным файлам ../cgi-data, конфигурационные файлы CGI-программ должны располагаться в каталоге /home/httpd/cgi-data.

Конфигурационный файл программы serve-control называется serve-control.xml, но и конфигурационный файл вообще может отсутствовать. Для этого необходимо, чтобы все настройки, которые считываются из конфигурационного файла, были установлены при компиляции системы с помощью опций скрипта configure.

Чтобы конфигурационный файл программы serve-control был необязательным, необходимо, чтобы программа serve-control была открыта для доступа со всех IP-адресов (дополнительные ограничения, конечно, могут задаваться для каждого турнира в конфигурационном файле турнира). Кроме того, при компиляции системы ejudge необходимо указание опций - -enable-charset, --enable-socket-path, --enable-super-serve-socket и --enable-conf-dir. Тем не менее, рекомендуется создавать этот конфигурационный файл и устанавливать жёсткие ограничения на разрешенные IP-адреса для доступа к serve-control.

Если конфигурационный файл не найден или не может быть открыт, используется следующий встроенный конфигурационный файл по умолчанию:

<?xml version="1.0" ?>
<serve_control_config>
 <serve_control_access default="allow"/>
</serve_control_config>

Опции --enable-charset, --enable-socket-path, --enable-super-serve- socket и --enable-conf-dir скрипта configure позволяют в этом случае установить значения по умолчанию для остальных необходимых элементов конфигурационного файла.