Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. Программирование. Ступени успешной карьеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Разное

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: В чем особенность "серьезных" веб сайтов?
 
 автор: volodumir   (06.09.2013 в 21:53)   письмо автору
 
 

Здравствуйте, сегодня в журнале прочитал о парне который в начале нулевых умел создавать сайты которые выдерживали миллион посетителей. В чем качественное отличие такого рода сайтов? Вроде нагрузка делится на несколько серверов, но вот какая структура? DNS сообщает же один ip одного сервера.

  Ответить  
 
 автор: cheops   (06.09.2013 в 22:11)   письмо автору
 
   для: volodumir   (06.09.2013 в 21:53)
 

Для начала код приложения, база данных и контент-файлы хранятся на разных серверах. Под приложение выделяют несколько Web-серверов, чтобы можно было обслуживать параллельно множество запросов. Базы данных и контент-сервера, как правило, тоже расположены не на одном сервере. Балансировщик распределяет обращения по нескольким Web-серверам. Несколько Web-серверов обращаются к серверам базы данных, объединенных репликацией по схеме звезда или кольцо (в зависимости от того, много у вас запросов на запись или не очень). Сейчас все чаще вообще кластеризуют сервисы (т.е. несколько серверов ведут или пытаются вести себя как один большой сервер). В принципе ничего фантастичного там нет - если у вас будет задача создать такой сайт и в распоряжении будет несколько серверов, вы быстро сообразите что к чему (там не так много схем и вариантов).

>DNS сообщает же один ip одного сервера.
Как правило, используются поддомены, под базы данных, контент сервера, какие-то внутренние сервисы, вроде рекламы, комментариев. Если сайт большой, то почти все сервисы могут быть распределены по своим группам серверов под своими поддоменами. Более того, запрос может идти к папке в рамках домена, а балансировщик может преобразовывать запрос к поддомену и совершенно отдельной группе серверов.

PS Просто в таких системах значительную роль начинает играть системный администратор, а не разработчик, как это часто бывает в проектах, не выходящих за пределы одного сервера.
PPS Поэтому очень часто приложение разработанное без учета масштабирования и рассчитанное на один сервер, переписывают полностью, опираясь на первую разработку, как на прототип.

  Ответить  
 
 автор: volodumir   (07.09.2013 в 01:01)   письмо автору
 
   для: cheops   (06.09.2013 в 22:11)
 

Еще несколько вопросов, если можно.
Балансировщик - это отдельный сервер?
Как определяется оптимальное ПО для конкретного типа компонентов?
Как мониторят нагрузку на железо всей системы?
К примеру ваш форум, сколько нужно серверов чтобы одновременно обслужить миллион пользователей?
Если система оптимизирована под 1 млн, никакой DDoS ей уже не страшен?
Для российского Google достаточно одного DNS сервера?

  Ответить  
 
 автор: cheops   (10.09.2013 в 21:15)   письмо автору
 
   для: volodumir   (07.09.2013 в 01:01)
 

>Балансировщик - это отдельный сервер?
Да, иногда маршрутизатор.

>Как определяется оптимальное ПО для конкретного типа компонентов?
1) Опыт, 2) иногда можно рассчитать.

>К примеру ваш форум, сколько нужно серверов чтобы одновременно обслужить миллион пользователей?
Придется переписывать. Один миллион одновременно - это очень много, придется разбрасывать сервера геграфически, т.е. потребуется несколько дата-центров в разных частях страны или мира (в зависимости от того, где сосредоточены посетители).

>Если система оптимизирована под 1 млн, никакой DDoS ей уже не страшен?
Ну в общем да...

>Для российского Google достаточно одного DNS сервера?
DNS-сервера в принципе два должно быть минимум. Это если свои организовывать. Но вообще да, если вы обслуживаете одну зону, вам должно его хватить за глаза, ведь основная нагрузка не на ваш сервер, а на сервера хост-провайдеров, которые кэшируют обращения пользователей (ну разве только вы выставите очень малое время обновления).

  Ответить  
 
 автор: volodumir   (11.09.2013 в 01:09)   письмо автору
 
   для: cheops   (10.09.2013 в 21:15)
 

Большое спасибо!

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования