Ubuntu下编译安装postgreSQL 10.5

ubuntu 16.04 LTS系统
postgreSQL 10.5

安装包准备

1.从PostgreSQL官网下载PostgreSQL的安装包

安装过程

2.解压源码包

tar zxvf postgresql-10.5.tar.gz
cd postgresql-10.5

3.检查环境配置

#创建postgreSQL的安装目录
mkdir /usr/local/postgresql
#检查环境配置--prefix是指定postgreSQL安装路径
./configure --prefix=/usr/local/postgresql

4.解决环境配置检查过程中出现的依赖问题
1)出现readline library not found依赖的解决

解决方法:

有网络:apt-get install -y libreadline-gplv2-dev
无网络:下载软件包使用dpkg命令安装 ,可在网站pkgs.org上下载
libtinfo-dev_6.0+20160213-1ubuntu1_amd64.deb
libreadline-gplv2-dev_5.2+dfsg-3build1_amd64.deb

2)出现zlib library not found依赖问题的解决

有网络:apt-get install zlib1g-dev

无网络:下载软件包
zlib1g-dev_1.2.8.dfsg-2ubuntu4_amd64.deb

5.再次重新检查环境
./configure --prefix=/usr/local/postgresql
6.编译安装
#编译安装
make && make install
出现下面的显示表示编译安装成功

安装contrib目录下的一些工具,是第三方组织的一些工具代码,建议安装

cd contrib
make && make install
7.添加用户
root 用户不能启动postgresql 所以创建一个普通用户来启动和管理
#如果直接只用useradd添加用户的话,可能出现没有home下的文件夹
#可以使用adduser 命令
adduser postgres
创建用户成功

7. 赋予 postgres用户相关文件夹权限

#创建postgreSQL数据存放位置
## postgreSQL有些配置文件将数据的存放位置指向 /usr/local/postgresql/data,
## 可以将将数据的存放位置创建在 /usr/local/postgresql下,可以省去后面一些配置的修改
mkdir -p /var/postgresql/data
## 日志存放
mkdir -p /var/postgresql/logs
# 给postgres用户赋予文件夹的所属权限和读写
chown -R postgres:postgres /usr/local/postgresql
chown -R postgres:postgres /var/postgresql

