Difference between revisions of "Judge.cfg:info"
(Created page with "Навигация: Главная страница/Система ejudge/Использование/Конфигурационные файлы/[[judge...") |
|||
Line 1: | Line 1: | ||
Навигация: [[Main Page|Главная страница]]/[[Система ejudge]]/[[Использование]]/[[Конфигурационные файлы]]/[[judge.cfg]]/[[judge.cfg:info|Общая информация]] | Навигация: [[Main Page|Главная страница]]/[[Система ejudge]]/[[Использование]]/[[Конфигурационные файлы]]/[[judge.cfg]]/[[judge.cfg:info|Общая информация]] | ||
+ | |||
+ | Данный конфигурационный файл используется CGI-программой <tt>[[judge]]</tt>. Содержимое файла прочитывается один раз при старте CGI-программы, то есть каждый раз, когда кто-либо посылает HTTP/HTTPS-запрос к серверу, приводящий к запуску программы <tt>judge</tt>. | ||
+ | |||
+ | Местоположение конфигурационного файла определяется на этапе компиляции системы | ||
+ | <tt>ejudge</tt> с помощью опции <tt>--enable-cgi-conf-dir</tt> скрипта <tt>[[configure]]</tt>. Эта опция позволяет установить каталог, в котором находятся конфигурационные файлы всех CGI-программ. | ||
+ | |||
+ | Если опция не была указана в командной строке configure, предполагается значение по | ||
+ | умолчанию, равное <tt>../cgi-data</tt>. Местоположение каталога конфигурационных файлов, | ||
+ | задаваемого опцией <tt>--enable-cgi-conf-dir</tt> может быть как абсолютным, так и относительным путём. В случае относительного пути точкой отсчёта является каталог, в котором находится сама CGI-программа <tt>judge</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>judge</tt> может называться <tt>judge.cfg</tt> или <tt>judge-<tt>''N''<tt>.cfg</tt>, где ''N'' — номер турнира (см. ниже), но и конфигурационный файл вообще может | ||
+ | отсутствовать. Для этого необходимо, чтобы все настройки, которые считываются из конфигурационного файла, были установлены при компиляции системы с помощью опций скрипта <tt>[[configure]]</tt>. | ||
+ | |||
+ | Чтобы конфигурационный файл программы judge был необязательным, необходимо, чтобы программа <tt>judge</tt> была открыта для доступа со всех IP-адресов (дополнительные ограничения, конечно, могут задаваться для каждого турнира в конфигурационном файле турнира). Кроме того, при компиляции системы <tt>ejudge</tt> необходимо указание опций <tt>--enable-charset, --enable-socket-path</tt> и <tt>--enable-conf-dir</tt>. | ||
+ | |||
+ | При запуске программы <tt>judge</tt> вначале определяется идентификатор турнира. Идентификатор турнира определяется либо по параметру запроса <tt>contest_id</tt>, либо по имени, | ||
+ | под которым вызывается программа <tt>judge</tt>, причем параметр запроса <tt>contest_id</tt> имеет | ||
+ | приоритет. В случае, когда идентификатор турнира не определен или определен по параметру запроса <tt>contest_id</tt>, всегда используется конфигурационный файл <tt>judge.cfg</tt>. Если | ||
+ | конфигурационный файл не существует, то будут использоваться значения по умолчанию. | ||
+ | |||
+ | Определение идентификатора турнира по имени программы является устаревшим механизмом и не рекомендуется для использования. В этом случае программа <tt>judge</tt> должна называться <tt>judge-</tt>''N'', где ''N'' — десятичное число-идентификатор турнира. Этого можно добиться | ||
+ | созданием символических или жестких ссылок в каталоге CGI-программ веб-сервера. Тогда | ||
+ | сначала будет сделана попытка считать конфигурационный файл <tt>judge-</tt>''N''<tt>.cfg</tt>, затем, если эта попытка завершилась неудачно, будет сделана попытка считать конфигурационный | ||
+ | файл <tt>judge-</tt>''N′''<tt>.cfg</tt>, где ''N′'' — это число, напечатанное с 6 десятичными знаками, включая | ||
+ | незначащие нули, например, <tt>judge-000001.cfg</tt>. Если это попытка завершилась неудачно, | ||
+ | будет сделана попытка считать конфигурационный файл <tt>judge-</tt>''N′′''<tt>.cfg</tt>, где ''N′′'' — число, | ||
+ | напечатанное без ведущих незначащих нулей. Наконец, будет сделана попытка считать конфигурационный файл <tt>judge.cfg</tt>, и в случае неуспеха будут использоваться значения по | ||
+ | умолчанию. |
Revision as of 11:00, 22 February 2012
Навигация: Главная страница/Система ejudge/Использование/Конфигурационные файлы/judge.cfg/Общая информация
Данный конфигурационный файл используется CGI-программой judge. Содержимое файла прочитывается один раз при старте CGI-программы, то есть каждый раз, когда кто-либо посылает HTTP/HTTPS-запрос к серверу, приводящий к запуску программы judge.
Местоположение конфигурационного файла определяется на этапе компиляции системы ejudge с помощью опции --enable-cgi-conf-dir скрипта configure. Эта опция позволяет установить каталог, в котором находятся конфигурационные файлы всех CGI-программ.
Если опция не была указана в командной строке configure, предполагается значение по умолчанию, равное ../cgi-data. Местоположение каталога конфигурационных файлов, задаваемого опцией --enable-cgi-conf-dir может быть как абсолютным, так и относительным путём. В случае относительного пути точкой отсчёта является каталог, в котором находится сама CGI-программа judge. Для этого используется переменная окружения SCRIPT_FILENAME, устанавливаемая веб-сервером при запуске CGI-программы.
Таким образом, если, например, CGI-программы располагаются в каталоге /home/httpd/cgi-bin, то при значении пути к конфигурационным файлам ../cgi-data, конфигурационные файлы CGI-программ должны располагаться в каталоге /home/httpd/cgi-data.
Конфигурационный файл программы judge может называться judge.cfg или judge-N.cfg, где N — номер турнира (см. ниже), но и конфигурационный файл вообще может отсутствовать. Для этого необходимо, чтобы все настройки, которые считываются из конфигурационного файла, были установлены при компиляции системы с помощью опций скрипта configure.
Чтобы конфигурационный файл программы judge был необязательным, необходимо, чтобы программа judge была открыта для доступа со всех IP-адресов (дополнительные ограничения, конечно, могут задаваться для каждого турнира в конфигурационном файле турнира). Кроме того, при компиляции системы ejudge необходимо указание опций --enable-charset, --enable-socket-path и --enable-conf-dir.
При запуске программы judge вначале определяется идентификатор турнира. Идентификатор турнира определяется либо по параметру запроса contest_id, либо по имени, под которым вызывается программа judge, причем параметр запроса contest_id имеет приоритет. В случае, когда идентификатор турнира не определен или определен по параметру запроса contest_id, всегда используется конфигурационный файл judge.cfg. Если конфигурационный файл не существует, то будут использоваться значения по умолчанию.
Определение идентификатора турнира по имени программы является устаревшим механизмом и не рекомендуется для использования. В этом случае программа judge должна называться judge-N, где N — десятичное число-идентификатор турнира. Этого можно добиться созданием символических или жестких ссылок в каталоге CGI-программ веб-сервера. Тогда сначала будет сделана попытка считать конфигурационный файл judge-N.cfg, затем, если эта попытка завершилась неудачно, будет сделана попытка считать конфигурационный файл judge-N′.cfg, где N′ — это число, напечатанное с 6 десятичными знаками, включая незначащие нули, например, judge-000001.cfg. Если это попытка завершилась неудачно, будет сделана попытка считать конфигурационный файл judge-N′′.cfg, где N′′ — число, напечатанное без ведущих незначащих нулей. Наконец, будет сделана попытка считать конфигурационный файл judge.cfg, и в случае неуспеха будут использоваться значения по умолчанию.