Ubuntu下postgresql安装及常见错误处理
依赖工具库
注意:
默认用户名是postgres
以下命令是Ubuntu操作系统中的命令
make
GCC
Zlib
- 安装命令:sudo apt-get install zlib1g-dev
- 注意有些软件包的名字无法确定,可以借助ubuntu software center来确定其有效名字,
readline
- 安装命令:sudo apt-get install libreadline6 libreadline6-dev
- 注意网上有的写安装readline-dev,这并不适用于Ubuntu系统,一定要找一下自己的操作系统安装readline的命令,不同的操作系统,命令是不一样的,要小心
安装
1.下载postgresql
下载地址:https://www.postgresql.org/ftp/source/v11.0/
2.解压文件:
在zmy目录下执行:tar -zxvf postgresql-11.0.tar
3.进入解压目录并配置参数
进入解压目录:cd postgresql-11.0
创建安装目录:sudo mkdir /opt/postgresql-11.0
配置安装参数:./configure --prefix=/opt/postgresql-11.0
注:
--prefix 指定安装目录
如果缺少readline,zlib,会报错,安装方法见依赖工具库
4.编译并安装
make & make install
注:linux编译安装中configure、make和make install各自的作用 https://www.jianshu.com/p/c70afbbf5172
5.创建用户组和用户,并设置密码(root不能执行pgsql的一些命令,所以一定要创建postgresql这个用户)
sudo useradd -d /home/postgres -m postgres #创建用户并为用户创建主目录,-m:自动建立用户的登入目录。
passwd postgres #为用户postgre设置密码
注:创建用户时没有密码,登录时又提示输入密码,那就 sudo passwd 用户名,然后回车输入两遍密码就可以为新用户添加密码了
6.创建数据库库文件存储目录并给postgresql用户赋予权限:
进入数据库安装目录: cd /opt/postgresql-11.0
创建data目录: sudo mkdir data
给postgresql用户赋予权限:sudo chown postgres.postgres data
7.切换用户:
su postgres
8.添加环境变量:
export POSTGRESQL_HOME=/opt/postgresql-11.0
export PGDATA=/opt/postgresql-11.0/data
export PATH=$PATH:$POSTGRESQL_HOME/bin:$PGDATA
#查看环境变量
echo $POSTGRESQL_HOME echo $PGDATA
echo $PATH
9初始化数据库目录:
初始化数据: initdb
10.配置监听地址和端口:
vi data/postgresql.conf
修改为如下配置:
listen_addresses = '*'
port = 5432
也就是将注释号"#"去掉,并把"localhost"改为"*"
PostgreSQL.conf文件配置详解[转]https://www.cnblogs.com/kuang17/p/6902712.html 特别详细,备查
12.启动数据库
pg_ctl -l log/server.log start
#关闭数据库 pg_ctl stop #重启数据库 pg_ctl restart
注:
-D data可以省略,系统会读取 PGDATA环境变量
启动数据库时遇到的错误

原因:修改pg_hba.conf出错
13.创建并连接数据库
createdb -h localhost stu
psql -h localhost stu
注:
- stu为数据库名,可以自己指定
- 连接数据库时,必须指定数据库名
- 创建数据库时遇到错误:“could not conoect to database template1: could not connect to server:connections on unix domain socket "/var/run/postgresql/.s.PGSQL.5432”