chmod -R 775 /var/postgresql/*

配置postgres用户环境变量
#切换至postgres用户
su - postgres
#修改配置文件
vim ~/.profile
# 添加以下内容和修改PATH
export PGHOME=/usr/local/postgresql
export PGDATA=/var/postgresql/data
export PGHOST=/tmp
export PATH="$HOME/bin:$HOME/.local/bin:$PATH:$PGHOME/bin"
export MANPATH=$PGHOME/share/man:$MANPATH
export LANG=en_US.utf8
export DATE=`date +"%Y-%m-%d %H:%M:%S"`
export LD_LIBRARY_PATH=$PGHOME/lib:$LD_LIBRARY_PATH
#下面只是启动服务的快捷配置,可不用配置
#alias pg_start='pg_ctl start -D $PGDATA'
#alias pg_stop='pg_ctl stop -D $PGDATA -m fast'

配置如下图

9.启动数据库

#初始化数据库
initdb -D /var/postgresql/data
#启动服务
pg_ctl -D /var/postgresql/data -l /var/postgresql/logs/logfile start
#连接数据库
psql
#创建数据库
create database test;
#创建表
create table t_user (id integer, name text);
#插入测试数据
insert into t_user values (1,'joke');
#查询数据
select * from t_user ;
#退出psql窗口
\q

10.修改监听所有网络以及数据库连接数
# 修改配置文件
vim /var/postgresql/data/postgresql.conf
# listen_addresses = ‘localhost’ 监听本机,'*'监听所有网络
listen_addresses = '*'
#max_connections 数据库的连接数根据具体需求更改

11. **修改远程访问 **

vim /var/postgresql/data/pg_hba.conf
#在文件的最下方加上下面的这句话
host all all 0.0.0.0/0 trust

12. 防火墙开启端口

# 切换root用户
su - root
# 防火墙 允许5432 端口
ufw allow 5432
** 重启postgreSQL服务
# 切换postgres用户
su - postgres
#重启服务
pg_ctl -D /var/postgresql/data -l /var/postgresql/logs/logfile restart

#停止服务
pg_ctl -D /var/postgresql/data -l /var/postgresql/logs/logfile stop

设置开机自启动
切换到root用户
su - root
找到解压后源码包里面的一个linux文件
cd /home/postgresql/postgresql-10.5/contrib/start-scripts

3. 修改linux文件属性,添加X属性

chmod a+x linux
复制linux文件到/etc/init.d目录下,更名为postgresql
cp linux /etc/init.d/postgresql
修改/etc/init.d/postgresql文件的两个变量
vi /etc/init.d/postgresql
#prefix设置为postgresql的安装路径:prefix=/usr/local/postgresql
#PGDATA设置为postgresql的数据目录路径:PGDATA="/var/postgresql/data"

执行service postgresql start,可以启动PostgreSQL服务
service postgresql start
如果这里执行命令后出现Failed to start postgresql.service: Unit postgresql.service not found.错误
请检查配置postgres用户的环境变量的时候是否将PATH给export了

设置postgresql服务开机自启动
#ubuntu 16.04前版本使用chkconfig命令
chkconfig --add postgresql
#ubuntu 16.04版本使用sysv-rc-conf命令,可能需要进行安装
sysv-rc-conf postgresql on
1. sysv-rc-conf 离线安装依赖的包
libcurses-perl_1.33-1build1_amd64.deb
libterm-readkey-perl_2.33-1build1_amd64.deb
libcurses-ui-perl_0.9609-1_all.deb
sysv-rc-conf_0.99-7_all.deb
从上至下依次安装即可
2. 在线安装
apt-get install sysv-rc-conf
重新启动系统,postgreSQL自动启动
参考文章:
https://www.aliyun.com/jiaocheng/142831.html
https://blog.csdn.net/jerry_sc/article/details/76408116

Ubuntu下编译安装postgreSQL 10.5的更多相关文章

  1. 在Ubuntu下编译安装GreatSQL

    在Ubuntu下编译安装GreatSQL 本次介绍如何利用Docker构建Ubuntu环境,并将GreatSQL源码编译成二进制文件. 1.准备工作 先创建本次Docker的workdir为 /dat ...

  2. Mac OSX下编译安装PostgreSQL

    原先使用的是官方提供的安装包,可是安装包会创建postgre这个用户.在登陆界面看的有点不爽,搜索了半天居然没有找到怎样在osx下编译安装的教程,并且假设是依照官方文档的编译安装办法一定会让你崩溃,本 ...

  3. linux下编译安装MariaDB 10.4.7,解决错误:cannot access ‘/auth_pam_tool_dir’: No such file or directory

    编译安装MariaDB 10.4.7,前面的步骤我就不复述了,一切正常没什么问题. 当执行到:scripts/mysql_install_db --basedir=/usr/local/mysql - ...

  4. ubuntu下编译安装poco

    系统环境: ubuntu版本:Linux jfcai-VirtualBox 4.15.0-29-generic #31-Ubuntu SMP Tue Jul 17 15:39:52 UTC 2018 ...

  5. [实践] ubuntu下编译安装ambari

    ambari是一个Hadoop套件的管理工具,可以方便部署.管理及监控.最初开发时使用的就是RH系的Linux,只支持RHEL.CentOS5/6.OEL.SLES,暂不支持Ubuntu:可我的需求就 ...

  6. Redhat 7.2 编译安装PostgreSQL 10

    1.环境说明 CentOS7.2 postgresql10.4 2.下载 postgresql的官方地址 https://www.postgresql.org/ftp/source/ 在下载列表中根据 ...

  7. ubuntu下编译安装mysql记录

         搞了整整一天,好不容易折腾完,在此记录下,下次就省事了.     去官网http://www.php.net/downloads.php下载所需要的php版本,这里我选择5.6.22.    ...

  8. Ubuntu 下编译安装linux

    1. 准备工作切换为管理员权限,sudo –i 输入用户密码 进入root 权限apt-get install build-essential kernel-package libncurses5-d ...

  9. linux-i386(ubuntu)下编译安装gsoap_2.8.17过程记录

    过程记录 :  1.下载gsoap_2.8.17.zip 并 解压 : $unzip gsoap_2.8.17.zip     2.进入解压后的目录gsoap-2.8   3.自动配置编译环境:  $ ...

随机推荐

  1. RabbitMQ系列之【centos6 服务开启自启脚本】

    #!/bin/sh## rabbitmq-server RabbitMQ broker## chkconfig: - 80 05# description: Enable AMQP service p ...

  2. EIGRP-10-弥散更新算法-计算距离,报告距离,可行距离和可行性条件

    对于某个目的网络,EIGRP持续关注它的各种距离参数.EIGRP使用复合度量参数,不过为了简化,这里使用一个没有单位的数值.同样出于简化,这里的EIGRP路由器都不使用水平分割.

  3. Python多线程 - threading

    目录 1. GIL 2. API 3. 创建子线程 4. 线程同步 4.1. 有了GIL,是否还需要同步? 4.1.1. 死锁 4.1.2. 竞争条件 4.1.3. GIL去哪儿了 4.2. Lock ...

  4. Hadoop + Hive + HBase + Kylin伪分布式安装

    问题导读 1. Centos7如何安装配置? 2. linux网络配置如何进行? 3. linux环境下java 如何安装? 4. linux环境下SSH免密码登录如何配置? 5. linux环境下H ...

  5. Ubuntu 20.04下源码编译安装ROS 2 Foxy Fitzroy

    ROS 2 Foxy Fitzroy(以下简称Foxy)于2020年6月5日正式发布了,是LTS版本,支持到2023年5月.本文主要根据官方的编译安装教程[1]完成,并记录编译过程中遇到的问题. 1. ...

  6. conda 管理包

    查看当前环境已经安装的包 conda list 查看指定环境中的安装包 conda list -n python27 在Anaconda 库中搜索包 conda search numpy #模糊搜索 ...

  7. jsc和luac文件 xxtea 解密.

    # -*- coding: utf-8 -*- import xxtea import os src = "./assets/src" dst = "./assets/s ...

  8. cb05a_c++_STL优先级队列priority_queue_less_greater

    /*cb05a_c++_STL优先级队列priority_queue自适应容器(容器适配器):不能使用list,list不能使用随机操作最大值优先级队列,//把数据放在队列里面是,最大的始终都是放在最 ...

  9. 设计模式系列之组合模式(Composite Pattern)——树形结构的处理

    说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修炼之道)>一书的阅读笔记.个人感觉这本书讲的不错,有兴趣推荐读一读.详细内容也可以看看此书作者的博客https:/ ...

  10. 这篇文章,我们来谈一谈Spring中的属性注入

    本系列文章: 读源码,我们可以从第一行读起 你知道Spring是怎么解析配置类的吗? 配置类为什么要添加@Configuration注解? 谈谈Spring中的对象跟Bean,你知道Spring怎么创 ...