PostgreSQL - Adminisztráció
A RoolWikiBÓL
2007. december 17., 16:50 változat (szerkesztés) Rozsahegyil (Vita | szerkesztései) (→Tranzakciófigyelés Unix szerű rendszereken) ← Előző változtatások |
2007. december 18., 10:12 változat (szerkesztés) (undo) 78.131.87.209 (Vita) (→Teszt adatbázis készítése (ugyanarra a szerverre)) Következő változtatások → |
||
30. sor: | 30. sor: | ||
Célszerű rendszeresen futtatni olyan időpontban, amikor a lehető legkevesebben haználják az adatbázist. | Célszerű rendszeresen futtatni olyan időpontban, amikor a lehető legkevesebben haználják az adatbázist. | ||
- | == Teszt adatbázis készítése (ugyanarra a szerverre) == | + | == Teszt adatbázis készítése (ugyanarra a szerverre ahol az éles adatbázis van) == |
Mentést készítünk az app, és a rool adatbázisról. | Mentést készítünk az app, és a rool adatbázisról. | ||
* Létrehozzuk az app_teszt és a rool_teszt adatbázist: | * Létrehozzuk az app_teszt és a rool_teszt adatbázist: |
2007. december 18., 10:12 változat
A PostgreSQL szerver adminisztrációjáról a hivatalos dokumentáció itt érhető el
Ez a dokumentáció az alapvető adatbázis szerver karbantartási funkciókról tartalmaz egy rövid ismertetőt.
Tartalomjegyzék |
Mentés
Az adatbázisok mentését a pg_dump programmal tudjuk elvégezni. Javasolt a rendszeres, gyakori teljes adatbázis mentés.
pg_dump -Upostgres app -f app.dump
- A -U paraméterrel a felhasználó nevét adtuk meg, akinek a nevében a mentést készítjük.
- app a mentendő adatbázis neve.
- A -f paraméter után a fájl nevét adjuk meg, melybe a dump kerül.
Az így elkészített app.dump állományt betöltve egy üres(!) adatbázisba, a mentés indításának pillanatában lévő adatbázist kapjuk vissza.
Távolról is készíthetünk mentést:
pg_dump -Upostgres -h192.168.10.20 app > app.dump
- a -h után kerül a szerver IP címe (a h után írhatunk szóközt, ahogy a többi paraméter is megadható egybe és különírva is)
Minden PostgreSQL parancs futtatható távolról ilyen módon. Ekkor figyelni kell arra, hogy a pg_dump verziója egyezzen meg a szerver verziójával, illetve annak a szervernek a verziójával, mellyel később a dump-ot használni akarjuk! (Ez utóbbi a fontosabb.) A többi paraméterről a pg_dump --help vagy a man pg_dump paranccsal kaphatunk információt.
Karbantartás
Az adatbázis szerver minnél gyorsabb működéséhez szükséges a következő parancs rendszeres futtatása az applikációs adatbázison (app):
app =# analyze;
Célszerű rendszeresen futtatni olyan időpontban, amikor a lehető legkevesebben haználják az adatbázist.
Teszt adatbázis készítése (ugyanarra a szerverre ahol az éles adatbázis van)
Mentést készítünk az app, és a rool adatbázisról.
- Létrehozzuk az app_teszt és a rool_teszt adatbázist:
createdb -Upostgres app_teszt createdb -Upostgres rool_teszt
- Betöltjük a dumpokat a teszt adatbázisokba:
psql -Upostgres app_teszt -f app.dump psql -Upostgres rool_teszt -f rool.dump
- Az app_tesztben kiadunk egy update parancsot:
psql -Upostgres app_teszt app_teszt=# update rjo_rendszer_parameter set ertek='rool_teszt' where kod='REPOS_DATABASE_NAME'; update 1 app_teszt=#
- Gyorsítjuk a lekérdezéseket (mindkét adatbázisban!):
psql -Upostgres app_teszt app_teszt=# analyze; ANALYZE app_teszt=# \c rool_teszt You are now connected to database "rool_teszt". rool_teszt=# analyze; ANALYZE
Kész. Most az app_teszt -be bejelentkezhet minden felhasználó aki az app-ba be tudott jelenkezni. A parancsikonról másolatot készítve, és a host= paramétert módosítva (host=app_teszt) elérhetővé tehetjük a teszt adatbázist. Ezen a módon a felhasználókat nem hozzuk létre. Ezért működik ez az eljárás csupán ugyanazon az adatbázis szerveren.
Tranzakciófigyelés Unix szerű rendszereken
Az adatbázis kéréseket kiszolgáló folyamatokat a postgres felhasználó futtatja. Milyen folyamatokat futtat a postgres felhasználó?
ps -upostgres
Részletesebb infó:
ps -upostgres uxww
Másképp
ps auxww | grep postgres
Ha csak az app adatbázis felé irányuló folyamatokra vagyunk kíváncsiak, fűzzük a következőket az előző parancs végére.
| grep „: .* app”
Ha egy adott felhasználó (pl. pooly) adatbázis kapcsolatai érdekelnek, akkor hozzáfűzendő (még):
| grep „: pooly”
Ha a tranzakcióban lévő kapcsolatok érdekelnek, akkor hozzáfűzendő (még):
| grep „transaction$”
Ha a zárolás (lock) miatt várakozók érdekelnek, akkor hozzáfűzendő (még):
| grep „waiting”
Egy folyamatot a megszüntethetünk a szerveren a kill parancsot használva, melyet postgres felhasználó nevében adjunk ki. paramétere a ps kimenetének 2. oszlopában szereplő folyamatazonosító (pid). Ne használjuk a kill -9 paraméterét! Példa a kill parancs használatára:
prompt$ kill 1234
Felhasználó jelszavának módosítása
A ROOL Bázis program nem nyújt felületet az adminisztrátoroknak a felhasználók jelszavának módosítására. Amennyiben sikeresen bejelentkezett a felhasználó, a saját jelszavát módosíthatja a 'felhasználó' beállításai ablakból nyíló, - erre szolgáló - dialógus ablakban. Ha valaki elfelejtené a jelszavát, az az SQL ablakban módosítható a következő parancs futtatásával:
alter user felhasználó_azonosító password 'új_jelszó';
(Mindegy melyik adatbázist választjuk.)