Progetto

Generale

Profilo

PostgresInitConf » Cronologia » Versione 10

Versione 9 (Amministratore Truelite, 18-03-2008 15:13) → Versione 10/13 (Simone Piccardi, 21-12-2010 13:13)

[[TracNav(TOC)]] 

 h1. Configurazione di base di PostgresSQL 

 [[PostgresSQL]] 


 Si sono riassunte qui le istruzioni per effettuare alcune configurazioni di 
 base sul database _PostgresSQL_. [[PostgresSQL]]. Si tenga presente che installando il pacchetto @postgres@ su _Debian Etch_ verrà installata la versione 7.4, se si vuole 
 <pre> 
 utilizzare la versione più recente si dovrà installare esplicitamente il pacchetto @postgres-8.1@. 

 
 <pre> 

 Si tenga presente che è sempre possibile installare due versioni diverse del 
 database in contemporanea, ed il sistema di configurazione di Debian si 
 prenderà carico di farli funzionare insieme, assegnandogli porte diverse: il 
 primo ad essere installato userà la porta standard 5432, il secondo la 
 successiva 5433, ecc. 

   

 Ovviamente se si rimuove la prima versione installata la seconda resterà in 
 ascolto sulla porta non standard, (se ne tenga conto qualora ci siano altri 
 programmi che usano il database installati dai pacchetti _Debian_, Debian, dato che 
 questi si collegano di default sulla porta 5432). 
 
 L'installazione di default del pacchetto di Debian consente l'accesso soltanto da @localhost@ e soltanto tramite l'utente locale @postgres@. Qualora 
 <pre> 
 serva poter accedere al database via rete occorre modificare la configurazione 
 del server. Questa si trova, a seconda dell versione installata, nella directory @/etc/postgres/7.4/main/@ o @/etc/postgres/8.1/main/@. 

 
 <pre> 

 Per abilitare l'accesso via rete occorre anzitutto porre in ascolto il server 
 su un indirizzo IP raggiungibile, rispetto al default che è porsi in ascolto solo sul @localhost@, per farlo occorre modificare il file @postgressql.conf@ inserendo una riga del tipo:  

 
 <pre> 
 
 <pre> 

 <pre> 
 listen_addresses='*' 
 </pre> 

 

 che abilita l'ascolto su tutti gli indirizzi locali, alternativamente si può 
 indicare un indirizzo specifico, nello stesso file si può anche indicare una porta diversa da quella di 
 <pre> 

 <pre> 
 default con la direttiva @port@. 

 Il passo successivo è modificare le regole di accesso su @pg_hba.conf@, il default infatti è accettare le connessioni solo per un utente locale del sistema o per accessi da @localhost@, per abilitarle da una sottorete 
 <pre> 
 generica si dovrà introdurre una riga del tipo:  

 

 <pre> 
 
 host      all           all           192.168.1.0/24                 md5 
 </pre> 

 

 che consente l'accesso agli utenti presenti sul database, identificati tramite 
 un hash MD5 (il default usato dalla gestione utenti del database). Effettuati 
 i cambiamenti si dovrà riavviare il servizio per renderli effettivi. 

 Per i compiti amministrativi l'installazione di default utilizza l'utente locale @postgres@ che consente l'accesso diretto al database con pieni 
 <pre> 
 diritti amministrativi, per questo il primo passo da fare è sempre quello di collegarsi con tale utente (in genere lo si fa con un @su postgres@ dato da @root@). 

 La linea di comando per l'accesso al database è fornita dal comando @psql@ 
 <pre> 
 <pre> 

 <pre> 
 che prende come primo argomento (opzionale) il nome di un database e come 
 secondo argomento (sempre opzionale) il nome di un utente, se ci si vuole collegare via rete occorre usare l'opzione @-h@ per indicare l'hostname (o 
 <pre> 
 l'indirizzo IP). I comandi di base sono i seguenti:  

 |@\l@| mostra l'elenco dei database| 
 |@\c nome@| si collega al database @nome@| 
 |@\d}@| mostra l'elenco delle tabelle del database (prima ci si deve collegare allo stesso)| 
 |@\du@| mostra l'elenco degli utenti (si deve essere collegati)| 

 <pre> 
 <pre> 
 <pre> 
 <pre> 

 Per verificare la lista degli utenti definiti ci si dovrà collegare al database di sistema @postgres@, per questo si potrà usare direttamente il comando @psql postgres@, a questo punto con il comando @\du@ si avrà 
 <pre> 
 <pre> 
 la lista degli utenti. 

 Per creare un nuovo utente si può utilizzare il comando @createuser@ che <pre> 
 di default crea un utente senza privilegi (a meno di non usare l'opzione @-d@ 
 <pre> 
 per consentire la creazione di altri database o l'opzione @-a@ per consentire la creazione di altri utenti). Il comando deve essere dato da un utente con privilegi amministrativi (nel caso l'utente @postgres@), si potrà allora aggiungere l'utente @myuser@ con: 

 
 <pre> 
 
 <pre> 

 <pre> 
 su postgres 
 createuser myuser -P 
 </pre> 

 e si usa l'opzione @-P@ per far sì che venga anche chiesta una password, 

 <pre> 
 necessaria nel caso ci si voglia collegare da remoto con la configurazione 
 mostrata in precedenza.  

 Il comando esegue una richiesta interattiva dei vari parametri per cui nel 
 nostro caso avremo che qualcosa del tipo: 

 
 <pre> 
 
 postgres@davis:~$ createuser myuser -P 
 Enter password for new user:  
 Enter it again:  
 Shall the new user be allowed to create databases? (y/n) n 
 Shall the new user be allowed to create more new users? (y/n) n 
 CREATE USER 
 </pre> 

 

 Se si vuole cambiare password ad un utente è sufficiente collegarsi con un utente dotato di privilegi amministrativi al database @postgres@ ed 
 <pre> 
 eseguire il seguente comando:  

 

 <pre> 
 
 ALTER USER nomeutente WITH PASSWORD 'nuovapassword'; 
 </pre> 

 La cancellazione di un utente si fà invece con il comando @dropuser@, che 

 <pre> 
 però oltre a rimuovere l'utente richiede anche che non ci siano database che 
 gli appartengono; pertanto il comando fallirà se prima non si rimuovono anche 
 i database che l'utente possiede. 

 Per creare un database si può incece usare il comando @createdb@ che <pre> 
 prende come argomento il nome del database da creare, ovviamente il comando 
 deve essere dato da un utente con privilegi amministrativi o comunque con il 
 diritto di creare dei database. Quando si crea un database questo di default apparterrà all'utente che lo crea, a meno di non usare l'opzione @-O@ per 
 <pre> 
 assegnargli un proprietario. 

  

 Nel nostro caso avendo creato un utente che non ha privilegi di creazione 
 dovremo creare il database dall'utente di amministrazione ed assegnarlo al 
 nostro utente, per cui dovremo fare:  
 
 <pre> 
 
 createdb mydb -O myuser 
 </pre>