Strona używa cookies (ciasteczek). Dowiedz się więcej o celu ich używania i zmianach ustawień. Korzystając ze strony wyrażasz zgodę na używanie cookies, zgodnie z aktualnymi ustawieniami przeglądarki.    X

Po drugiej stronie serwisu internetowego - na przykładzie Allegro

Każde żądanie (przeładowanie strony) wysłane do serwisu internetowego przebywa daleką drogę od przeglądarki poprzez infrastrukturę sieciową i serwery aż do wnętrza aplikacji, by z powrotem, wraz z danymi, zostać odesłanym do użytkownika.

Zainspirowany jedną z prelekcji na InfoShare 2013 (patrz 1, 2) postanowiłem przyjrzeć się tej drodze śledząc przez jakie warstwy, po kolei, przechodzi typowe żądanie i jakie decyzje są na nich podejmowane. Na przykładzie Allegro.pl postaram się zaprezentować architekturę oraz rozwiązania techniczne stojące za wysoką wydajnością i niezawodnością serwisu. Mam nadzieję, że uda mi się pokazać złożoność i skomplikowanie procesu od kliknięcia/wpisania adresu w przeglądarce do prezentacji wyników w postaci strony www.

Zapraszam na wycieczkę!

W liczbach

Jak wspomniałem wcześniej, posłużę się przykładem doskonale wszystkim znanego serwisu aukcyjnego Allegro.pl, który należy do Grupy Allegro. Analizie poddany zostanie przypadek użycia (ang. use case) wyszukiwania towarów, czyli od wpisania szukanego hasła aż do prezentacji listy aukcji do niego pasujących.

Grupa Allegro to:

  • 50% wartości rynku e-commerce w Polsce - według raportu Rzeczypospolitej z października 2012r.;
  • 125 platform e-commerce na całym świecie;
  • 23 kraje, w których prowadzona jest działalność, a do najbardziej egzotycznych należą: Turcja i Kazachstan;
  • ponad 4 000 pracowników,
    • w tym 1500 osób w Polsce;
    • w tym około 500 pracowników IT,
      • z czego 80 osób zajmuje się tylko infrastrukturą IT:
      • zajmują się serwerowniami (Data Center - DC), utrzymaniem serwisów i developmentem narzędzi wspomagających pracę administratorów, np. Ralph;
  • około 3 000 serwerów zlokalizowanych w dwóch Data Center - trzecia lokalizacja jest w trakcie tworzenia;

Allegro.pl to:

Dane statystyczne na temat serwisu Allegro.pl przedstawiają się następująco:
  • ponad 6 000 wywołań serwisu na sekundę;
  • 180 mln aukcji;
  • kilkaset GB danych;
  • rozproszone rozwiązania IT;
  • 2 serwerownie,
    • w każdej znajdują się po 2 redundantne klastry zdolne w każdej chwili przejąć ruch do i z serwisu;
    • klastry składają się z kilkudziesięciu (około 40) połączonych ze sobą maszyn serwerowych;

Historia Data Center Grupy Allegro

Działalność Grupy Allegro prawie od samego początku opiera się na outsourcingu Data Center.
  • 1999 rok - początki portalu aukcyjnego i serwer przyniesiony pod pachą do jednej z Poznańskich piwnic, w której nad głowami ciągnęły się rury wodno-kanalizacyjne, a między nimi pełno było pajęczyn.
  • 2004 rok - pierwsze DC zlokalizowane w serwerowni firmy TK Telekom w Poznaniu.
  • 2008 rok - drugie DC zlokalizowane w serwerowni firmy Beyond w Poznaniu- działa do dnia dzisiejszego.
  • 2009 rok - trzecie DC zlokalizowane we Frankfurcie. Zdecydowano się na nie jako zapasowe DC na wypadek: zalania, odcięcia prądu, pożaru, wybuchu czy ogłoszenia ataku bombowego :-) Po uruchomieniu tej serwerowni, ze względu na odległość, pojawił się problem opóźnień rzędu 23-25ms. Zlikwidowano je, we współpracy z operatorami internetowymi, za pomocą TCP window, czyli zwiększania okna odbioru danych powyżej jego maksymalnej pojemności 65 535 bajtów.
  • 2012 rok - czwarte DC zlokalizowane w serwerowni firmy Polkom. Jesienią 2012 roku, ze względów ekonomicznych, zdecydowano się na przenosiny z Frankfurtu do Skawiny pod Krakowem.

Przetwarzanie żądania

Po garści informacji statystycznych czas na konkrety. Po wpisaniu hasła w polu tekstowym rozpoczyna się bardzo złożony proces:

1. DNS

W pierwszej kolejności żądanie trafia do serwerów DNS, które decydują która z serwerowni obsłuży dane zapytanie. Rozwiązują nazwę domeny na konkretny adres IP, na który kierują ruch.

2. Trasa do serwerowni

