Настройка Apache для начинающих

2006-06-14, Автор - Ленар Хайруллин; Продукт - Apache; [7871]
Apache – исключительно надежный и удобный веб-сервер. К сожалению, есть те, кто не хочет использовать его в качестве локального сервера по одной причине – из-за отсутствия графического конфигуратора даже в среде Windows, что достаточно непривычно для многих пользователей этой системы. Настраивается Apache путем редактирования вручную файла конфигурации httpd.conf. Но представления о сложности и непонятности этого процесса ошибочны по двум причинам. Первая – в комментариях httpd.conf вполне достаточно информации для того, чтобы можно было разобраться с любой настройкой. Вторая – чтобы сделать из только что установленного Apache сервер, настроенный для вполне комфортной работы, надо менять совсем немного.

Что нам надо?

  1. Запустить самый популярный веб-сервер под самой популярной платформой – Windows.
  2. Хранить файлы сайта в той директории, в которой нам это удобно, – пусть это будет C:www.
  3. Не иметь проблем с кодировками, в первую очередь – с отображением кириллицы.
  4. Вполне возможно – одновременно работать с несколькими сайтами.

Попробуем решить все эти проблемы. Заходим туда, где установлен Apache. Находим и открываем файл httpd.conf – он находится в поддиректории conf. Здесь необходимо напомнить, что все строки этого файла, начинающиеся с "решетки" (#), существуют только в качестве текстовых комментариев, в качестве настроек сервера же используются строки, "решетки" в начале не имеющие. Сначала выполняем настройку директории, которая будет выдаваться веб-сервером в качестве корневой директории сайта. Ищем в тексте директиву DocumentRoot – строку, начинающуюся на DocumentRoot. Эта директива определяет, какая директория будет сопоставляться с корневой директорией сайта. Исправляем ее на DocumentRoot "C:/www" (следует отметить – здесь и далее в пути используются слэши, наклоненные вправо, а не влево, как привыкли пользователи Windows). Проблема с расположением сайта в нужном месте решена.

Далее устанавливаем для нее правила безопасности. Для этого в Apache используется директива Directory. Используется она следующим образом:


Options функции сервера
AllowOverride варианты
Order варианты

Список используемых параметров следующий.

Options – определяет, какие функции сервера будут доступны. Возможны следующие варианты:

  • Includes – разрешено использование SSI (Server-Side Includes);
  • IncludesNOEXEC – разрешено использование SSI с ограничениями (не допускаются #exec и #include);
  • Indexes – разрешено использование индексных файлов, причем если URL указывает на директорию на сайте (например, www.domain.ru/dir/), в которой нет индексного файла, то будет показываться содержимое этой директории, если же этой опции нет – выдается "доступ запрещен";
  • ExecCGI – разрешено выполнение скриптов CGI;
  • FollowSymLinks – сервер следует по символическим ссылкам в директории (имеет смысл в Unix);
  • SymLinksIfOwnerMatch – то же самое, но только в том случае, если целевой файл имеет того же владельца, что и ссылка;
  • All – все вышеописанное вместе;
  • None – ничего из вышеописанного;
  • MultiViews – возможность подбора соответствующего контента и его выдачи в зависимости от предпочтений клиента (браузера) – указывается отдельно, даже если включено все (Options All).

AllowOverride – определяет, какие директивы из файлов .htaccess могут преобладать над такими же, указанными в httpd.conf. Варианты:

  • AuthConfig – позволяет использовать директивы авторизации;
  • FileInfo – позволяет использовать директивы для работы с типами документов;
  • Indexes – позволяет использовать директивы для работы с индексными файлами;
  • Limit – позволяет использовать директивы для определения доступа к хосту;
  • Options – позволяет использовать директивы для работы со специфическими функциями директорий;
  • All – все вышеуказанное;
  • None – ничего из вышеуказанного.

Order – устанавливает правила доступа к серверу. Варианты:

  • Deny,Allow – директива Deny определяется перед Allow, доступ по умолчанию разрешен, кроме хостов, указанных в следующей строке после Deny from.
  • Allow,Deny – директива Allow определяется перед Deny, доступ по умолчанию запрещен, кроме хостов, указанных в следующей строке после Allow from.
  • Mutual-failure – разрешен доступ только тех хостов, которые присутствуют в Allow и отсутствуют в Deny.

Теперь на основе всего этого начинаем настраивать наш сервер. В httpd.conf по умолчанию директива Directory существует в двух экземплярах – и . Первый вариант мы вообще не трогаем, переходим ко второму и устанавливаем следующие параметры:


Options Indexes FollowSymLinks
AllowOverride None
Order allow,deny
Allow from all

В переводе на русский язык – для директории C:/www, выбранной ранее в качестве корневой для нашего сайта, а также всех ее поддиректорий выбраны такие параметры:

  • из функциональности сервера разрешены индексы в директориях и переходы по символическим ссылкам (правда, это актуально только для Unix);
  • возможность переопределения параметров с помощью файлов .htaccess отсутствует полностью, но с учетом того, что мы имеем полный доступ к серверу, она и не актуальна – все можно настроить через httpd.conf;
  • доступ к серверу разрешен со всех хостов.

Сохраняем httpd.conf и перезапускаем Apache – c помощью Apache Monitor или в командной строке командой apache -k restart. Все, настройка корневой директории сайта закончена.

Проверяем, правильно ли мы все сделали. Создаем в C:www простейшую веб-страничку, открываем браузер и в адресной строке вводим адрес: http://127.0.0.1/имя_созданной_страницы. Наша страница должна открыться. Если не открылась – самым внимательным образом надо проверить все внесенные в httpd.conf изменения – скорее всего, что-то было сделано неправильно.

Но и в том случае, если она будет открываться, вполне возможно, что вместо символов кириллицы мы увидим нечто нечитаемое. Происходит это потому, что, во-первых, Apache предоставляет браузеру, запросившему страницу, кодировку по умолчанию для этой страницы, а во-вторых – кодировка эта не кириллическая. И если Internet Explorer в большинстве таких ситуаций все равно определяет кодировку из самой страницы, то с Opera или Mozilla проблемы практически гарантированы. Конечно, можно выставлять используемый набор символов каждый раз вручную в браузере, но сколь-нибудь удобным это назвать невозможно.

Поэтому настраиваем Apache на выдачу нужной кодировки по умолчанию. Находим в httpd.conf строку, начинающуюся на AddDefaultCharset. Скорее всего, полностью она будет выглядеть как AddDefaultCharset ISO-8859-1, что соответствует кодировке ISO-8859-1, в которой символы кириллицы отсутствуют. Меняем ISO-8859-1 на windows-1251, если предполагается, что сайт будет содержать страницы в кодировке Windows, на KOI-8r, если используется KOI-8, или на ту, которая нужна. Сохраняем файл, перезапускаем Apache – и наблюдаем нормальный русский язык на нашей тестовой странице в любом браузере.

И еще. Apache достаточно легко настроить на работу с несколькими сайтами. Адреса, которые для них можно использовать, – 127.0.0.2, 127.0.0.3 и так далее. Правда, по сети виден будет только один (тот, который является сайтом по умолчанию, он же 127.0.0.1), но именно для локальной работы это не критично. Раздел httpd.conf, в котором настраивается все для этого необходимое, находится в самом конце файла и называется Virtual Hosts.

Чтобы добавить один дополнительный сайт, создадим директорию, которая будет использоваться как его корневая, например C:www2. Предположим, что сайт должен откликаться на адрес 127.0.0.2, и дадим ему имя site2. Затем в самый конец раздела Virtual Hosts добавим следующие строки:


ServerAdmin webmaster@site2
ServerName site2
DocumentRoot "C:/www2"
ScriptAlias /cgi/ "C:/www2/cgi/"
ErrorLog "C:/www2/error.log"
CustomLog "C:/www2/custom.log" common

Перезапускаем Apache. Теперь, набрав в строке браузера 127.0.0.1, мы попадаем на первый локальный сайт, набрав 127.0.0.2 – на второй. Остается сказать только, что внутри каждого контейнера VirtualHost можно использовать практически любые директивы Apache, что дает возможность настраивать каждый сайт самым детальным образом.

Автор: Алекс Звягин

Комментарии:
Смартфон Porsche Design Huawei Mate 20 R...
Смартфон Porsche Design Huawei Mate 20 RКомпания Huawei представила премиальный смартфон Porsche Design Huawei Mate 20 RS, за основу которого взя...
Huawei Mate 20X получил 7,12-дюймовый эк...
Huawei Mate 20X получил 7,12-дюймовый экПомимо флагманских смартфонов Mate 20 и Mate 20 Pro компания Huawei сегодня представила и огромный Huawei...
Флагманский смартфон Huawei Mate 20 Pro ...
Флагманский смартфон Huawei Mate 20 Pro Как и ожидалось, сегодня компания Huawei представила флагманские смартфоны Mate 20 и Mate 20 Pro, главной...
CTL Chromebox CBx1 с невероятно мощным п...
CTL Chromebox CBx1 с невероятно мощным пОбычно все системы, которые разрабатывают для Chrome OS, получаются довольно слабыми — производители изна...
Sharkoon Pure Steel со странным шасси...
Sharkoon Pure Steel со странным шассиПользователи хотят получать нестандартные корпуса для своих компьютеров и производители эти решения готов...
Тесты Core i9-9900K разочаровали...
Тесты Core i9-9900K разочаровалиВ последнее время в сети было много информации о том, что компания Intel делает большой упор на процессор...
Обзор APC Back-UPS BV800I-GR. Линейно-ин...
Обзор APC Back-UPS BV800I-GR. Линейно-инВажность защиты подключаемых бытовых приборов, офисной техники и настольных компьютеров очевидна далеко н...
ALLDOCUBE M5S порадует вас производитель...
ALLDOCUBE M5S порадует вас производительБольшая часть современных пользователей по какой-то странной причине уверена в том, что нужно приобретать...
Поделиться в социальных сетях:


Предварительный обзор Creative Sound Bla...
Предварительный обзор Creative Sound BlaДлительное время разработчики игровой периферии активно избегали консоли. Рынок был не очень развит, да и...
Обзор Bouncemaster. Шикарная игра...
Обзор Bouncemaster. Шикарная играНа  современном рынке казуальных игр есть большая проблема с отсутствием новых ярких идей. Большая часть ...
Предварительный обзор Thermaltake View 3...
Предварительный обзор Thermaltake View 3Компьютерные корпусы давно перестали быть чем-то обычным. Сейчас пользователи покупают настоящие произвед...
Предварительный обзор SteelSeries Rival ...
Предварительный обзор SteelSeries Rival Рынок игровой периферии давно перестал быть чем-то простеньким и недорогим. Геймеры хотят получить от пер...
Honor представила премиальный смартфон H...
Honor представила премиальный смартфон H10 октября в Москве прошла презентация смартфона Honor 8X. Модель позиционирует себя, как премиальный сма...
Предварительный обзор Alienware m15. Шик...
Предварительный обзор Alienware m15. ШикВ последнее время игровых ноутбуков стало все меньше — то производители прямо каждый день выпускали новые...
Обзор Battlerite Royale. Королевская бит...
Обзор Battlerite Royale. Королевская битКоролевские битвы пользуются бешеной популярностью среди геймеров — каждый хочет получить удовольствие от...
Предварительный обзор Nokia 7.1. Достойн...
Предварительный обзор Nokia 7.1. ДостойнБуквально вчера в сети была информация о мобильном телефоне Nokia 7.1, которую многие опровергали. Мы даж...
Обзор My Brother Rabbit. Отличная истори...
Обзор My Brother Rabbit. Отличная историЯ довольно редко играю в квесты и сюжетные игры в этом жанре мне нравятся невероятно редко. Обычно разраб...
Предварительный обзор Realme 2 Pro. Вот ...
Предварительный обзор Realme 2 Pro. Вот Весной этого года компания Oppo показала виру новый бренд Realme, который является дочерним предприятием....
Обзор Standoff 2. Шутер нового поколения...
Обзор Standoff 2. Шутер нового поколенияРазвитие мобильных шутеров идет против всех правил и аналитики. Уже несколько лет к ряду все говорят о то...
Предварительный обзор Huawei Y9 (2019). ...
Предварительный обзор Huawei Y9 (2019). Все понимают, что современным гигантам мобильного рынка довольно трудно как-то удивлять своего потенциаль...

МегаОбзорМегаОбзор
ЭЛ № ФС 77 - 68301. Выдано РоскомнадзоромМегаОбзор
MegaObzor в социальных сетях:
Яндекс.Метрика
2006-2018 © MegaObzor