М Б С

Бесплатная помощь в раскрутке форума и сайта
Текущее время: 02-05, 17:21

Часовой пояс: UTC + 4 часа




Начать новую тему Ответить на тему  [ 1 сообщение ] 
Автор Сообщение
СообщениеДобавлено: 22-09, 09:31 
Не в сети
Администратор
Аватара пользователя

Зарегистрирован: 10-07, 10:14
Сообщения: 2347
Откуда: Москва
Создание динамических поддоменов через Windows / IIS

Довольно часто приходится сталкиваться с проблемой, когда информации на сайте, размещенном на Windows Server, становится настолько много, что приходится пересмотреть свои взгляды на архитектуру сайта. В этих случаях сайт можно разбить на поддомены. В статье представлены два способа, как этого добиться с небольшим их анализом со стороны автора.
Приступая к реализации этих методов, необходимо получить следующие доступы и возможности пользоваться технологиями:
• должна быть возможность изменения DNS;
• доступ к серверу ISS;
• ISAPI_Rewrite (для реализации 2 способа).
Реализация первого метода: настройка сервера IIS
Вероятно, у вас будет ограниченное количество поддоменов, которыми необходимо будет управлять. Управлять им можно будет как всеми вместе, так и каждым по отдельности.
Управление группой поддоменов: добавьте следующую запись в ваш DNS и измените домен вместе с IP следующим образом:
*.example.com IN A 1.2.3.4
Объявление вручную: добавьте запись для каждого из поддоменов.
В sub1.example.com 1.2.3.4
В sub2.example.com 1.2.3.4
В sub3.example.com 1.2.3.4
Настройка веб-сервера
Во-первых, убедитесь, что вы создали корень директории для каждого из поддоменов, как при работе с новым сайтом. Ваша директория может выглядеть следующим образом:
d:\inetpub\wwwroot\example.com\sub1\
d:\inetpub\wwwroot\example.com\sub2\
d:\inetpub\wwwroot\example.com\sub3\
d:\inetpub\wwwroot\example.com\js\
d:\inetpub\wwwroot\example.com\css\
d:\inetpub\wwwroot\example.com\img\
Далее необходимо создать сайт для каждого из поддоменов. Следующие действия можно повторять для вех поддоменов:
• Откройте консоль IIS (IIS Management Console);
• Щелкните на Web Sites и выберите New: Web-site;
• Нажмите Next, чтобы продолжить;
• Введите описание сайта и нажмите кнопку Next. Пример того, как это выглядит: sub1.example.com;
• IP-адрес и Settings: введите sub1.example.com в Host header.
• На следующей странице введите путь d:\inetpub\wwwroot\example.com\sub1\
• На следующей странице, выберите подходящие настройки и нажмите кнопку Next.
Дело сделано.
Теперь начинается самое интересное: созданы отдельные сайты для каждого поддомена, но у них есть общие файлы (скрипты, CSS, картинки). Проблема состоит в том, как сделать так, чтобы каждому сайту были доступны эти файлы.
• Кликните правой кнопкой мыши на поддомен, который вы только что создали в консоль управления IIS и выберите New : Virtual Directory;
• В качестве примера будем использовать папку CSS. Кликните на Next и введите в css псевдонимом;
• Укажите путь d : \ inetpub \ wwwroot \ example.com \ css \ и нажмите кнопку Next.
Реализация первого метода: подведение итогов
Итак, мы создали несколько поддоменов и разделили между ними общие файлы.
Реализация первого метода: использование ISAPI_Rewrite
Сразу перейдем к сравнению первого метода со вторым.
Настройка DNS
Добавьте следующую запись в ваш DNS и измените домен вместе с IP следующим образом:
*.example.com IN A 1.2.3.4
Настройка веб-сервера
• Откройте консоль управления IIS выберите Web-site;
• Щелкните правой кнопкой мыши по нему и выберите Properties;
• Нажмите кнопку Advanced;
• Убедитесь, что имеется одна запись для множества сущностей для данного веб-сайта с заполненным Host Header Name. Данная запись будет перехватывать все запросы, которые адресуются IP-адрес;
• Убедитесь, что IP-адрес используется только этим сайтом
Настройка httpd.ini по ISAPI_Rewrite
Добавьте следующий код в httpd.ini в корне директории. Убедитесь, что они в правильном порядке.
# Конвертировать http://example.com к http://www.example.com/
RewriteCond Host: ^example.com
RewriteRule (.*) http\://www\.example.com$1 [I,RP]
# ограничимся рядом общих папок.
# будем выполнять их соответственно вне зависимости от поддомена.
# Example: http://sub1.example.com/img/logo.jpg -> /img/logo.jpg
# Example: http://www.example.com/img/logo.jpg -> /img/logo.jpg
RewriteRule (/css/.*) $1 [I,O,L]
RewriteRule (/js/.*) $1 [I,O,L]
RewriteRule (/img/.*) $1 [I,O,L]
# Перенаправлять все остальные подкаталоги, не соответствующие
# вышеупомянутому списку, как поддомены.
#example: www.example.com\sub1 -> sub1.example.com
RewriteCond Host: www\.highspeed\.com
RewriteRule /(\w*)/(.*) http\://$1\.example\.com$2 [I,RP]
# Если веб-сайт начинается с www, то обязательно укажите файл в корневой папке.
# Если вы специально создали папки / www /, то вы можете закомментировать этот раздел.
RewriteCond Host: (?:www\.)example.com
RewriteRule (.*) $1 [I,O,L]
# url сайта, начинающийся без www, будет переправлен на поддомен
# Example: http://sub1.example.com/default.asp -> /sub1/default.asp
# Note: if the folder does not exists, then the user will get a 404 error automatically.
RewriteCond Host: (.*)\.example.com
RewriteRule (.*) /$1$2 [I,O,L]
# исправление недостающего символа
# выдача 404 ошибки
RewriteCond Host: (.*)
RewriteRule ([^.?]+[^.?/]) http\://$1$2/ [I,RP]
Тестирование поддоменов
Предположим, что корпоративный сайт состоит из двух поддоменов sub1, sub2.
URI ¦ Расположение на сервере
http://www.example.com ¦ /
http://sub1.example.com/img/logo.jpg ¦ /img/logo.jpg
http://sub2.example.com ¦ /sub2/
http://abc.example.com ¦ /abc/ -> 404 Not Found
Реализация второго метода: подведение итогов
Второе решение легкое в реализации, однако нужно быть осторожным в создании директорий. Так, например, пользователь не может создавать папки d:\inetpub\wwwroot\example.com\sub1\img\ потому, что она противоречит ISAPI_Rewrite (/ img / *.). Поэтому файлы в этой папке не будут доступны.
Сравнения
Multiple IIS- плюсы
• Вся информация из всех папок доступна, противоречий нет.
• Отделены log-файлы для отслеживания их по отдельности.
• Может быть осуществлена настройка для группы серверов и произведена балансировка нагрузки на них.
Multiple IIS сеть - минусы
• Необходимость создания нового сайта на поддомене.
• Требует доступа к серверу IIS.
ISAPI_Rewrite - плюсы
• Простота установки.
• Легкость просмотра log-файлов.
• Для добавления поддомена просто необходимо добавить новую папку
ISAPI_Rewrite - минусы
• Необходимость отслеживания каталогов во избежание конфликтов.
• Нужна выделять IP-адрес.
• Требуется дополнительный ресурс для обработки каждого файла.
• Необходимость подбора сервера, который поддерживает ISAPI_Rewrite.
Заключение
Хотя ISAPI_Rewrite гораздо проще в реализации, все-таки, использовать его рекомендуется на не очень больших сайтах, с которыми работает группа разработчиков. Это объясняется тем, что группа разработчиков должна постоянно отслеживать добавление и удаление ресурсов. Для большого сайта администратор должен будет произвести все настройки на нескольких серверах только один раз. Поддомены, созданные различными командами разработчиков, в этом случае будут функционировать практически одинаково с одинаковыми настройками.
В конце концов, выбор способа разделения сайта на поддомены зависит от администратора, который обслуживает сайт.
Перевод Сергея Стружкова

Эдвард Льюис (Edward Lewis) http://www.seoconsultants.com/
Статься была взята сайта http://www.seonews.ru/
При перепечатке статьи ссылка на http://mbs.flybb.ru/ обязательна


Вернуться к началу
 Профиль  
 
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ 1 сообщение ] 

Часовой пояс: UTC + 4 часа


Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 1


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения

Найти:
Перейти:  
Powered by Forumenko © 2006–2014
Русская поддержка phpBB