Allegro.pl jako duży serwis korzysta z usług wielu dostawców internetu (providerów). Żądanie dociera do serwerowni w możliwie najkrótszym czasie. Zanim dotrze do celu przechodzi przez wiele węzłów, przełączników (switchy) i routerów na całym świecie (zależnie od położenia geograficznego użytkownika).

3. Wejście do serwerowni

Na tym etapie żądanie filtrowane jest przez firewalle i kierowane do lokalnych load balancerów, których zadaniem jest równomierne rozkładanie obciążenia na serwery znajdujące się w serwerowni.

4. Serwer aplikacji

Load balancery kierują żądanie do konkretnego serwera aplikacji, która je przetwarza i decyduje jakie dane i skąd musi je pobrać.

5. Źródło danych

Po określeniu czego potrzebuje, zapytanie kierowane jest do źródeł danych, którymi mogą być różnego rodzaju bazy danych, repozytoria danych czy hurtownie danych. Allegro wykorzystuje całe spektrum technologii: MySQL, Oracle, PostgreSQL czy NoSQL działających na serwerach, które umożliwiają skalowanie horyzontalne. Zapewniona jest też redundancja źródeł danych, co oznacza, że w przypadku awarii jednego z urządzeń nie ma przerwy w dostępie do żądanych treści. Najistotniejsza jest wydajność i dostępność.

6. Składanie odpowiedzi

Po zebraniu wszystkich danych serwer aplikacji generuje odpowiedź dla użytkownika - kod HTML strony internetowej wraz treścią.

7. Wysłanie odpowiedzi

Zebrane dane wysyłane są do przeglądarki użytkownika możliwie najkrótszą drogą przez łącza providerów - niekonieczną tą samą trasą jaką przyszło żądanie!

8. < 1 sec.

Całość procesu od wysłania zapytania do uzyskania odpowiedzi trwa mniej niż 1 sekundę.

Ciekawostki

  • W serwerowni zawsze znajduje się kilka wolno stojących (na stocku) maszyn, które w krótkim czasie można dołączyć do klastra w celu zwiększenia mocy obliczeniowej, np. w okresie przed świętami Bożego Narodzenia kiedy zainteresowanie serwisem wzrasta kilkukrotnie.
  • Żadna z serwerowni nie jest pośrednikiem pomiędzy Allegro a dostawcami internetu. Pozycja firmy jest tak duża, że we własnym zakresie negocjuje umowy, stawki i przepustowości oraz posiada własne przyłącza światłowodowe do swojej infrastruktury.
  • W lipcu 2012 roku Grupa Allegro po raz pierwszy opublikowała oprogramowanie na zasadzie Open Source. Był to Ralph - system ułatwiający uporządkowanie informacji na temat infrastruktury serwerowej. Umożliwia też zautomatyzowanie pracy wykonywanej przy utrzymaniu serwerowni.

Wnioski

Z technologicznego punktu widzenia jest to bardzo skomplikowana architektura, ale zapewnia skalowalność i dostępność serwisu Allegro.pl mimo ogromnej liczby użytkowników odwiedzających go każdego dnia.

Źródła wiedzy i danych

 

internet bezpieczeństwo serwery

Komentarze

0 nowych
  #1 25.05.2013 10:09

i wszystko po to żeby po kwerendzie "kredki" dostać w wynikach pudełka śniadaniowe

denesmet   3 #2 25.05.2013 12:05

Na pewno kilkaset GB a nie TB?

SebaZ   15 #3 25.05.2013 13:34

@bumszakalaka (niezalogowany)
pudełko na śniadanie LUB kredki ;-) Nie moja wina jaki winik - ja tylko zrobiłem screenshota.

@denesmet
Tak powiedział pracownik Allegro na InfoShare - też mi się wydało to dziwne, ale nie zmieniłem jednostki. Może to być prawdą, jeśli wyjąć backupy i treści statyczne takie jak obrazki. No i pamiętaj, że dotyczy to tylko portalu allegro.pl, bez pozostałych zabawek GA.

Autor edytował komentarz.
FaUst   11 #4 25.05.2013 13:36

Az ciekawostek - serwerownia Beyond.pl mieści się w podziemiach poznańskiego Starego Browaru (centrum handlowe i nie tylko - dla tych co nie wiedzą). W niedalekiej przyszłości Beyond ma zamiar wybudować własne DC

SebaZ   15 #5 25.05.2013 13:41

@FaUst
Miałem pokusę, żeby opisać DC dokładnie z pomieszczeniami, zabezpieczeniami, przyłączami i lokalizacjami, ale uznałem, że wpis i tak już jest długi. Może następnym razem dobiorę się do tego tematu szerzej :)

  #6 27.05.2013 22:04

Całość fajnie napisana i co ważne przedstawiona zarówno w liczbach, jak i wizualnie.
Brawo! Czekam na kolejny tego typu wpis na Twoim blogu :)

  #7 28.05.2013 13:44

Fajnie poznać co się dzieje na stronach, nie tylko to co widzimy :) np. ja sporo się dowiedziałem :) dzięki!