Po podniesieniu wersji bazy z wersji wczesniejszej niż 10.2.0.1 do wersji 10.2.0.1
można zauważyć sporo wpisów w pliku alert.log postaci:
WARNING: inbound connection timed out (ORA-3136)
Jak podaje dokumentacja przyczyn może być wiele, chociaż jedna wydaje się najbardziej prawdopodobna. W ustawieniach listenera oraz protokoł SQL*Net istnieją dwa parametry:
SQLNET.INBOUND_CONNECT_TIME ( w pliku sqlnet.ora )
INBOUND_CONNECT_TIMEOUT_LISTENER ( w pliku listener.ora )
Co one oznaczają:
SQLNET.INBOUND_CONNECT_TIME - czas w sekundach, w których użytkownik musi poprawnie się zidentyfikować w bazie danych. Należy zwrócić uwagę, że nie polega to tylko i wyłącznie na odczytaniu zaszyfrowanego hasła z perspektyw systemowych, deszyfrowaniu go i porównaniu z prowadzonym. W bazie danych wykonywnych jest szereg zapytań i zmian w sesji użytkownika. Wartosć zero 0, że czas ten jest nieskończony.
INBOUND_CONNECT_TIMEOUT_LISTENER - czas w sekundach, w których użytkownik musie się zidentyfikować i wykonać poprawne połączenie do bazy danych. Podobnie, wartosć 0 oznacza, że czas ten jest nieskończony.
W wersjach wczesniejszych oba parametry są domyslnie ustawione na 0.
W wersji 10.2 i pozniejszych domyslne wartosći tych parametrów wynoszą 60.
Jeżeli ta wartosć nie jest wystarczająca to należy ją zwiększyć,np.:
SQLNET.INBOUND_CONNECT_TIMEOUT = 200 (w sqlnet.ora)
INBOUND_CONNECT_TIMEOUT_LISTENER = 200 (w listener.ora)
Inne możliwe przyczyny:
- przeciążenie serwera ( za mała wartosć SHARED POOL ? )
- problemy z siecią ( tutaj jest konieczna konsultacja z administratorami sieciowymi)
Można też spróbować włączyć sledzenie protokołu SQL*NET ( trace ). Należy zrobić to w sqlnet.ora. Przykład włączenia trace'a:
TRACE_LEVEL_CLIENT=admin
TRACE_LEVEL_SERVER=admin
TRACE_UNIQUE_CLIENT=on
TRACE_DIRECTORY_SERVER=$ORACLE_HOME/trace
TRACE_DIRECTORY_SERVER=$ORACLE_HOME/trace
TRACE_TIMESTAMP_CLIENT=on
TRACE_TIMESTAMP_SERVER=on
Jedna uwaga: Pliki sledzenia szybko przyjmują duże rozmiary ( rzędu MB ). Dlatego zaleca się zebranie ich pewnej liczby a następnie wyłączenia sledzenia.
Przydatna dokumentacja ( numery dokumentów w Oracle Metalink):
345197.1
465043.1
730066.1
sobota, 25 lipca 2009
piątek, 24 lipca 2009
O grafach w Oracle Spatial słów kilka
Zazwyczaj grafy i związane z nimi implementacja struktur danych i algorytmów kojarzy się nam zazwyczaj z warstwą aplikacyjną systemu. Systemowy bazodanowe obecnie umożliwiają przechowywanie tych struktur w postaci relacyjnej. Związane jest z rozwojem systemów GIS ( Geography Information Systems ) , czyli polskie SIP. Chciałbym omówić jak jest to robione w Oracle 10g database.
Obiekty do analizy (Java)
NODES
LINKS
PATHS
PLINKS
SDO_NET
Cała architektura może być podzielona na dwa zasadnicze segmenty. Pierwszy segment to część bazodanowa. Cała informacja przechowywana jest w tabelach. Na rysunku przedstawiono cztery tabele opisujące sieć. Zasadniczo wymagane są dwie : Nodes oraz Links. Pozostałe tabele umożliwiają przechowywanie analiz przeprowadzanych na sieci – w najprostszym przypadku wyliczone ścieżki.
Drugi segment to część analityczna. Sieć zostaje załadowana do aplikacji -> obszar Network. Jeżeli chcemy przeprowadzić jakieś operacje na sieci dotyczące , np. wyszukiwania najbliższych sąsiadów danego wierzchołka musimy wywołać statyczne funkcje klasy NetworkManager. W przypadku modyfikowania struktury sieci (dodawanie, usuwanie i modyfikacja jej elementów) posługujemy się funkcjami klasy NetworkFactory.
Do przeprowadzania analiz w sieci można użyć dwóch interfejsów programistycznych: Javy lub PL/SLQ’a. Z racji tego, że większość analiz jest przeprowadzanych w warstwie aplikacyjnej, właściwsze będzie omówienie możliwości interfejsu programistycznego z poziom Javy.
Interfejs programistyczny został podzielony ze względu na funkcjonalność na dwie części:
- obliczenia i analizy na istniejącej sieci -> klasa NetworkManager
Znajdowanie najkrótszej ścieżki między dwoma obiektami(wierzchołkami) w sieci ( wersje używają algorytmu Dijkstry lub algorytmu A* ).
Znajdowanie najbliższych sąsiadów dla danego wierzchołka. Działa podobnie jak operator przestrzenny SDO_NN, z tą różnicą że drogę możemy pokonywać tylko po krawędziach sieci. Znajdowanie wierzchołków znajdujących się w określonej odległości od wierzchołka startowego
Rozwiązanie problemu komiwojażera, czyli znalezienie optymalnej ścieżki przy zadanej liście wierzchołków, które należy odwiedzić Obliczanie Minimalnego Drzewa Rozpinającego ( ang. Minimum Cost Spaning Tree) dla sieci
Obiekty do analizy (Java)
NODES
LINKS
PATHS
PLINKS
SDO_NET
Cała architektura może być podzielona na dwa zasadnicze segmenty. Pierwszy segment to część bazodanowa. Cała informacja przechowywana jest w tabelach. Na rysunku przedstawiono cztery tabele opisujące sieć. Zasadniczo wymagane są dwie : Nodes oraz Links. Pozostałe tabele umożliwiają przechowywanie analiz przeprowadzanych na sieci – w najprostszym przypadku wyliczone ścieżki.
Drugi segment to część analityczna. Sieć zostaje załadowana do aplikacji -> obszar Network. Jeżeli chcemy przeprowadzić jakieś operacje na sieci dotyczące , np. wyszukiwania najbliższych sąsiadów danego wierzchołka musimy wywołać statyczne funkcje klasy NetworkManager. W przypadku modyfikowania struktury sieci (dodawanie, usuwanie i modyfikacja jej elementów) posługujemy się funkcjami klasy NetworkFactory.
Do przeprowadzania analiz w sieci można użyć dwóch interfejsów programistycznych: Javy lub PL/SLQ’a. Z racji tego, że większość analiz jest przeprowadzanych w warstwie aplikacyjnej, właściwsze będzie omówienie możliwości interfejsu programistycznego z poziom Javy.
Interfejs programistyczny został podzielony ze względu na funkcjonalność na dwie części:
- obliczenia i analizy na istniejącej sieci -> klasa NetworkManager
Znajdowanie najkrótszej ścieżki między dwoma obiektami(wierzchołkami) w sieci ( wersje używają algorytmu Dijkstry lub algorytmu A* ).
Znajdowanie najbliższych sąsiadów dla danego wierzchołka. Działa podobnie jak operator przestrzenny SDO_NN, z tą różnicą że drogę możemy pokonywać tylko po krawędziach sieci. Znajdowanie wierzchołków znajdujących się w określonej odległości od wierzchołka startowego
Rozwiązanie problemu komiwojażera, czyli znalezienie optymalnej ścieżki przy zadanej liście wierzchołków, które należy odwiedzić Obliczanie Minimalnego Drzewa Rozpinającego ( ang. Minimum Cost Spaning Tree) dla sieci
Subskrybuj:
Posty (Atom)