解决方法:加上-h localhost这个选项
- 可能是在pg_hba.conf中没有设置好本机访问
- 连接数据库时遇到“psql: FATAL: role "postgresql" does not exist”错误
- 解决方案:使用 “psql -U postgres [数据库名]” 登录
- 连接数据库时遇到“psql: FATAL: Peer authentication failed for user "postgres"错误
解决办法如下:
1). 运行下面的命令编辑pg_hba.conf文件 sudo vim /etc/postgresql/9.1/main/pg_hba.conf
2). 将
# Database administrative login by Unix domain socket
local all postgres peer
改为
# Database administrative login by Unix domain socket
local all postgres trust
3). 保存后执行下面的命令重新加载配置文件: sudo /etc/init.d/postgresql reload
Ubuntu下postgresql安装及常见错误处理的更多相关文章
- ubuntu下postgreSQL安装配置
一.安装并配置,并设置远程登陆的用户名和密码 1.安装postgreSQL sudo apt-get update sudo apt-get install postgresql-9.4 在Ubunt ...
- Ubuntu下postgresql安装
第一步:在Ubuntu下安装Postgresql 1.使用 apt-get install 安装 zhang@ubuntu:~/protgresql#sudo apt ...
- ubuntu下mysql安装(server、client、dev),开启、停止和重启,及常见错误
转自:ubuntu下mysql安装(server.client.dev),开启.停止和重启,及常见错误 1. 在ubuntu下安装server和client很简单: (1)安装server apt-g ...
- ubuntu 下编译安装 mysql php nginx 及常见错误 (持续添加)
mysql mysql 可以使用mysql 官方提供的apt源进行安装 参见这里 php 安装前先安装一些常见库 sudo apt-get install libpng16-16 libpng16-d ...
- Ubuntu下编译安装postgreSQL 10.5
Ubuntu下编译安装postgreSQL 10.5 ubuntu 16.04 LTS系统postgreSQL 10.5 安装包准备 1.从PostgreSQL官网下载PostgreSQL的安装包 安 ...
- ubuntu下git安装及使用
ubuntu下git安装及使用 其实,好几个月前,就已经安装好了,可是一直搁置在那儿,所以密码等一些其它细节都忘的差不多了,所以今天就重新部署了一下,并开始积极使用......... 1,git ...
- windows下postgreSQL安装与启动
转:https://www.yiibai.com/postgresql/install-postgresql.html https://blog.csdn.net/irainreally/articl ...
- PHP编译安装时常见错误解决办法,php编译常见错误
PHP编译安装时常见错误解决办法,php编译常见错误 1.configure: error: xslt-config not found. Please reinstall the libxslt & ...
- Elasticsearch学习之ElasticSearch 5.0.0 安装部署常见错误或问题
ElasticSearch 5.0.0 安装部署常见错误或问题 问题一: [--06T16::,][WARN ][o.e.b.JNANatives ] unable to install syscal ...
随机推荐
- 模板(Template)系统
一.常用语法 官方文档 只需要记两种特殊符号: {{ }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 1.1变量 {{ 变量名 }} 变量名由字母数字和下划线组成. 点(.)在模板 ...
- Failed to load ApplicationContext
java.lang.IllegalStateException: Failed to load ApplicationContext at org.springframework.test.conte ...
- Spring框架之使用JdbcTemplate开发Dao层程序
简介: JdbcTemplate开发dao层程序 由Spring框架给我们提供,Spring提供的很多操作数据源(关系型数据库,二维表格模型,有明确的行和列(mysql/orcal等) 非关系 ...
- nginx 动态跨域配置
方法一: server { ..... set $cors_origin ""; if ($http_origin ~* "a.xxxx.com") { set ...
- Prometheus监控学习笔记之解读prometheus监控kubernetes的配置文件
0x00 概述 Prometheus 是一个开源和社区驱动的监控&报警&时序数据库的项目.来源于谷歌BorgMon项目.现在最常见的Kubernetes容器管理系统中,通常会搭配Pro ...
- IOS 苹果手机fiddler抓包时出现了tunnel to 443 解决方案,亲测有效
先上一张捉取成功图[版本需4.0以上,并非所有https数据可抓取,具体原因未知] 1.先对Fiddler进行设置[打开Fiddler ——> Options .然后打开的对话框中,选择HTTP ...
- P4577 [FJOI2018]领导集团问题
P4577 [FJOI2018]领导集团问题 我们对整棵树进行dfs遍历,并用一个multiset维护对于每个点,它的子树可取的最大点集. 我们遍历到点$u$时: 不选点$u$,显然答案就为它的所有子 ...
- Linux 使用 github 常用命令
Linux 使用 github 常用命令 今天整理一下常用的 github 命令,自己只是一个编程小白,有些地方可能做的不是很好,仅仅用作自己的学习使用. 创建一个文件夹用于存放github仓库 m ...
- 《学习OpenCV3》第6章课后习题
//Exercises at end of Chapter 5,<learning OpenCV3> #include "stdafx.h" #include < ...
- shell 变量相关的命令
变量="变量" readonly 变量名="变量" 表示设置该变量为只读变量 ,这个变量不能别改变 echo $变量名 set 显示本地所有的变量 unse ...