SEO - Статьи Создание динамических поддоменов через Windows / IIS

Discussion in 'SЕО - тонкости, методы раскрутки' started by OptimaPrime, 31 Oct 2007.

  1. OptimaPrime

    OptimaPrime Banned

    Joined:
    30 Mar 2007
    Messages:
    307
    Likes Received:
    588
    Reputations:
    -61
    Довольно часто приходится сталкиваться с проблемой, когда информации на сайте, размещенном на 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 гораздо проще в реализации, все-таки, использовать его рекомендуется на не очень больших сайтах, с которыми работает группа разработчиков. Это объясняется тем, что группа разработчиков должна постоянно отслеживать добавление и удаление ресурсов. Для большого сайта администратор должен будет произвести все настройки на нескольких серверах только один раз. Поддомены, созданные различными командами разработчиков, в этом случае будут функционировать практически одинаково с одинаковыми настройками.

    В конце концов, выбор способа разделения сайта на поддомены зависит от администратора, который обслуживает сайт.

    (с)Эдвард Льюис