PostgreSQL安装详细步骤(linux)
官方安装文档:http://www.postgresql.org/download/linux/redhat/
1. 检查PostgreSQL 是否已经安装
Linux-软件包管理-rpm命令管理-查询
rpm -qa | grep postgres 检查PostgreSQL 是否已经安装
rpm -qal | grep postgres 检查PostgreSQL 安装位置
若已经安装,则使用rpm -e 命令卸载。
rpm -e postgresql94-contrib-9.4.4-1PGDG.rhel6.x86_64 postgresql94-server-9.4.4-1PGDG.rhel6.x86_64 卸载
rpm -e postgresql94-libs-9.4.4-1PGDG.rhel6.x86_64 postgresql94-9.4.4-1PGDG.rhel6.x86_64 卸载
可以使用rpm -qa | grep postgres再次查看是否还有Postgres安装文件,没有卸载完成。
2.使用yum库设置安装postgresql94版本,最好先创建用户组和用户:
(1)新增postgres用户组:
groupadd postgres
(2)新增postgres用户并且设置这个用户属于上面创建的postgres用户组:
useradd -g postgres postgres
(3)修改postgres用户密码:passwd postgres(这里设置密码为postgres)
passwd postgres --修改postgres用户密码
yum install http://yum.postgresql.org/9.4/redhat/rhel-6-x86_64/pgdg-redhat94-9.4-1.noarch.rpm 使用yum库
3.安装postgresql94
yum search postgresql //也可以先找一下,server版会有多个,决定选择装哪个
yum -y install postgresql94-server postgresql94-contrib //安装postgresql94
注意:如果出现错误,首先停止服务查看服务名称chkconfig --list找到postgresql的服务名,注意服务名可能会带有版本号,service 服务名 stop,然后使用rpm -e卸载命令,然后在执行上面的安装就可以了
安装成功
可以使用rpm -qal|grep postgres这个命令查看安装文件的位置,注意默认的postgresql配置文件的位置和名称(带有版本号)
查看/etc/rc.d/init.d/postgresql-9.4文件中的PGDATA信息,并显示行号。
cat /etc/rc.d/init.d/postgresql-9.4 | grep -n PGDATA -n显示行号
上图说明默认数据库文件的安装位置是在:/var/lib/pgsql/9.4/data,如果需要改变数据库文件的存放位置可以修改这里,下面会介绍如何修改默认数据库文件的存放位置。先看看这个目录里面有没有数据库的文件:
ls -la /var/lib/pgsql/9.4/data 查看这个目录里面的内容
上图说明postgresql安装完成之后,默认数据库文件存放所使用的目录是空的。
下面的内容比较重要,介绍postgresql数据库如何安装:
一、如何更改默认数据库安装位置,安装postgresql数据库:
1、删除postgres用户和他的文件信息(如果之前安装过)
userdel -r postgres
2、删除postgres用户组(如果之前安装过)
groupdel postgres
(1)新增postgres用户组:
groupadd postgres
(2)新增postgres用户并且设置这个用户属于上面创建的postgres用户组:
useradd -g postgres postgres
(3)修改postgres用户密码:passwd postgres(这里设置密码为postgres)
passwd postgres --修改postgres用户密码
创建数据库文件存放的目录:/mnt/pgsql/data
mkdir -p /mnt/pgsql/data 递归方式创建pgsql/data目录
默认刚建立的目录/mnt/pgsql和/mnt/pgsql/data的所有者和所有组都是root,需要修改为postgres用户和用户组。
chown -R postgres:postgres /mnt/pgsql
ll /mnt
chown -R postgres:postgres /mnt/pgsql/data
ll /mnt/pgsql
查看是否已经更改为postgres用户和用户组了。
接下来就是要修改默认数据库文件存放路径了:
修改postgresql数据库的配置文件(/etc/rc.d/init.d/postgresql-9.4)中的PGDATA和PGLOG改成我们自己创建的目录:/mnt/pgsql:
PGDATA=/mnt/pgsql/data
PGLOG=/mnt/pgsql/pgstartup.log
保存之后,继续查询initdb文件的存放位置:
find / -name initdb 查找initdb 的安装位置
指定数据库存放位置和编码方式,初始化数据库:
/usr/pgsql-9.4/bin/initdb -E UNICODE -D /mnt/pgsql/data
注意: 出现上面的错误说明Postgresql不能以root身份初始化,要以postgres用户的身份运行,所以上面要创建linux用户postgres和组postgres。
切换postgres用户执行初始化数据库操作
su - postgres 切换用户
/usr/pgsql-9.4/bin/initdb -E UNICODE -D /mnt/pgsql/data --初始化数据库
cd /mnt/pgsql/data 切换目录
ll 查询初始化数据库成功之后的目录内容
编辑postgresql.conf文件,修改数据库默认接收的监听地址与端口参数:
cat postgresql.conf | grep -n listen_addresses 查找listen_addresses在postgresql.conf文件中的位置并显示行号
vi postgresql.conf 编辑postgresql.conf文件
查询listen_addresses的值:
修改前listen_addresses的值:
去掉59行的注释,将listen_addresses = 'localhost' 改成 listen_addresses = '*',下图是修改后listen_addresses的值:
接下来继续修改pg_hba.conf文件,告诉数据库服务器它将允许什么样的客户端连接到自己:
vi pg_hba.conf --修改postgresql服务连接文件
修改前的源文件:
在86行下面增加一行,表示允许任何一个客户端使用正确的用户名和密码访问自己:
host all all 0.0.0.0/ trust
# TYPE DATABASE USER ADDRESS METHOD # "local" is for Unix domain socket connections only
local all all trust或peer
# IPv4 local connections:
host all all 127.0.0.1/ trust
host all all 0.0.0.0/ password
# IPv6 local connections:
host all all ::/ password
# Allow replication connections from localhost, by a user with the
# replication privilege.
#local replication postgres peer
#host replication postgres 127.0.0.1/ ident
#host replication postgres ::/ ident
备注:设置 trust,本地可以使用psql -U postgres直接登录服务器;设置 peer,本地可以使用psql -h 127.0.0.1 -d postgres -U postgres直接登录服务器;
exit --返回root用户
chkconfig --list 查看所有服务并找到postgre的服务名称
默认postgresql-9.4不是自启动的,我们需要设置postgresql-9.4服务为自启动服务:
chkconfig postgresql-9.4 on 设置服务自启动
chkconfig --list
service postgresql-9.4 status 查看服务状态
service postgresql-9.4 start 启动postgresql-.4服务
有三种方式可以查看postgresql运行是否运行
ps -ef | grep postgres 查postgres的进程信息
netstat -tpnl | grep 5432 查postgres的端口号5432是否已经打开
service postgresql-9.4 status 查看服务状态
开始连接postgresql数据库:
psql -U postgres //连接pgsql server
psql -h 127.0.0.1 -d postgres -U postgres //连接pgsql server
看到上图表示连接数据库成功了。
修改配置文件pg_hba.conf
之后,登录数据库重新刷新更新后的配置命令:
select pg_reload_conf();
show data_directory;
为数据库默认的登陆名postgres(等同于SQLServer里面的sa)设置登陆数据库的密码:
ALTER USER postgres WITH PASSWORD ''; //添加密码
select * from pg_shadow;
\q回车 退出登录
设置防火墙
iptables -I INPUT -p tcp --dport -j ACCEPT
iptables -I INPUT -p tcp --dport -j ACCEPT
service iptables save
service iptables restart
cat /etc/sysconfig/iptables
二、采用默认的方式安装postgresql数据库文件:
直接执行下面的命令,都不需要创建linux用户:
service postgresql-9.4 initdb
如果启动过程中报错了,例如:Data directory is not empty![失败],估计是卸载出了问题,删除/var/lib/pgsql目录下面所有文件,使用rpm -e 命令卸载重新安装.
cd /var/lib/pgsql/data
cd /var/lib/pgsql
cd /var/lib
rm -rf /var/lib/pgsql
ll /var/lib
rpm -e postgresql94-contrib-9.4.-1PGDG.rhel6.x86_64 postgresql94-server-9.4.-1PGDG.rhel6.x86_64 postgresql94-9.4.-1PGDG.rhel6.x86_64 postgresql94-libs-9.4.-1PGDG.rhel6.x86_64 卸载
yum -y install postgresql94-server postgresql94-contrib 安装
service postgresql-9.4 initdb 初始化数据库
设置开机启动postgresql
chkconfig postgresql-9.4 on
查看postgresql运行是否运行
ps -ef | grep postgres 查postgres的进程信息
netstat -tpnl |grep 查postgres的端口号5432是否已经打开
service postgresql-9.4 status 查看服务状态
用postgres用户登录,并改密码
su postgres //切换用户
如果出现下面的错误,需要重新运行postgresql的服务,若想psql能直接登陆,再重启一下DB,socket文件会随着服务器的启动而生成。
ps -ef | grep postgre 查postgre进程
kill -
service postgresql-9.4 status
service postgresql-9.4 stop
service postgresql-9.4 start
su postgres //切换用户
psql -U postgres //连接pgsql server
ALTER USER postgres WITH PASSWORD ''; //添加密码
select * from pg_shadow;
\q 退出
如果出现下面这个错误
需要继续创建文件
touch /home/postgres/.psql_history 创建这个文件
chmod -R g+w /home/postgres 提升postgres这个目录的权限
chmod a+w /home/postgres/.psql_history 提升.psql_history这个文件的权限
修改/var/lib/pgsql/9.4/data/postgresql.conf(这个文件是默认的安装位置)
vi /var/lib/pgsql/9.4/data/postgresql.conf 修改postgresql的配置文件
去掉59行的注释,将listen_addresses = 'localhost' 改成 listen_addresses = '*'
修改/var/lib/pgsql/9.4/data/pg_hba.conf(这个文件是默认的安装位置)
vi /var/lib/pgsql/9.4/data/pg_hba.conf 修改postgresql服务连接文件
第80行:peer改称md5,本地就可以连接自己了。
在82行下面增加一行
host all all 192.168.6.0/ md5 允许192.168.0.0网段连接
host all all 0.0.0.0/0 md5 允许所有IP连接
关闭防火墙
service iptables stop
重启postgresql的服务
service postgresql-9.4 restart
三、使用客户端工具就可以连接成功了!
Navicat for PostgreSQL
pgAdmin III
转自:http://www.postgresql.org/download/linux/redhat/
http://www.cnblogs.com/mchina/archive/2012/06/06/2539003.html
http://blog.51yip.com/pgsql/1520.html
PostgreSQL安装详细步骤(linux)的更多相关文章
- PostgreSQL安装详细步骤(windows)
原文地址:http://blog.chinaunix.net/uid-354915-id-3498734.html PostgreSQL安装:一.windows下安装过程安装介质:postgresql ...
- PostgreSQL安装详细步骤windows
PostgreSQL安装:一.windows下安装过程安装介质:postgresql-9.1.3-1-windows.exe(46M),安装过程非常简单,过程如下:1.开始安装: 2.选择程序安装目录 ...
- PostgreSQL安装详细步骤(windows)[转]
PostgreSQL安装: 一.windows下安装过程 安装介质:postgresql-9.1.3-1-windows.exe(46M),安装过程非常简单,过程如下: 1.开始安装: 2.选择程序安 ...
- 2.PostgreSQL安装详细步骤(windows)【转】
感谢 Junn9527 PostgreSQL安装:一.windows下安装过程安装介质:postgresql-9.1.3-1-windows.exe(46M),安装过程非常简单,过程如下:1.开始安装 ...
- PostgreSQL在win7上安装详细步骤
原文:PostgreSQL在win7上安装详细步骤 PostgreSQL安装: 一.windows下安装过程 安装介质:postgresql-9.1.3-1-windows.exe(46M),安装过程 ...
- linux/centos下安装nginx(rpm安装和源码安装)详细步骤
Centos下安装nginx rpm包 ...
- linux下mysql-5.5.15安装详细步骤
linux下mysql-5.5.15安装详细步骤 注:该文档中用到的目录路径以及一些实际的值都是作为例子来用,具体的目录路径以各自安装时的环境为准 mysql运行时需要一个启动目录.一个安装目录和一个 ...
- MySql Server 5.7的下载及安装详细步骤
1.下载安装包 1)找到官网下载地址(https://dev.mysql.com),选择downloads,找到windows
- elasticsearch kibana + 分词器安装详细步骤
elasticsearch kibana + 分词器安装详细步骤 一.准备环境 系统:Centos7 JDK安装包:jdk-8u191-linux-x64.tar.gz ES安装包:elasticse ...
随机推荐
- 【BZOJ】【3239】Discrete Logging
BSGS BSGS裸题,嗯题目中也有提示:求a^m (mod p)的逆元可用快速幂,即 pow(a,P-m-1,P) * (a^m) = 1 (mod p) /******************** ...
- 用java解析在OpenStreetMap上下载的地图数据(SAX版,适合比较大的xml文件)
java程序如下: package gao.map.preprocess; import java.io.BufferedWriter; import java.io.File; import jav ...
- iOS开发-UITableView常用方法
UITableView常用来展示数据,类似于Android中的ListView,相对于Android中的ListView而言,UITableView的实现是非常简单,继承UITableViewData ...
- 给开发者准备的 10 款最好的 jQuery 日历插件[转]
这篇文章介绍的是 10 款最棒而且又很有用的 jQuery 日历插件,允许开发者们把这些漂亮的日历插件结合到自己的网站中.这些日历插件易用性都很强,轻轻松松的就可以把漂亮的日历插件装饰到你的网站了.希 ...
- [LeetCode] Distinct Subsequences [29]
题目 Given a string S and a string T, count the number of distinct subsequences of T in S. A subsequen ...
- 在CentOS/RHEL上设置SSH免密码登录
本文会告诉你怎样在 CentOS/RHEL 上设置 SSH 免密码登录.自动登录配置好以后,你可以通过它使用 SSH (Secure Shell)和安全复制 (SCP)来移动文件. SSH 是开源的, ...
- 防止excel数字变成科学计数法
在网上查了很多资料知道解决办法大概有两个:一是在身份证字段前加个英文单引号,二是设置Excel的格式为文本格式. 我试用过第一种确实可以显示,但是有个“'”号在那里感觉确实不是很好,虽然听说不影响,但 ...
- windows下安装redis 以及phpredis的扩展 (windows redis php&php7)
一.工具准备 1. redis for windows 下载 https://github.com/MSOpenTech/redis 2. PHP扩展下载 http://pecl.php.net/pa ...
- 【Linux】关于Linux的部分细节与配置文件
文章对Linux的启动过程 进行了讲解,摘录一些要点,(摘自:https://www.ibm.com/developerworks/cn/linux/l-linuxboot/)如下: 当系统首次引导时 ...
- Inside GDALAllRegister之四: 跳过driver
这个函数很短小: /** * \brief This method unload undesirable drivers. * * All drivers specified in the space ...