Project

General

Profile

Support #553

Updated by Daniel Curtis over 9 years ago

This is a simple guide for setting up a standalone PostgreSQL database server on Debian. 

 * Use sudo to get a root shell 
 <pre> 
 sudo -s 
 </pre> 

 * Update the system: 
 <pre> 
 apt-get update && sudo apt-get upgrade 
 </pre> 

 h1. Install PostgreSQL 

 * Install PostgreSQL 
 <pre> 
 apt-get install postgresql postgresql-client 
 </pre> 

 h2. Configure PostgreSQL 

 * Edit pg_hba.conf to enable Create a database access via the local socket: 
 <pre> 
 nano /etc/postgresql/9.4/main/pg_hba.conf 
 </pre> 
 #* Replace peer with *trust* 
 <pre> 
 local     all           all                                 trust    
 </pre>  

 * Edit the main postgresql config: 
 <pre> 
 nano /etc/postgresql/9.4/main/postgresql.conf 
 </pre> 
 #* And change the @listen_addresses@ parameter: 
 <pre> 
 listen_addresses = '*' 
 </pre> and user 

 * Then append Create a rule regular system user account using adduser (skip this step to enable network access from a given subnet: use an existing account): 
 <pre> 
 echo "host      all       all       192.168.0.0/24    trust" >> /etc/postgresql/9.4/main/pg_hba.conf adduser somepguser 
 </pre> 

 * And restart postgresql: 
 <pre> 
 service postgresql restart 
 </pre> 

 h2. Create a database and user 

 * Connect to the default database: 
 <pre> 
 su - postgres 
 psql 
 </pre> 
 #* Set a password for the postgres user: 
 <pre> 
 \password postgres 
 </pre> 
 #* Create a new user, the The postgres admin console will show @postgres=#@: @postgres=#@, create a new user: 
 <pre> 
 CREATE USER somepguser WITH PASSWORD 'somepguserpass'; 
 </pre> 
 #* And a create a database: 
 <pre> 
 CREATE DATABASE somepgdatabase OWNER somepguser; 
 </pre> 
 #* Quit from the database 
 <pre> 
 \q 
 </pre> 

 * Exit from the postgres user 
 <pre> 
 exit 
 </pre> 

 * Connect as somepguser to the new database: 
 <pre> 
 su - somepguser 
 psql -d somepgdatabase -U somepguser 
 </pre> 

 h3. Enable Network Service 

 * Edit the main postgresql config: 
 <pre> 
 nano /etc/postgresql/9.4/main/postgresql.conf 
 </pre> 
 #* If connecting And change the @listen_addresses@ parameter: 
 <pre> 
 listen_addresses = '*' 
 </pre> 

 * Then append a rule to allow access from a remote host, connect using the following: given subnet: 
 <pre> 
 psql -h pg.example.com -d somepgdatabase -U somepguser echo "host      all       all       192.168.0.0/24    trust" >> /etc/postgresql/9.4/main/pg_hba.conf 
 </pre> 

 * And restart postgresql: 
 <pre> 
 service postgresql restart 
 </pre> 

 h2. Resources 

 * https://wiki.debian.org/PostgreSql

Back