Zalety i wady architektury rozproszonej wykorzystującej migawki tylko do odczytu
|
|
- Lidia Turek
- 8 lat temu
- Przeglądów:
Transkrypt
1 Zalety i wady architektury rozproszonej wykorzystującej migawki tylko do odczytu Marek Wojciechowski Instytut Informatyki Politechnika Poznańska ul. Piotrowo 3a, Poznań marek@cs.put.poznan.pl Streszczenie Niniejszy artykuł przedstawia zalety i wady architektury rozproszonej wykorzystującej replikację danych opartą na migawkach tylko do odczytu (ang. read-only snapshots) w stosunku do architektury scentralizowanej oraz rozproszonej bez replikacji. Omówiono w nim kryteria, które należy uwzględnić przy wyborze architektury systemu oraz jej wpływ na funkcjonalność, niezawodność, skalowalność, efektywność przetwarzania i poufność danych. Artykuł jest wynikiem rozważań i analiz prowadzonych podczas pracy nad projektem systemu informatycznego dla szpitali. 1. Wstęp Systemy scentralizowane, w których wszystkie dane znajdują się na jednym serwerze, są zdecydowanie łatwiejsze w projektowaniu, konfiguracji i zarządzaniu od rozproszonych. Nie oznacza to jednak, że scentralizowana architektura bazy danych jest w każdym przypadku właściwa. Systemy rozproszonych baz danych znajdują zastosowanie z dwóch podstawowych powodów. Pierwszy z nich to fakt, że wiele informatyzowanych jednostek (przedsiębiorstw, urzędów, szpitali, itp.) ma ze swej natury charakter rozproszony. W przypadku, gdy firma posiada swoje oddziały w wielu miastach niedopuszczalnym rozwiązaniem byłoby oparcie systemu informatycznego na jednym serwerze bazy danych, ponieważ system taki byłby podatny na awarie łączy komunikacyjnych, a ponadto nawet dostęp do danych o charakterze lokalnym wymagałby odwołań do zdalnego serwera. Z drugiej strony wykorzystywanie przez poszczególne jednostki organizacyjne przedsiębiorstwa w pełni autonomicznych systemów baz danych, między którymi nie ma żadnych powiązań, również nie jest rozwiązaniem idealnym, gdyż w większości przypadków oprócz danych o charakterze lokalnym, występują dane współdzielone przez wszystkie jednostki, bądź udostępniane przez pewne jednostki innym. W takich sytuacjach najlepszym wyjściem jest wykorzystywanie systemów rozproszonych baz danych. Drugim ważnym powodem, dla którego projektuje się systemy o architekturze rozproszonej jest potrzeba zwiększenia mocy przetwarzania. Obecnie systemy informatyczne przetwarzają ogromne ilości danych, a ponadto w większości przypadków ilość pamiętanych danych zwiększa się w trakcie użytkowania systemu. Dlatego też często nawet w sytuacji gdy możliwe byłoby wykorzystanie jednego serwera, dokonuje się rozproszenia danych na kilku mniej obciążonych serwerach. Podstawowe problemy związane z projektowaniem i eksploatacją systemów rozproszonych baz danych wynikają z konieczności wykorzystywania sieci komputerowych przy komunikowaniu się serwerów ze sobą. Żadne łącza transmisyjne nie są niezawodne, w związku z czym zawsze istnieje niebezpieczeństwo, że dane zgromadzone na niektórych serwerach będą przez pewien czas niedostępne. Dodatkowo czas odpowiedzi systemu w przypadku odwoływania się do zdalnych danych może być znacznie dłuższy niż podczas korzystania z danych lokalnych. Prawdopodobieństwo wystąpienia tego typu problemów jest tym większe im wolniejsze i mniej stabilne są połączenia sieciowe. Jak wspomniano wcześniej, rozproszenie danych może mieć na celu rozłożenie obciążenia na kilka serwerów. Jednakże mimo rozproszenia danych, serwery udostępniające dane, z których korzystają wszystkie jednostki organizacyjne mogą w dalszym ciągu być nadmiernie obciążone.
2 Pewnym rozwiązaniem wspomnianych wyżej problemów związanych z rozproszeniem danych jest replikacja. Utrzymywanie kopii danych na wszystkich serwerach, do których kierowane są żądania dostępu do tych danych, jest sposobem na zwiększenie dostępności danych, przy jednoczesnym skróceniu czasu odpowiedzi. Oprogramowanie Oracle Server silnie wspiera replikację. Jednakże bogactwo oferowanych mechanizmów zależy od tego, jakie dodatkowe opcje zostaną zakupione wraz z serwerem. Replikacja podstawowa bazująca na migawkach tylko do odczytu dostępna jest w wersji serwera z PL/SQL i opcją rozproszoną (ang. Oracle Server with the distributed option). Bardziej zaawansowane mechanizmy oferowane są dopiero w wersji serwera uzupełnionej o opcję zaawansowanej replikacji (ang. Oracle Server with the distributed and advanced replication options). Migawki tylko do odczytu są dostępne już wraz z opcją rozproszoną, ich konfigurowanie nie jest skomplikowane, a odpowiednie ich wykorzystanie pozwala na złagodzenie niedogodności związanych z faktem rozproszenia danych. Jednak w konkretnych zastosowaniach, ze względu na swą naturę, migawki mogą wpływać niekorzystnie na funkcjonalność i własności systemu informatycznego. Struktura niniejszego artykułu jest następująca. Rozdział drugi zawiera porównanie różnych architektur pokazując ich zalety i wady. Rozdział trzeci poświęcony jest w całości migawkom tylko do odczytu, ich funkcjonalności oraz sugerowanym zastosowaniom. Rozdział czwarty pokazuje konkretne problemy związane z wykorzystaniem migawek. Rozdział piąty zawiera podsumowanie oraz wskazówki, którymi należy kierować się przy wyborze architektury systemu. 2. Architektury systemów baz danych Podstawowym modelem przetwarzania stosowanym we współczesnych systemach informatycznych jest model klient-serwer (ang. client-server model). W modelu tym przetwarzanie z definicji ma charakter rozproszony i jest realizowane na wielu węzłach komunikujących się ze sobą za pośrednictwem sieci komputerowej. W przypadku systemów baz danych wykorzystujących oprogramowanie firmy Oracle, serwerem jest maszyna, na której pracuje system zarządzania bazą danych Oracle Server. Podstawowym zadaniem aplikacji klientów jest komunikacja z użytkownikiem obejmująca przyjmowanie zapytań do bazy danych oraz prezentację wyników. Należy jednak podkreślić, że część przetwarzania odbywa się również na klientach, co jest jedną z zalet modelu klient-serwer, gdyż pozwala odciążyć serwery powierzając im jedynie zarządzanie danymi. System bazy danych jest określany jako rozproszony, gdy nie tylko przetwarzanie danych odbywa się na wielu węzłach, ale również dane są rozmieszczone na wielu serwerach. W przypadku gdy wszystkie dane znajdują się na jednym serwerze, mamy do czynienia ze scentralizowaną architekturą bazy danych. Zarówno architektura scentralizowana jak i rozproszona mają swoje zalety. Jednakże, jak wspomniano we wstępie, niekiedy geograficzne rozproszenie informatyzowanej organizacji narzuca wybór architektury rozproszonej. Inaczej wygląda sytuacja w przypadku jednostek, które w całości objęte są jedną stabilną siecią lokalną. Wtedy do wyboru architektury rozproszonej mogą skłonić następujące jej zalety: rozłożenie obciążenia każdy z serwerów jest odpowiedzialny za zarządzanie częścią danych, co prowadzi do ich mniejszego obciążenia, a w związku z tym skrócenia czasu odpowiedzi systemu, łatwiejsza skalowalność oprócz skalowalności pionowej polegającej na wymianie serwera na mocniejszy, możliwa jest skalowalność pozioma sprowadzająca się do dodania do systemu nowego serwera (taka operacja może wiązać się z koniecznością rekonfiguracji systemu, jest jednak na pewno mniej kosztowna w przypadku systemu, który od początku swego istnienia zakładał rozproszenie danych). Architektura rozproszona ma również pewne wady, które mogą przemawiać na korzyść architektury scentralizowanej. Problemy związane z rozproszeniem danych to: większy koszt systemu rozproszenie danych wymaga większej liczby komputerów zdolnych do pełnienia funkcji serwera, trudniejsze odtwarzanie spójnego stanu systemu po awarii w przypadku awarii jednego z serwerów, po odtworzeniu jego stanu na podstawie kopii zapasowej stan rozproszonej bazy danych może nie być spójny. Powyższe niedogodności oczywiście nie dyskwalifikują architektury rozproszonej. Jeżeli chodzi o koszt systemu, to w pewnym stopniu fakt rozproszenia danych zmniejsza wymagania sprzętowe stawiane serwerom, w związku z czym w konkretnych przypadkach może okazać się, że zastąpienie jednego mocnego serwera kilkoma słabszymi jest korzystne także ze względów finansowych. Z kolei proces odtwarzania stanu systemu po awarii (ang. recovery), chociaż skomplikowany w przypadku rozproszonych baz danych, jest silnie wspomagany
3 przez Oracle Server np. poprzez wykorzystywanie dzienników powtórzeń (ang. redo logs), co może pozwolić na odtworzenie stanu systemu z chwili tuż przed wystąpieniem awarii. Istotnym kryterium oceny systemu jest jego podatność na awarie. W przypadku architektury scentralizowanej, w której wszystkie dane przedsiębiorstwa znajdują się na jednym serwerze, każda awaria serwera powoduje całkowitą niemożność korzystania z systemu informatycznego we wszystkich jednostkach organizacyjnych przedsiębiorstwa. Natomiast jeżeli system przedsiębiorstwa oparty jest na rozproszonej bazie danych i każda z jednostek organizacyjnych posiada własny serwer zarządzający lokalnymi danymi a jedynie podczas wykonywania niektórych operacji konieczne jest odwołanie do innych serwerów, to awaria dowolnego serwera zatrzyma pracę jedynie w jednej z jednostek, a pozostałe odczują tylko ograniczenie funkcjonalności systemu. Należy jednak zwrócić uwagę, że z punktu widzenia każdej z jednostek szansa wystąpienia awarii pozbawiającej ją dostępu do własnych danych nie jest mniejsza niż w przypadku systemu z jednym serwerem (może być większa ze względu na to, że często zakup kilku serwerów jest alternatywą dla jednego mocniejszego i bardziej niezawodnego serwera), a dodatkowo pojawiają się możliwości częściowej utraty funkcjonalności związane z awariami innych serwerów. Aby chociaż w pewnym stopniu uodpornić system na niebezpieczeństwo utraty połączenia ze zdalnymi serwerami wykorzystuje się replikację danych. Replikacja polega na utrzymywaniu wielu kopii tych samych danych (np. wszędzie tam gdzie są one wykorzystywane). Podstawowe zadanie jakie stoi przed systemem zarządzania bazą danych oferującym replikację to utrzymywanie spójnego stanu replik. W zależności od sposobu propagowania zmian między replikami, replikacja może być synchroniczna lub asynchroniczna. W przypadku replikacji synchronicznej zmiany dokonane na innych stanowiskach są natychmiast odzwierciedlane lokalnie (modyfikacja wszystkich replik odbywa się w ramach jednej transakcji). Replikacja asynchroniczna gwarantuje, że zmiana jednej z replik po pewnym czasie będzie propagowana do pozostałych replik, ale nie musi to nastąpić natychmiast (transakcja modyfikująca jedną z replik może się zakończyć przed uspójnieniem stanu wszystkich replik). Architektura rozproszona z replikacją danych ma następujące zalety w stosunku do architektury rozproszonej bez replikacji: odwołania do zdalnych danych mogą być zastąpione odwołaniami do ich lokalnych replik, co może spowodować skrócenie czasu odpowiedzi (szczególnie w przypadku systemów, w których serwery komunikują się ze sobą poprzez sieci rozległe), a także rozłożenie obciążenia serwerów przy dostępie do współdzielonych w systemie danych, gdy niektóre stanowiska są niedostępne np. z powodu awarii sieci, możliwe jest w dalszym ciągu operowanie na kopiach danych. Stosowanie replikacji ma jednak pewne wady. Replikacja synchroniczna może uniemożliwiać modyfikacje replikowanych danych w sytuacji gdy którakolwiek z replik jest niedostępna. Z kolei replikacja asynchroniczna wiąże się z zezwoleniem na okresową niespójność replik. W związku z powyższym replikacja synchroniczna znajduje zastosowanie w systemach, w których wymagana jest absolutna spójność replik, a połączenia sieciowe są niezawodne. Natomiast wykorzystanie replikacji asynchronicznej jest celowe w przypadkach, gdzie istotna jest przede wszystkim dostępność danych, a nie jest wymagana absolutna spójność replik. Oracle Server umożliwia implementację replikacji synchronicznej za pomocą procedur składowanych i wyzwalaczy. Wsparcie dla replikacji asynchronicznej zależy w sposób istotny od opcji serwera. Oracle Server with the distributed option oferuje jedynie migawki tylko do odczytu (ang. read-only snapshots). Bardziej zaawansowane mechanizmy (replikacja symetryczna, migawki modyfikowalne) dostępne są dopiero w Oracle Server with the distributed and advanced replication options. Opcja zaawansowanej replikacji jest kosztowna, a migawki tylko do odczytu są dostępne już wtedy, gdy możliwe jest rozproszenie bazy danych, pozwalając na korzystanie ze wspomnianych wcześniej zalet replikacji. Wszystko to zachęca do ich stosowania w systemach rozproszonych baz danych, lecz fakt, że nie zezwalają one na modyfikacje danych, a także sam charakter replikacji asynchronicznej, może w niektórych sytuacjach istotnie wpływać na funkcjonalność systemu. 3. Migawki tylko do odczytu Migawka tylko do odczytu jest definiowana przez rozproszone zapytanie odwołujące się do jednej lub więcej tabel źródłowych, perspektyw lub innych migawek. W zależności od postaci zapytania, migawka może być pełną kopią tabeli, kopią fragmentu tabeli lub udostępniać dane z wielu tabel. Dane zawarte w migawce są wynikiem wydania zapytania definiującego migawkę w pewnym momencie w przeszłości. W związku z tym, że dane źródłowe poddane replikacji za pomocą migawek tylko do odczytu mogą się zmieniać w czasie, aby migawka odzwierciedlała w miarę aktualny stan tabel źródłowych, konieczne jest jej odświeżanie. W dowolnej chwili można zażądać odświeżenia migawki lub grupy migawek poprzez wywołanie odpowiedniej procedury
4 składowanej. Ponadto, migawki mogą być odświeżane automatycznie przez system w zadanych odstępach czasowych. Dla pojedynczych migawek lub ich grup specyfikuje się następujące parametry automatycznego odświeżania: interwał czasowy mówiący jak często migawka ma być automatycznie odświeżana (jeśli nie jest podany, to migawka nie jest odświeżana automatycznie i wymaga ręcznego odświeżania za pomocą wywołania procedury składowanej) tryb odświeżania (FAST, COMPLETE lub FORCE). Tryb FAST dostępny jest tylko dla tzw. migawek prostych. Migawka prosta bazuje na jednej tabeli i zapytanie ją definiujące nie zawiera: agregatów, operatora DISTINCT, klauzul GROUP BY lub CONNECT BY, podzapytań, operacji połączenia i operacji na zbiorach. Odświeżanie w trybie FAST jest odświeżaniem przyrostowym polegającym na uwzględnieniu w replice zmian, których dokonano w replikowanej tabeli od chwili poprzedniego odświeżenia migawki. Aby możliwe było wykorzystanie tego trybu, na tabeli źródłowej musi być założony tzw. dziennik migawki, który zawiera informacje o usuniętych, zmodyfikowanych i dodanych krotkach. Replika, która nie spełnia wspomnianych warunków, jest repliką złożoną i wymaga odświeżania w trybie COMPLETE polegającym na ponownym utworzeniu migawki poprzez wykonanie definiującego ją zapytania. Tryb COMPLETE jest z reguły bardziej czasochłonny niż FAST (szczególnie wtedy gdy niewielka część krotek tabeli źródłowej ulega zmianie w okresie między kolejnymi odświeżeniami migawki) i dlatego, mimo że jest oczywiście możliwy również dla migawek prostych, jest na ogół wykorzystywany tylko przy odświeżaniu migawek złożonych, gdy nie ma dla niego alternatywy. Tryb odświeżania FORCE sprowadza się do wykonania odświeżenia w trybie FAST gdy jest ono możliwe, a w przeciwnym wypadku COMPLETE. Podstawową wadą migawek tylko do odczytu jest to, że z definicji nie pozwalają na modyfikowanie danych. W związku z tym, wspomagają one implementację jedynie podstawowego modelu replikacji, w którym jedna z kopii jest kopią matką i tylko ona może być modyfikowana, natomiast pozostałe repliki pozwalają jedynie na odczyt danych. Model taki jest najbardziej odpowiedni w sytuacjach, gdy dane są modyfikowane tylko w jednej z jednostek organizacyjnych przedsiębiorstwa, a czytane w pozostałych. Mimo swojej prostoty i istotnych ograniczeń funkcjonalnych podstawowy model replikacji wykazuje wyższość nad architekturą rozproszoną bez replikacji szczególnie w przypadku znacznego geograficznego rozproszenia jednostek przedsiębiorstwa, gdyż korzystanie z replik przy operacjach odczytu zamiast odwoływania się do zdalnych danych pozwala skrócić czas odpowiedzi, a także gwarantuje dostęp do potrzebnych danych na wypadek awarii połączeń sieciowych. Replikacja asynchroniczna bazująca na migawkach tylko do odczytu jest efektywnym mechanizmem szczególnie wtedy gdy modyfikacje replikowanych danych są rzadkie, bądź gdy nie jest wymagana natychmiastowa propagacja zmian, ponieważ w takich sytuacjach możliwe jest stosunkowo rzadkie odświeżanie migawek w chwilach gdy obciążenie systemu jest niewielkie, np. w nocy. 4. Problemy związane z wykorzystywaniem migawek na przykładzie systemu informatycznego szpitala Podczas prac prowadzonych w Instytucie Informatyki nad systemem informatycznym szpitala Eskulap/2000 [3] rozważane były różne architektury bazy danych. Mimo, że można przyjąć iż w większości przypadków jednostki organizacyjne informatyzowanego szpitala będą połączone stabilną siecią lokalną, wybór padł na architekturę rozproszoną ze względu na ogromne ilości danych przetwarzane w szpitalu oraz nieustanny ich przyrost, który w przypadku architektury scentralizowanej mógłby prowadzić do nadmiernego obciążenia serwera. Natomiast rozproszona architektura bazy danych nie tylko pozwala rozłożyć obciążenie systemu na kilka serwerów, ale także cechuje się bogatszymi możliwościami skalowania systemu. Szpital składa się z wielu jednostek organizacyjnych, które wykonują specyficzne zadania, a w związku z tym są również odpowiedzialne za generowanie różnych danych. Ze względu na duże ilości danych przetwarzanych w systemie informatycznym szpitala oraz poufność niektórych informacji architektura, w której każda z jednostek organizacyjnych posiada swój własny serwer bazy danych, wydaje się być odpowiednia. Problemem jest oczywiście fakt, że dane wprowadzane do systemu w jednej z jednostek organizacyjnych szpitala mogą być wykorzystywane również w innych jednostkach. Idealnym rozwiązaniem jest sytuacja, w której dla zrealizowania wszystkich operacji aplikacje użytkowników systemu z danej jednostki muszą odwoływać się jedynie do lokalnego serwera bazy danych. Aby było to możliwe niezbędna jest replikacja niektórych danych. Ze względu na znaczną różnicę w cenie wersji serwera Oracle Server with the distributed option w stosunku do Oracle Server with the distributed and advanced replication options oprogramowanie Eskulap/2000 zakłada istnienie jedynie opcji rozproszonej, która dla wsparcia replikacji oferuje jedynie migawki tylko do odczytu. Zastosowanie replikacji asynchronicznej opartej na migawkach tylko do odczytu ze względu
5 na ich naturę może jednak w niektórych konkretnych przypadkach w istotny sposób niekorzystnie zmieniać funkcjonalność systemu wprowadzając zagrożenia nie występujące w architekturze rozproszonej bez replikacji. Ponadto, może się okazać, że obciążenie systemu związane z odświeżaniem migawek będzie większe niż w przypadku bezpośredniego odwoływania się do zdalnych relacji. Implementacja replikacji danych za pomocą migawek komplikuje się dodatkowo ze względu na fakt, że często okazuje się iż pewne dane mogą być modyfikowane w kilku jednostkach organizacyjnych. Poniższy rysunek przedstawia uproszczony schemat udostępniania pewnych informacji przez jednostki organizacyjne innym jednostkom. Uwzględnione zostały na nim dane, których udostępnianie komplikuje się w przypadku rozproszonej architektury systemu. Linie przerywane symbolizują możliwość modyfikacji współdzielonych danych w wielu jednostkach, a linie ciągłe udostępnianie danych innym jednostkom tylko do odczytu. Rejestracja Skierowanie do poradni lub przyjęcie na oddział Biuro Przyjęć Współdzielone dane katalogowe Decyzja poradni lub sposób opuszczenia oddziału Oddział A Oddział B Oddział N... Historia choroby Wyniki badań Zakład 1 Zakład 2 Zakład 3 Rysunek 1. Schemat przepływu informacji między jednostkami szpitala Aby lepiej przyjrzeć się zasygnalizowanym problemom, rozważmy następujące zagadnienia związane z funkcjonalnością systemu informatycznego szpitala. 4.1 Modyfikacje replikowanych danych katalogowych W wielu aplikacjach wykorzystywane są dane o charakterze katalogów. Przykładem takich danych są informacje o podziale administracyjnym kraju obejmujące listy województw, powiatów i gmin. Oczywiste jest, że wszystkie jednostki szpitala powinny dysponować taką samą listą województw czy gmin. Lista taka charakteryzuje się niewielką zmiennością w czasie, może się zmienić w wyniku reformy administracyjnej kraju, ale mogą również być konieczne drobne poprawki po wykryciu np. błędów literowych. W tej sytuacji nie ma dużej różnicy czy każda z jednostek będzie mieć w swojej bazie danych niezależne tabele zawierające informacje o gminach, województwach, itp., czy też na jednym stanowisku będą znajdować się tabele źródłowe a na pozostałych repliki odświeżane rzadko lub tylko na żądanie by niepotrzebnie nie obciążać systemu. Rozwiązanie oparte na replikacji wydaje się lepsze, gdyż wymusza modyfikacje na wyróżnionej kopii i automatycznie gwarantuje spójność pozostałych. W systemie wykorzystywane są również katalogi o innym charakterze, które są uaktualniane w trakcie normalnej pracy z systemem. Przykładem takich danych jest lista jednostek obcych, z których pacjenci są kierowani do szpitala lub do których szpital kieruje swoich pacjentów na badania czy konsultacje. Każda z jednostek szpitala powinna dysponować taką samą listą jednostek obcych, aby możliwe było opracowywanie globalnych zestawień statystycznych np. o jednostkach, do których najczęściej kieruje się pacjentów na badania
6 itp. Replikacja asynchroniczna za pomocą migawek tylko do odczytu umożliwia wszystkim jednostkom szybki dostęp do danych katalogowych, ale modyfikacje mogą być wykonane tylko na kopii matce. Brak dostępu do stanowiska, na którym znajduje się kopia źródłowa np. w wyniku awarii serwera uniemożliwi uzupełnienie katalogu. Replikacja nie rozwiązuje więc w tym przypadku całkowicie problemów związanych z rozproszeniem danych, ale zdecydowanie jest wskazana, gdyż gwarantuje możliwość odczytu katalogów, jeśli tylko dostępny jest serwer lokalny. Prawdopodobieństwo ograniczenia funkcjonalności na wypadek awarii jest oczywiście większe niż w wypadku scentralizowanej bazy danych, ale można je zminimalizować umieszczając dane katalogowe na serwerze jednostki, która najczęściej je modyfikuje. 4.2 Udostępnianie historii choroby i modyfikacje danych związanych z chorobami pacjentów Gdy pacjent zostaje skierowany na oddział, zbierane są o nim w trakcie wywiadu informacje o przebytych i współistniejących chorobach, chorobach w rodzinie pacjenta, uczuleniach itp. Są to dane wpisywane do tzw. historii choroby, która jest następnie uzupełniana o aktualne rozpoznania, wyniki badań oraz przebieg leczenia. Ze względu na olbrzymie ilości danych celowe jest zorganizowanie systemu w taki sposób, żeby każdy oddział dysponował lokalnym serwerem bazy danych, na którym składowane są dane dotyczące pacjentów, którzy byli lub aktualnie są leczeni na danym oddziale. Gdy pacjent w przyszłości pojawi się ponownie na tym samym oddziale, lekarze będą mieli oczywiście dostęp do jego historii choroby, będą mogli uaktualnić dane o pacjencie (uczulenia, choroby, itp.). Nie powinna być możliwa modyfikacja dotychczasowej historii choroby, powinna ona jedynie być uzupełniana o nowe informacje. Sytuacja komplikuje się znacznie, gdy pacjent leczony kiedyś w szpitalu pojawia się ponownie, ale na innym oddziale, bądź też gdy w trakcie leczenia zostaje podjęta decyzja o przeniesieniu pacjenta na inny oddział. Nowe informacje związane z historią choroby pacjenta powinny być składowane na serwerze oddziału, na którym aktualnie pacjent przebywa. Natomiast niezbędne jest również udostępnienie historii choroby, która powstała na oddziałach, na których pacjent przebywał wcześniej. Udostępnianie tych informacji za pomocą rozproszonych zapytań odczytujących dane o danym pacjencie z serwerów wszystkich oddziałów jest niebezpieczne, gdyż zakończy się niepowodzeniem w przypadku awarii któregokolwiek z serwerów oddziałowych, a dodatkowo może okazać się nieefektywne, ponieważ wymaga wykonywania rozproszonych transakcji. Replikowanie danych dotyczących pacjentów leczonych aktualnie na oddziale z innych oddziałów wydaje się kuszącym rozwiązaniem. Nawet ograniczając się do migawek tylko do odczytu, taką replikację można zrealizować na kilka sposobów. Pierwszy z nich to wykorzystanie jednej migawki bazującej na unii danych z odpowiadających sobie tabel ze wszystkich oddziałów. Wadą takiego rozwiązania jest fakt, że odświeżenie migawki nie powiedzie się w przypadku, gdy chociaż jeden z serwerów oddziałowych będzie z jakiegoś powodu niedostępny. Ulepszeniem takiego wariantu jest konfiguracja, w której dla każdego z pozostałych oddziałów tworzony jest w lokalnej bazie danych zestaw migawek odwołujących się do danych tylko z danego oddziału, a dane zbiorcze są udostępniane poprzez perspektywy bazujące na uniach odpowiadających sobie migawek. Wtedy na wypadek awarii, gdy jeden z serwerów oddziałowych będzie niedostępny, każdy z pozostałych oddziałów może mieć dostęp do aktualnych danych ze wszystkich oddziałów poza tym niedostępnym (oczywiście dostępne są dane z chwili ostatniego odświeżenia migawek replikujących jego obiekty). Ceną za bezpieczniejsze odświeżanie migawek w tej konfiguracji jest dłuższy czas wykonywania zapytań odwołujących się do historii choroby z innych oddziałów ze względu na wykorzystanie złożonych perspektyw. We wszystkich powyższych wariantach występują dwa istotne problemy. Pierwszy wiąże się z trybem odświeżania migawek, a drugi wynika z faktu, że niekiedy konieczne może być zezwolenie na modyfikacje danych pamiętanych na serwerach innych oddziałów. Efektywnym trybem odświeżania migawek jest tryb FAST, szczególnie w przypadku rzadko modyfikowanych danych. Niestety jest on możliwy tylko dla migawek prostych. Natomiast aby migawki z historią choroby zawierały dane tylko tych pacjentów, którzy w danej chwili są leczeni na oddziale, muszą one w swej definicji zawierać podzapytanie zwracające identyfikatory pacjentów, dla których istnieją aktualne pobyty na oddziale. Migawki takie musiałyby być odświeżane bardziej kosztownym trybem COMPLETE. Odświeżanie w trybie FAST wymagałoby rezygnacji z filtrowania danych i replikacji prawie wszystkich danych każdego oddziału na pozostałych oddziałach, co w znacznym stopniu podważyłoby sens replikacji, której celem było rozłożenie obciążenia w systemie. Wagę opisywanego problemu na szczęście zmniejsza fakt, że odświeżenie migawek konieczne byłoby tylko w chwili przyjęcia na oddział pacjenta, który był kiedyś leczony na innym oddziale. Drugi ważny problem występuje gdy replikowane dane mogą być modyfikowane przez wiele oddziałów. Przykładem są informacje o chorobach pacjentów. Naturalnym rozwiązaniem jest pamiętanie ich w tabeli o strukturze: identyfikator pacjenta, identyfikator choroby, rok zachorowania, opcjonalny rok zakończenia choroby. Każdy oddział posiadający lokalną tabelę z chorobami pacjentów musiałby posiadać repliki takich tabel z innych oddziałów. Problem pojawia się gdy zachorowanie pacjenta na jakąś chorobę zaewidencjonuje jeden oddział, a datę zakończenia choroby wprowadza drugi. Wariant z modyfikacją tabeli
7 źródłowej, który sprawdził się w przypadku danych katalogowych, w tym wypadku się komplikuje, gdyż trzeba rozstrzygnąć w której z baz danych tabela źródłowa się znajduje. Rozwiązaniem powyższych problemów może być utrzymywanie danych pacjenta tylko w jednej kopii na oddziale, na którym pacjent przebywa, a po zakończeniu pobytu przenoszenie ich do centralnego archiwum. Przy kolejnym przyjęciu pacjenta na dowolny z oddziałów, dane o nim byłyby sprowadzane na dany oddział. Rozwiązanie takie również nie jest niestety idealne, ponieważ zdarza się, że dane pacjenta są w danej chwili potrzebne na dwóch oddziałach jednocześnie np. gdy pacjent w ramach pobytu na jednym oddziale jest kierowany na konsultacje lub zabieg na drugi oddział. W związku z tym, być może najlepszym rozwiązaniem jest rezygnacja z rozpraszania tych danych, które potencjalnie mogą dotyczyć wielu oddziałów. 4.3 Udostępnianie wyników badań pacjentów innym jednostkom Danymi, które również są wprowadzane w pewnych jednostkach i udostępniane innym są wyniki badań. Pacjenci przebywający na oddziałach kierowani są na badania np. do laboratorium, zakładu radiologii, itp. W przypadku architektury rozproszonej, gdzie jednostki wykonujące badania wprowadzają wyniki badań do swoich lokalnych baz danych, pojawia się problem udostępniania oddziałom wyników ich pacjentów. Wykorzystanie migawek tylko do odczytu prowadzi do dylematu nad trybem ich odświeżania. Problem jest tu bardziej istotny niż w przypadku udostępniania historii choroby, gdyż migawki z wynikami badań powinny być odświeżane możliwie często (jeśli czas potrzebny na przesłanie wyników badań drogą elektroniczną byłby dłuższy niż papierową, sensowność używania systemu informatycznego zostałaby w znacznym stopniu podważona). Rezygnacja z replikacji prowadziłaby do konieczności wykonywania rozproszonych zapytań przy każdym żądaniu wyświetlenia wyników badań pacjenta. Być może jednak takie zapytania byłyby generowane przez użytkowników nie częściej niż przez system w celu odświeżania migawek, a na pewno wymagałyby transmisji mniejszej ilości danych. Za wykorzystaniem replikacji przemawia jedynie kwestia dostępności danych na wypadek awarii. Zdarza się jednak, że kwestie dostępności pewnych danych są regulowane specjalnymi przepisami i czas udostępniania tych danych musi być ściśle kontrolowany. Replikacja tego typu danych ogranicza kontrolę dostępu do nich, szczególnie na wypadek awarii połączeń sieciowych opóźniającej odświeżenie migawek. 4.4 Propagowanie ważnych decyzji oraz informacji o ich ewentualnym anulowaniu Wiele decyzji podejmowanych w różnych jednostkach szpitala implikuje pewne akcje w innych jednostkach. Przykładowo decyzja izby przyjęć o skierowaniu pacjenta na dany oddział upoważnia ten oddział do przyjęcia pacjenta. Przenoszenie informacji o tego typu decyzjach za pomocą migawek tylko do odczytu, pozwala na zatwierdzenie i wprowadzenie do systemu decyzji dotyczącej jakiejś jednostki, nawet gdy jej baza danych jest niedostępna, gdyż jest gwarancja, że po usunięciu awarii migawki się odświeżą i informacja dotrze do adresata. Korzystanie z danych innych jednostek za pomocą migawek ukrywa przed użytkownikami awarie połączeń sieciowych. Tego typu awarie nie spowodują utraty dostępu do danych, a jedynie nie pozwolą na odświeżenie migawek, przez co nie przepłyną nowe informacje. Jeśli nie przepłynie drogą elektroniczną np. decyzja o przyjęciu pacjenta na oddział, to uszkodzenie połączenia zostanie wykryte w chwili, gdy pacjent fizycznie zgłosi się na oddział. Są jednak sytuacje, w których nieświadomość użytkowników, że nie mają dostępu do najświeższych danych może mieć katastrofalne skutki. Żaden z użytkowników systemu nie jest nieomylny i zawsze istnieje możliwość wprowadzenia do systemu pewnych danych przez pomyłkę. Zezwolenie na usuwanie omyłkowo wprowadzonych do bazy danych informacji może być niewskazane. Na przykład wprowadzony przez przypadek błędny wynik badania może spowodować podjęcie przez lekarza niewłaściwej decyzji. Zezwolenie na jego usunięcie zafałszowałoby obraz sytuacji, w której decyzja została podjęta. Właściwszym rozwiązaniem jest umożliwienie jedynie anulowania niepoprawnych wpisów. W przypadku gdy informacja o anulowaniu jakiegoś wpisu udostępniana jest innym jednostkom poprzez migawki tylko do odczytu, istnieje niebezpieczeństwo, że informacja nie będzie propagowana z powodu awarii połączeń sieciowych, a użytkownik dokonujący anulowania nawet nie zostanie poinformowany o braku komunikacji. Dlatego wydaje się, że kluczowe decyzje w systemie powinny być przenoszone w ramach rozproszonych transakcji, aby szybko można było wykryć awarię połączeń. 5. Podsumowanie W artykule przedstawiono zalety i wady architektury rozproszonej wykorzystującej replikację danych opartą na migawkach tylko do odczytu, odwołując się do konkretnych przykładów z projektowanego w Instytucie Informatyki Politechniki Poznańskiej systemu informatycznego szpitala. Rozproszenie danych pozwala na rozłożenie obciążenia w systemie, a także ułatwia jego skalowanie. Może się ono jednak wiązać ze znacznym
8 skomplikowaniem implementacji pewnych mechanizmów, a także zwiększyć podatność systemu na awarie. Aby niskim kosztem uodpornić system na awarie połączeń sieciowych oraz poprawić efektywność wykonywania zapytań, wskazane jest replikowanie niektórych danych za pomocą migawek tylko do odczytu. Przy wyborze danych, które mają być replikowane należy zdawać sobie sprawę, że tego typu replikacja może silnie wpływać na funkcjonalność systemu. Najlepsze efekty daje replikacja danych, które są często czytane, a stosunkowo rzadko modyfikowane, przy czym najlepiej aby modyfikacje były dokonywane tylko w jednej z jednostek informatyzowanej organizacji. W przypadku danych modyfikowanych w wielu jednostkach, być może należy nawet zrezygnować z ich rozproszenia lub zastosować bardziej kosztowną replikację symetryczną. Replikacja za pomocą migawek tylko do odczytu, ze względu na swój asynchroniczny charakter, jest również niewskazana przy przesyłaniu między jednostkami informacji, które powinny natychmiast dotrzeć do adresata, a ewentualna niemożność ich przesłania nie powinna być ukrywana przed użytkownikami. Literatura [1] Oracle7 Server Distributed Systems Manual, Vol. 1, Oracle7 Documentation. [2] Oracle7 Server Distributed Systems Manual, Vol. 2, Oracle7 Documentation. [3] T. Biały, System informatyczny Eskulap/2000, PLOUG 98, listopad [4] S. Ceri, G. Pelagatti, Distributed Databases Principles and Systems, McGraw Hill Book Company, [5] T. Koszlajda, Synchroniczna a asynchroniczna replikacja danych w systemach rozproszonych baz danych, POLMAN 98, kwiecień 1998.
Problemy niezawodnego przetwarzania w systemach zorientowanych na usługi
Problemy niezawodnego przetwarzania w systemach zorientowanych na usługi Jerzy Brzeziński, Anna Kobusińska, Dariusz Wawrzyniak Instytut Informatyki Politechnika Poznańska Plan prezentacji 1 Architektura
Bazy danych. Plan wykładu. Rozproszona baza danych. Fragmetaryzacja. Cechy bazy rozproszonej. Replikacje (zalety) Wykład 15: Rozproszone bazy danych
Plan wykładu Bazy danych Cechy rozproszonej bazy danych Implementacja rozproszonej bazy Wykład 15: Rozproszone bazy danych Małgorzata Krętowska, Agnieszka Oniśko Wydział Informatyki PB Bazy danych (studia
Replikacja bazy danych polega na kopiowaniu i przesyłaniu danych lub obiektów bazodanowych między serwerami oraz na zsynchronizowaniu tych danych w
J. Karwowska Replikacja bazy danych polega na kopiowaniu i przesyłaniu danych lub obiektów bazodanowych między serwerami oraz na zsynchronizowaniu tych danych w celu utrzymania ich spójności. Dane kopiowane
Od czego zacząć przy budowaniu środowisk wysokiej dostępności?
Budowanie środowisk wysokiej dostępności w oparciu o nową wersję IDS 11 Artur Wroński IBM Information Management Technical Team Leader artur.wronski@pl.ibm.com Od czego zacząć przy budowaniu środowisk
Rozproszone bazy danych. Robert A. Kłopotek Wydział Matematyczno-Przyrodniczy. Szkoła Nauk Ścisłych, UKSW
Rozproszone bazy danych Robert A. Kłopotek r.klopotek@uksw.edu.pl Wydział Matematyczno-Przyrodniczy. Szkoła Nauk Ścisłych, UKSW Scentralizowana baza danych Dane są przechowywane w jednym węźle sieci Można
Bazy danych 2. Wykład 1
Bazy danych 2 Wykład 1 Sprawy organizacyjne Materiały i listy zadań zamieszczane będą na stronie www.math.uni.opole.pl/~ajasi E-mail: standardowy ajasi@math.uni.opole.pl Sprawy organizacyjne Program wykładu
Autorytatywne serwery DNS w technologii Anycast + IPv6 DNS NOVA. Dlaczego DNS jest tak ważny?
Autorytatywne serwery DNS w technologii Anycast + IPv6 DNS NOVA Dlaczego DNS jest tak ważny? DNS - System Nazw Domenowych to globalnie rozmieszczona usługa Internetowa. Zapewnia tłumaczenie nazw domen
Systemy rozproszone. na użytkownikach systemu rozproszonego wrażenie pojedynczego i zintegrowanego systemu.
Systemy rozproszone Wg Wikipedii: System rozproszony to zbiór niezależnych urządzeń (komputerów) połączonych w jedną, spójną logicznie całość. Połączenie najczęściej realizowane jest przez sieć komputerową..
Galileo - encyklopedia internetowa Plan testów
Galileo - encyklopedia internetowa Plan testów Sławomir Pawlewicz Alan Pilawa Joanna Sobczyk Matek Sobierajski 5 czerwca 2006 1 Spis treści 1 Wprowadzenie 3 1.1 Cel..........................................
Zapewnienie wysokiej dostępności baz danych. Marcin Szeliga MVP SQL Server MCT
Zapewnienie wysokiej dostępności baz Marcin Szeliga MVP SQL Server MCT Agenda Techniki zapewniania wysokiej dostępności baz Zasada działania mirroringu baz Wdrożenie mirroringu Planowanie Konfiguracja
Systemy rozproszonych baz danych 1
Systemy rozproszonych baz danych 1 Problematyka rozproszonych baz danych Wykład przygotował: Robert Wrembel ZSBD wykład 1 (1) 1 Plan wykładu Wprowadzenie do problematyki Definicja rozproszonej bazy danych
Replikacje. dr inż. Dziwiński Piotr Katedra Inżynierii Komputerowej. Kontakt:
dr inż. Dziwiński Piotr Katedra Inżynierii Komputerowej Kontakt: piotr.dziwinski@kik.pcz.pl Replikacje 2 1 Podstawowe pojęcia Strategie replikacji Agenci replikacji Typy replikacji Modele replikacji Narzędzia
Koncepcja wirtualnej pracowni GIS w oparciu o oprogramowanie open source
Koncepcja wirtualnej pracowni GIS w oparciu o oprogramowanie open source Dr inż. Michał Bednarczyk Uniwersytet Warmińsko-Mazurski w Olsztynie Wydział Geodezji i Gospodarki Przestrzennej Katedra Geodezji
Wprowadzenie. Dariusz Wawrzyniak 1
Dariusz Wawrzyniak Politechnika Poznańska Instytut Informatyki ul. Piotrowo 2 (CW, pok. 5) 60-965 Poznań Dariusz.Wawrzyniak@cs.put.poznan.pl Dariusz.Wawrzyniak@put.edu.pl www.cs.put.poznan.pl/dwawrzyniak
Podstawy Systemów Zarządzania Baz Danych
Podstawy Systemów Zarządzania Baz Danych 1. System Zarządzania Bazą Danych (SZBD) System Zarządzania Bazą Danych to zorganizowany zbiorem narzędzi umożliwiających definiowanie i konstruowanie bazy danych,
Wykład I. Wprowadzenie do baz danych
Wykład I Wprowadzenie do baz danych Trochę historii Pierwsze znane użycie terminu baza danych miało miejsce w listopadzie w 1963 roku. W latach sześcdziesątych XX wieku został opracowany przez Charles
Projekt dotyczy stworzenia zintegrowanego, modularnego systemu informatycznego wspomagającego zarządzanie pracownikami i projektami w firmie
Projekt dotyczy stworzenia zintegrowanego, modularnego systemu informatycznego wspomagającego zarządzanie pracownikami i projektami w firmie informatycznej. Zadaniem systemu jest rejestracja i przechowywanie
Dokumentacja wstępna TIN. Rozproszone repozytorium oparte o WebDAV
Piotr Jarosik, Kamil Jaworski, Dominik Olędzki, Anna Stępień Dokumentacja wstępna TIN Rozproszone repozytorium oparte o WebDAV 1. Wstęp Celem projektu jest zaimplementowanie rozproszonego repozytorium
Referat pracy dyplomowej
Referat pracy dyplomowej Temat pracy: Wdrożenie intranetowej platformy zapewniającej organizację danych w dużej firmie na bazie oprogramowania Microsoft SharePoint Autor: Bartosz Lipiec Promotor: dr inż.
SZKOLENIE: Administrator baz danych. Cel szkolenia
SZKOLENIE: Administrator baz danych. Cel szkolenia Kurs Administrator baz danych skierowany jest przede wszystkim do osób zamierzających rozwijać umiejętności w zakresie administrowania bazami danych.
Sieci równorzędne, oraz klient - serwer
Sieci równorzędne, oraz klient - serwer podział sieci ze względu na udostępnianie zasobów: równorzędne, peer-to-peer, P2P, klient/serwer, żądanie, odpowiedź, protokół sieciowy, TCP/IP, IPX/SPX, admin sieciowy,
IBM DCE/DFS. Mikołaj Gierulski. 17 stycznia 2003
IBM DCE/DFS Mikołaj Gierulski 17 stycznia 2003 1 Spis treści 1 IBM DCE 3 2 DCE/Distributed File Service 3 2.1 Rozwiązanie podstawowych problemów rozproszonych systemów plików.... 3 2.1.1 Nazewnictwo................................
Przetwarzanie i zabezpieczenie danych w zewnętrznym DATA CENTER
Przetwarzanie i zabezpieczenie danych w zewnętrznym DATA CENTER Gdańsk, 27-28 września 2012 r. Krzysztof Pytliński Zakład Teleinformatyki Kontekst Data Center jako usługa zewnętrzna, zaspokajająca potrzeby
Niezawodne usługi outsourcingowe na przykładzie usług kampusowych i Krajowego Magazynu Danych w sieci PIONIER
Niezawodne usługi outsourcingowe na przykładzie usług kampusowych i Krajowego Magazynu Danych w sieci PIONIER Prof. Roman Wyrzykowski, Politechnika Częstochowska Rafał Mikołajczak, Marek Zawadzki Poznańskie
Opis wdrożenia Platformy Technologicznej epodreczniki.pl na zasobach Poznańskiego Centrum Superkomputerowo-Sieciowego
Opis wdrożenia Platformy Technologicznej epodreczniki.pl na zasobach Poznańskiego Centrum Superkomputerowo-Sieciowego w ramach realizacji umowy pomostowej nr 427/PCSS/2016 Poznań, 21 lutego 2017 r. 1 Spis
Charakterystyka sieci klient-serwer i sieci równorzędnej
Charakterystyka sieci klient-serwer i sieci równorzędnej Sieć klient-serwer Zadaniem serwera w sieci klient-serwer jest: przechowywanie plików i programów systemu operacyjnego; przechowywanie programów
Wykonać Ćwiczenie: Active Directory, konfiguracja Podstawowa
Wykonać Ćwiczenie: Active Directory, konfiguracja Podstawowa Instalacja roli kontrolera domeny, Aby zainstalować rolę kontrolera domeny, należy uruchomić Zarządzenie tym serwerem, po czym wybrać przycisk
Opis Architektury Systemu Galileo
Opis Architektury Systemu Galileo Sławomir Pawlewicz Alan Pilawa Joanna Sobczyk Marek Sobierajski 5 czerwca 2006 1 Spis treści 1 Wprowadzenie 5 1.1 Cel.......................................... 5 1.2 Zakres........................................
Podstawowe pojęcia dotyczące relacyjnych baz danych. mgr inż. Krzysztof Szałajko
Podstawowe pojęcia dotyczące relacyjnych baz danych mgr inż. Krzysztof Szałajko Czym jest baza danych? Co rozumiemy przez dane? Czym jest system zarządzania bazą danych? 2 / 25 Baza danych Baza danych
Systemy rozproszone System rozproszony
Systemy rozproszone Wg Wikipedii: System rozproszony to zbiór niezależnych urządzeń (komputerów) połączonych w jedną, spójną logicznie całość. Połączenie najczęściej realizowane jest przez sieć komputerową.
współbieżność - zdolność do przetwarzania wielu zadań jednocześnie
Systemy rozproszone Wg Wikipedii: System rozproszony to zbiór niezależnych urządzeń (komputerów) połączonych w jedną, spójną logicznie całość. Połączenie najczęściej realizowane jest przez sieć komputerową.
Architektura i mechanizmy systemu
Architektura i mechanizmy systemu Warsztaty Usługa powszechnej archiwizacji Michał Jankowski, PCSS Maciej Brzeźniak, PCSS Plan prezentacji Podstawowe wymagania użytkowników - cel => Funkcjonalnośd i cechy
Część I Tworzenie baz danych SQL Server na potrzeby przechowywania danych
Spis treści Wprowadzenie... ix Organizacja ksiąŝki... ix Od czego zacząć?... x Konwencje przyjęte w ksiąŝce... x Wymagania systemowe... xi Przykłady kodu... xii Konfiguracja SQL Server 2005 Express Edition...
Nowe aplikacje i usługi w środowisku Grid
Nowe aplikacje i usługi w środowisku Grid Wstęp Pojęcie GRID Aplikacje/Usługi Laboratorium Wirtualne Krajowy Magazyn Danych Zastosowanie Skala i zasięg Użytkownik końcowy Uwarunkowania ekonomiczne Laboratorium
Diagram wdrożenia. Rys. 5.1 Diagram wdrożenia.
Diagram wdrożenia Zaprojektowana przez nas aplikacja bazuje na architekturze client-server. W tej architekturze w komunikacji aplikacji klienckiej z bazą danych pośredniczy serwer aplikacji, który udostępnia
Rok szkolny 2015/16 Sylwester Gieszczyk. Wymagania edukacyjne w technikum. ADMINISTROWANIE BAZAMI DANYCH kl. 4c
Wymagania edukacyjne w technikum ADMINISTROWANIE BAZAMI DANYCH kl. 4c Lp. 1 2 4 5 Temat Zasady dotyczące zarządzania projektem podczas prac związanych z tworzeniem bazy oraz cykl życiowy bazy Modele tworzenia
Wstęp. Historia i przykłady przetwarzania współbieżnego, równoległego i rozproszonego. Przetwarzanie współbieżne, równoległe i rozproszone
Wstęp. Historia i przykłady przetwarzania współbieżnego, równoległego i rozproszonego 1 Historia i pojęcia wstępne Przetwarzanie współbieżne realizacja wielu programów (procesów) w taki sposób, że ich
Spis treści. 1 Moduł RFID (APA) 3
Spis treści 1 Moduł RFID (APA) 3 1.1 Konfigurowanie Modułu RFID..................... 3 1.1.1 Lista elementów Modułu RFID................. 3 1.1.2 Konfiguracja Modułu RFID (APA)............... 4 1.1.2.1
SQL w 24 godziny / Ryan Stephens, Arie D. Jones, Ron Plew. Warszawa, cop Spis treści
SQL w 24 godziny / Ryan Stephens, Arie D. Jones, Ron Plew. Warszawa, cop. 2016 Spis treści O autorach 11 Podziękowania 12 Część I Wprowadzenie do języka SQL 13 Godzina 1. Witamy w świecie języka SQL 15
INTERNETOWE BAZY DANYCH materiały pomocnicze - wykład X
Wrocław 2006 INTERNETOWE BAZY DANYCH materiały pomocnicze - wykład X Paweł Skrobanek C-3, pok. 323 e-mail: pawel.skrobanek@pwr.wroc.pl INTERNETOWE BAZY DANYCH PLAN NA DZIŚ zajęcia 1: 2. Procedury składowane
Wybrane działy Informatyki Stosowanej
Wybrane działy Informatyki Stosowanej Dr inż. Andrzej Czerepicki a.czerepicki@wt.pw.edu.pl http://www2.wt.pw.edu.pl/~a.czerepicki 2017 APLIKACJE SIECIOWE Definicja Architektura aplikacji sieciowych Programowanie
REGULAMIN OCHRONY DANYCH OSOBOWYCH W ZASOBACH SPÓŁDZIELNI MIESZKANIOWEJ LOKATORSKO- WŁASNOŚCIOWEJ w Konstancinie-Jeziornie.
REGULAMIN OCHRONY DANYCH OSOBOWYCH W ZASOBACH SPÓŁDZIELNI MIESZKANIOWEJ LOKATORSKO- WŁASNOŚCIOWEJ w Konstancinie-Jeziornie. I Podstawa prawna: 1. Ustawa z dnia 29.08.1997 roku o ochronie danych osobowych
Wojewódzki Specjalistyczny Szpital Dziecięcy w Kielcach. Szpitalny System Informatyczny
Wojewódzki Specjalistyczny Szpital Dziecięcy w Kielcach Szpitalny System Informatyczny Historia szpitala rozpoczyna się w 1920 r. - 01.01.1922r. przyjęto pierwszego pacjenta. Wojewódzki Specjalistyczny
Zarządzanie transakcjami
Zarządzanie transakcjami Właściwości ACID Przyjmuje się, że transakcje i protokoły zarządzania transakcjami powinny posiadać właściwości ACID: Atomowość (atomicity) każda transakcja stanowi pojedynczą
Problemy optymalizacji, rozbudowy i integracji systemu Edu wspomagającego e-nauczanie i e-uczenie się w PJWSTK
Problemy optymalizacji, rozbudowy i integracji systemu Edu wspomagającego e-nauczanie i e-uczenie się w PJWSTK Paweł Lenkiewicz Polsko Japońska Wyższa Szkoła Technik Komputerowych Plan prezentacji PJWSTK
Oracle11g: Wprowadzenie do SQL
Oracle11g: Wprowadzenie do SQL OPIS: Kurs ten oferuje uczestnikom wprowadzenie do technologii bazy Oracle11g, koncepcji bazy relacyjnej i efektywnego języka programowania o nazwie SQL. Kurs dostarczy twórcom
Hurtownie danych. Wstęp. Architektura hurtowni danych. http://zajecia.jakubw.pl/hur CO TO JEST HURTOWNIA DANYCH
Wstęp. Architektura hurtowni. Jakub Wróblewski jakubw@pjwstk.edu.pl http://zajecia.jakubw.pl/hur CO TO JEST HURTOWNIA DANYCH B. Inmon, 1996: Hurtownia to zbiór zintegrowanych, nieulotnych, ukierunkowanych
Sieciowa instalacja Sekafi 3 SQL
Sieciowa instalacja Sekafi 3 SQL Niniejsza instrukcja opisuje instalację Sekafi 3 SQL w wersji sieciowej, z zewnętrznym serwerem bazy danych. Jeśli wymagana jest praca jednostanowiskowa, należy postępować
Wstęp. Opis ten dotyczy wydziałów orzeczniczych.
Wstęp. Opis ten dotyczy wydziałów orzeczniczych. W związku z przekształceniem 79 Sądów w Wydziały Zamiejscowe i związane z tym liczne zapytania odnośnie strony technicznej i sposobu przygotowania baz danych
Dotacje na innowacje Inwestujemy w waszą przyszłość
Załącznik nr 1 Załącznik techniczny przedmiotu zamówienia zakup badań w zakresie opracowania wersji serwera aplikacyjnego pod aplikację wektorową i obsługi wymiany treści multimedialnych w tymże serwerze
Opis administracji terminali ABA-X3 v.1.5.0
Opis administracji terminali v.1.5.0 System terminalowy jest scentralizowany oznacza to, że Użytkownik stacji roboczej (terminala) jest całkowicie uzależniony od konfiguracji wprowadzonej przez Administratora.
1 Moduł Inteligentnego Głośnika
1 Moduł Inteligentnego Głośnika Moduł Inteligentnego Głośnika zapewnia obsługę urządzenia fizycznego odtwarzającego komunikaty dźwiękowe. Dzięki niemu możliwa jest konfiguracja tego elementu Systemu oraz
Zapytanie ofertowe nr 03/05/2014. Zakup licencji na oprogramowanie do wirtualizacji Działanie POIG 8.2
nr 03/05/2014 Zakup licencji na oprogramowanie do wirtualizacji Działanie POIG 8.2 Warszawa, 5 maja 2014 Veriti sp. z o.o. ul. Koszycka 8 01-446 Warszawa Tel/Faks : +48 22 100 62 42 e-mail: biuro@veriti.pl
KS-ZSA. Korporacyjne grupy towarowe
KS-ZSA Korporacyjne grupy towarowe 1. Ustawienia po stronie KS-ZSA Aby rozpocząć pracę z korporacyjnymi grupami towarowymi system KS-ZSA należy odpowiednio skonfigurować KS-ZSA: Uprawnienia: - 61.Admin
E-administracja warunkiem rozwoju Polski. Obecna i potencjalna rola epuap w procesowym zarządzaniu w administracji
E-administracja warunkiem rozwoju Polski Obecna i potencjalna rola epuap w procesowym zarządzaniu w administracji Mariusz Madejczyk Ministerstwo Spraw Wewnętrznych i Administracji 1 epuap, a zarządzanie
1 Moduł Inteligentnego Głośnika 3
Spis treści 1 Moduł Inteligentnego Głośnika 3 1.1 Konfigurowanie Modułu Inteligentnego Głośnika........... 3 1.1.1 Lista elementów Modułu Inteligentnego Głośnika....... 3 1.1.2 Konfigurowanie elementu
Spis treści. Przedmowa
Spis treści Przedmowa V 1 SQL - podstawowe konstrukcje 1 Streszczenie 1 1.1 Bazy danych 1 1.2 Relacyjny model danych 2 1.3 Historia języka SQL 5 1.4 Definiowanie danych 7 1.5 Wprowadzanie zmian w tabelach
Regulamin usług świadczonych drogą elektroniczną dla strony www.tauron-pe.pl
Regulamin usług świadczonych drogą elektroniczną dla strony www.tauron-pe.pl 2012-05-22 TAURON Obsługa Klienta Strona 2 z 10 Rozdział 1 Postanowienia ogólne 1 1. Niniejszy regulamin (dalej zwany Regulaminem)
Ramowy plan kursu. Lp. Moduły Wyk. Lab. Przekazywane treści
Ramowy plan kursu Lp. Moduły Wyk. Lab. Przekazywane treści 1 3 4 Technologia MS SQL Server 2008 R2. Podstawy relacyjnego modelu i projektowanie baz. Zaawansowane elementy języka SQL. Programowanie w języku
Pojęcie bazy danych. Funkcje i możliwości.
Pojęcie bazy danych. Funkcje i możliwości. Pojęcie bazy danych Baza danych to: zbiór informacji zapisanych według ściśle określonych reguł, w strukturach odpowiadających założonemu modelowi danych, zbiór
System Kancelaris. Zdalny dostęp do danych
Kancelaris krok po kroku System Kancelaris Zdalny dostęp do danych Data modyfikacji: 2008-07-10 Z czego składaj adają się systemy informatyczne? System Kancelaris składa się z dwóch części: danych oprogramowania,
AUREA BPM Oracle. TECNA Sp. z o.o. Strona 1 z 7
AUREA BPM Oracle TECNA Sp. z o.o. Strona 1 z 7 ORACLE DATABASE System zarządzania bazą danych firmy Oracle jest jednym z najlepszych i najpopularniejszych rozwiązań tego typu na rynku. Oracle Database
Temat: Ułatwienia wynikające z zastosowania Frameworku CakePHP podczas budowania stron internetowych
PAŃSTWOWA WYŻSZA SZKOŁA ZAWODOWA W ELBLĄGU INSTYTUT INFORMATYKI STOSOWANEJ Sprawozdanie z Seminarium Dyplomowego Temat: Ułatwienia wynikające z zastosowania Frameworku CakePHP podczas budowania stron internetowych
Internetowe Konto Pacjenta swobodne zarządzanie dokumentacją medyczną
Internetowe Konto Pacjenta swobodne zarządzanie dokumentacją medyczną Piotr Szmołda Kierownik Projektów piotr.szmolda@unizeto.pl Projekt współfinansowany przez Unię Europejską ze środków Europejskiego
VPN Virtual Private Network. Użycie certyfikatów niekwalifikowanych w sieciach VPN. wersja 1.1 UNIZETO TECHNOLOGIES SA
VPN Virtual Private Network Użycie certyfikatów niekwalifikowanych w sieciach VPN wersja 1.1 Spis treści 1. CO TO JEST VPN I DO CZEGO SŁUŻY... 3 2. RODZAJE SIECI VPN... 3 3. ZALETY STOSOWANIA SIECI IPSEC
PROCEDURA ADMINISTROWANIA ORAZ USUWANIA AWARII I BŁĘDÓW W CSIZS
Załącznik nr 3 do umowy nr 10/DI/PN/2016 PROCEDURA ADMINISTROWANIA ORAZ USUWANIA AWARII I BŁĘDÓW W Rozdział 1. ADMINISTROWANIE 1. Wykonawca, w celu zapewnienia ciągłości funkcjonowania, zobowiązuje się
T-SQL dla każdego / Alison Balter. Gliwice, cop Spis treści. O autorce 11. Dedykacja 12. Podziękowania 12. Wstęp 15
T-SQL dla każdego / Alison Balter. Gliwice, cop. 2016 Spis treści O autorce 11 Dedykacja 12 Podziękowania 12 Wstęp 15 Godzina 1. Bazy danych podstawowe informacje 17 Czym jest baza danych? 17 Czym jest
Praca w sieci z serwerem
11 Praca w sieci z serwerem Systemy Windows zostały zaprojektowane do pracy zarówno w sieci równoprawnej, jak i w sieci z serwerem. Sieć klient-serwer oznacza podłączenie pojedynczego użytkownika z pojedynczej
GIT. Rozproszony system kontroli wersji
GIT Rozproszony system kontroli wersji Co to jest system kontroli wersji? System kontroli wersji śledzi wszystkie zmiany dokonywane na pliku (lub plikach) i umożliwia przywołanie dowolnej wcześniejszej
Systemy rozproszone. Wstęp. Krzysztof Banaś Systemy rozproszone 1
Systemy rozproszone Wstęp Krzysztof Banaś Systemy rozproszone 1 Systemy rozproszone Możliwa definicja: Co najmniej dwa zasoby, z których co najmniej jeden jest komputerem, połączone siecią, komunikujące
REGULAMIN OCHRONY DANYCH OSOBOWYCH W SPÓŁDZIELNI MIESZKANIOWEJ FAMEG" w Radomsku
REGULAMIN OCHRONY DANYCH OSOBOWYCH W SPÓŁDZIELNI MIESZKANIOWEJ FAMEG" w Radomsku Zatwierdzono Uchwałą Rady Nadzorczej nr 15/2012 z dnia 25 maja 2012 r. Sekretarz Rady Nadzorczej Ewa Pawłowska Przewodniczący
Monitorowanie i zarządzanie urządzeniami sieciowymi przy pomocy narzędzi Net-SNMP
Uniwersytet Mikołaja Kopernika w Toruniu Wydział Matematyki i Informatyki Wydział Fizyki, Astronomii i Informatyki Stosowanej Szymon Klimuk Nr albumu: 187408 Praca magisterska na kierunku Informatyka Monitorowanie
dr inŝ. Michał Tomaszewski Wydział Elektrotechniki, Automatyki i Informatyki Politechnika Opolska
dr inŝ. Michał Tomaszewski Wydział Elektrotechniki, Automatyki i Informatyki Politechnika Opolska Definicje Rola administratora w firmie Zadania administratora Szkolenia Rady, wskazówki Programiści ABAP
1.1. Założenia dla architektury korporacyjnej EPL
1.1. Założenia dla architektury korporacyjnej EPL Podczas tworzenia koncepcji architektury korporacyjnej mieliśmy na celu zaproponowanie takich zmian architektonicznych, które wprowadzałyby w Urzędzie
Multi-wyszukiwarki. Mediacyjne Systemy Zapytań wprowadzenie. Architektury i technologie integracji danych Systemy Mediacyjne
Architektury i technologie integracji danych Systemy Mediacyjne Multi-wyszukiwarki Wprowadzenie do Mediacyjnych Systemów Zapytań (MQS) Architektura MQS Cechy funkcjonalne MQS Cechy implementacyjne MQS
System generacji raportów
Zalety systemu Czym jest ProReports? prostota instalacji, wieloplatformowość (AIX, Linux, Windows, Solaris), obsługa popularnych formatów (PDF, XLS, RTF, HTML,TXT,XML,CSV), obsługa wielu baz danych, raporty
Copyright 2013 COIG SA Wszelkie prawa zastrzeżone. Nieautoryzowane rozpowszechnianie całości lub fragmentu niniejszej publikacji w jakiejkolwiek
Centralny Ośrodek Informatyki Górnictwa S.A. KSOP Opis przyrostowej kopii bazy danych Copyright 2013 COIG SA Wszelkie prawa zastrzeżone. Nieautoryzowane rozpowszechnianie całości lub fragmentu niniejszej
EXSO-CORE - specyfikacja
EXSO-CORE - specyfikacja System bazowy dla aplikacji EXSO. Elementy tego systemu występują we wszystkich programach EXSO. Może on ponadto stanowić podstawę do opracowania nowych, dedykowanych systemów.
Middleware wprowadzenie października 2010
Dariusz Wawrzyniak Politechnika Poznańska Instytut Informatyki ul. Piotrowo 2 (CW, pok. 5) 60-965 Poznań Dariusz.Wawrzyniak@cs.put.poznan.pl Dariusz.Wawrzyniak@put.edu.pl www.cs.put.poznan.pl/dwawrzyniak/middleware
Liczba godzin 1,2 Organizacja zajęć Omówienie programu nauczania 2. Tematyka zajęć
rzedmiot : Systemy operacyjne Rok szkolny : 015/016 Klasa : 3 INF godz. x 30 tyg.= 60 godz. Zawód : technik informatyk; symbol 35103 rowadzący : Jacek Herbut Henryk Kuczmierczyk Numer lekcji Dział Tematyka
SiR_13 Systemy SCADA: sterowanie nadrzędne; wizualizacja procesów. MES - Manufacturing Execution System System Realizacji Produkcji
System informatyczny na produkcji: Umożliwi stopniowe, ale jednocześnie ekonomiczne i bezpieczne wdrażanie i rozwój aplikacji przemysłowych w miarę zmiany potrzeb firmy. Może adoptować się do istniejącej
Sposoby klastrowania aplikacji webowych w oparciu o rozwiązania OpenSource. Piotr Klimek. piko@piko.homelinux.net
Sposoby klastrowania aplikacji webowych w oparciu o rozwiązania OpenSource Piotr Klimek piko@piko.homelinux.net Agenda Wstęp Po co to wszystko? Warstwa WWW Warstwa SQL Warstwa zasobów dyskowych Podsumowanie
Do kogo kierujemy ofertę?
3 Bezpieczeństwo Do kogo kierujemy ofertę? Utrata danych stanowi jedno z największych zagrożeń dla płynności funkcjonowania firmy. Efektywne rozwiązanie pozwalające na szybkie, bezpieczne i zautomatyzowane
Replikacja kolejkowa (Q-replication) w IBM DB2
Replikacja kolejkowa (Q-replication) w IBM DB2 Paweł Kędziora, Maciej Krysiuk, Marek Lewandowski Politechnika Poznańska pawel.kedziora@gmail.com, maciej.krysiuk@gmail.com, lewandowski.marek@gmail.com SPIS
Middleware wprowadzenie października Dariusz Wawrzyniak (IIPP) 1
Dariusz Wawrzyniak Politechnika Poznańska Instytut Informatyki ul. Piotrowo 2 (CW, pok. 5) 60-965 Poznań Dariusz.Wawrzyniak@cs.put.poznan.pl poznan pl Dariusz.Wawrzyniak@put.edu.pl www.cs.put.poznan.pl/dwawrzyniak/middleware
Systemy informatyczne dla zarządzania nauką - Dziekanat96
Systemy informatyczne dla zarządzania nauką - Dziekanat96 Maciej Zakrzewicz Instytut Informatyki Politechniki Poznańskiej mzakrz@cs.put.poznan.pl Streszczenie System Dziekanat96 jest rozproszonym środowiskiem
Relacyjne, a obiektowe bazy danych. Bazy rozproszone
2 Relacyjne, a obiektowe bazy danych. Bazy rozproszone Zastosowania baz danych systemy bankowe (bankomat) systemy masowej obsługi (hipermarket) rezerwacja biletów lotniczych telefonia komórkowa (sms) Dziekanat
CuBe EMAT Ewidencja Materiałowa Wersja
Program Ewidencji Materiałowej Uniwersalny program do prowadzenia ewidencji magazynowej, który dzięki prostej obsłudze może być szybko wdrożony dla różnych zastosowań. Charakterystyka programu Program
Service Level Agreement Pisemna gwarancja jakości
Service Level Agreement Pisemna gwarancja jakości Service Level Agreement (w skrócie SLA) to gwarancja poziomu jakości usług hostingowych, czyli pisemne zobowiązanie usługodawcy określające m.in.: czas
Załącznik Zakres Prac dotyczący świadczenia Usług Wsparcie Mikrokodu
Załącznik Zakres Prac dotyczący świadczenia Usług Wsparcie Mikrokodu Niniejszy Zakres Prac (zwany dalej Zakresem Prac ) obowiązuje w relacjach między Klientem i IBM jako osobą prawną określoną poniżej
Inżynieria Programowania - Projektowanie architektoniczne
Inżynieria Programowania - Projektowanie architektoniczne Katedra Informatyki, Politechnika Świętokrzyska w Kielcach Kielce, 22 października 2016 1 2 3 4 5 Architektury charakterystyczne dla różnych dziedzin
RIS. Razem budujemy jakość w radiologii
RIS Razem budujemy jakość w radiologii O systemie RIS Zastosowana architektura nie wymaga posiadania własnej infrastruktury sprzętowej, umożliwiając instalację systemu bezpośrednio na serwerach dedykowanych
Szczegółowy opis przedmiotu umowy. 1. Środowisko SharePoint UWMD (wewnętrzne) składa się z następujących grup serwerów:
Rozdział I Szczegółowy opis przedmiotu umowy Załącznik nr 1 do Umowy Architektura środowisk SharePoint UMWD 1. Środowisko SharePoint UWMD (wewnętrzne) składa się z następujących grup serwerów: a) Środowisko
ZMIANY TREŚCI SPECYFIKACJI ISTOTNYCH WARUNKÓW ZAMÓWIENIA
ZP/271/5/D/2/2015 Wilkowice, 9 lipiec 2015r. ZMIANY TREŚCI SPECYFIKACJI ISTOTNYCH WARUNKÓW ZAMÓWIENIA dot. postępowania o udzielenie zamówienia publicznego na zadanie Poprawa jakości usług medycznych i
Zmiana treści Specyfikacji Istotnych Warunków Zamówienia.
Projekt współfinansowany przez Unię Europejską z Europejskiego Funduszu Rozwoju Regionalnego w ramach Regionalnego Programu Operacyjnego Województwa Śląskiego na lata 2007-2013 Czerwionka-Leszczyny 6.11.2012
STROJENIE BAZ DANYCH: INDEKSY. Cezary Ołtuszyk coltuszyk.wordpress.com
STROJENIE BAZ DANYCH: INDEKSY Cezary Ołtuszyk coltuszyk.wordpress.com Plan spotkania I. Wprowadzenie do strojenia baz danych II. III. IV. Mierzenie wydajności Jak SQL Server przechowuje i czyta dane? Budowa
Program szkolenia KURS SPD i PD Administrator szkolnej pracowni internetowej Kurs MD1 Kurs MD2 Kurs MD3 (dla szkół ponadgimnazjalnych)
Miejsce prowadzenia szkolenia Program szkolenia KURS SPD i PD Administrator pracowni internetowej Kurs MD1 Kurs MD2 Kurs MD3 (dla szkół ponadgimnazjalnych) Pracownie komputerowe znajdujące się w wyznaczonych
Dane wejściowe. Oracle Designer Generowanie bazy danych. Wynik. Przebieg procesu
Dane wejściowe Oracle Designer Generowanie bazy danych Diagramy związków encji, a w szczególności: definicje encji wraz z atrybutami definicje związków między encjami definicje dziedzin atrybutów encji
KONFERENCJA technologie sieciowe
PROJEKTOWANIE INFRASTRUKTURY IT WSPIERĄJĄCEJ APLIKACJE KONFERENCJA technologie sieciowe Damian Sieradzki LANSTER 2014 Model TCP/IP Model ISO/OSI Warstwa aplikacji Warstwa Aplikacji Warstwa prezentacji
SZCZEGÓŁOWY OPIS PRZEDMIOTU ZAMÓWIENIA
Projekt współfinansowany przez Unię Europejską ze środków Europejskiego Funduszu Rozwoju Regionalnego w ramach Regionalnego Programu Operacyjnego Województwa Opolskiego na lata 2007-2013 inwestujemy w