Postgresql在linux环境下以源码方式安装

2023-11-06 00:30

本文主要是介绍Postgresql在linux环境下以源码方式安装,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

linux环境下源码方式的安装

1.下载安装包(源码安装方式)

安装包下载
https://www.postgresql.org/ftp/source/
在这里插入图片描述

2.安装postgresql

① 创建安装目录

mkdir /opt/pgsql12

② 解压下载的安装包

cd /opt/pgsql12
tar -zxvf postgresql-12.16.tar.gz 

③编译安装

#指定源码的位置./configure --prefix=/opt/pgsql12/postgresql-12.16

./configure --help查看可定制的参数,其中打印的结果中–with类的都是打开一些功能,此外还有–without,–disable等,具体参考官网;

–prefix=prefix:安装到prefix指向的目录;默认为/usr/local/pgsql 
或者./configure --without-readline 按照默认的
–bindir=dir:安装应用程序到dir;默认为prefix/bin
–with-docdir=dir:安装文档到dir;默认为prefix/doc
–with-pgport=port:设置默认的服务器端网络连接服务TCP端口号
–with-tcl:为服务端提供Tcl存储过程支持
–with-perl:为服务端提供Perl存储过程支持
–with-python:为服务端提供Python存储过程支持

④ 创建用户、组、数据目录
创建新用户,PostgreSQL不允许使用root用户运行服务,需要创建新用户用于管理PostgreSQL服务

# 创建组
groupadd postgres
# 创建用户
useradd -g postgres postgres
# 创建数据目录
mkdir –p /opt/pgsql12/postgresql-12.16/data
# 修改目录归属
chown postgres:postgres /opt/pgsql12/postgresql-12.16/data

⑤配置环境变量
环境变量的配置方式可参考
root用户执行以下操作

编辑修改.bash_profile文件

#/home/postgres是你刚才创建的用户 
vim /home/postgres/.bash_profile

在原有内容添加
在这里插入图片描述

 PG_HOME=/opt/pgsql12/postgresql-12.16#注意 PGDATA是固定名称
export PGDATA=/opt/pgsql12/postgresql-12.16/data

使修改的.bash_profile文件立即生效

source /home/postgres/.bash_profile
#切换到postgres用户
su - postgres
#检测postgresql版本
psql --version

输出版本号则证明环境变量配置正确
⑥初始化数据库

# 切换至postgres用户su - postgres
# 使用initdb命令初始化数据库initdb -A md5 -D $PG_DATA -E utf8 --locale=C -W

-A 是加密方式
-D 是数据目录
-E 是字符集 (默认即utf8)
执行之后会提示输入密码。(设置你的数据库的密码)
⑦ 启停数据库
可以使用初始化打印的结果来启动
在这里插入图片描述

pg_ctl -D /opt/pgsql12/postgresql-12.16/data -l logfile start

如果配了环境变量(⑤中的环境变量)也可以直接pg_ctl start来启动,因为pgdata能识别到;
重启:pg_ctl restart
关闭:pg_ctl stop
通过pg_ctl --help可以查看完整的选项,
其中关闭和重启选项中的shutdown modes包括smart、fast、immediate;
smart是最安全的关闭方法,等待所有客户端连接关闭之后才关闭;
fast是用的生产中最多的,自动杀掉连接,回滚未完成事务;
immediate相当于kill -9;

pg_ctl -D /opt/pgsql12/postgresql-12.16/data stop -ms
pg_ctl -D /opt/pgsql12/postgresql-12.16/data  stop -mf
pg_ctl -D /opt/pgsql12/postgresql-12.16/data   stop -mi

此外启动数据库还可以通过脚本启动,需要切换回root用户执行

/opt/pgsql12/postgresql-12.16/contrib/start-scripts/linux

使用此脚本需要修改脚本中prefix、PGDATA等内容。

3.利用chkconfig设置PostgreSQL为服务自启动(没啥必要)

①拷贝启动脚本
PostgreSQL的开机自启动脚本位于/opt/pgsql12/postgresql-12.16/contrib/start-scripts/linux
是postgresql在linux系统上的启动脚本。

# 复制到系统的/etc/init.d/目录下的postgresql文件上
cp /opt/pgsql12/postgresql-12.16/contrib/start-scripts/linux  /etc/init.d/postgresql

②修改/etc/init.d/postgresql文件的两个变量prefix、PGDATA

# Installation prefix
prefix=/opt/pgsql12/postgresql-12.16# Data directory
PGDATA="/opt/pgsql12/postgresql-12.16/data"

③要将 postgresql服务设置为开机自启动
chkconfig --add postgresql

4.配置远程访问

①开放端口号或者关闭linux的防火墙也可以(不推荐)

# 开放5432端口
firewall-cmd --zone=public --add-port=5432/tcp --permanent
# 配置立即生效
firewall-cmd --reload

②修改ip绑定

vim /opt/pgsql12/postgresql-12.16/data/postgresql.conf 

将监听地址由localhost改为*

listen_addresses = '*'  

在esc命令模式下通过/listen_addresses找到 将注释打开修改为*
*代表监听任意ip可以修改为实际网络的地址
③允许所有ip访问

vim /opt/pgsql12/postgresql-12.16/data/pg_hba.conf 

大概86行下面添加如下内容

host    all             all             0.0.0.0/0            md5

在这里插入图片描述
④在windows环境下测试连接
在这里插入图片描述
telnet ip 端口号 可查看某端口是否开放

这篇关于Postgresql在linux环境下以源码方式安装的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/353408

相关文章

Go中sync.Once源码的深度讲解

《Go中sync.Once源码的深度讲解》sync.Once是Go语言标准库中的一个同步原语,用于确保某个操作只执行一次,本文将从源码出发为大家详细介绍一下sync.Once的具体使用,x希望对大家有... 目录概念简单示例源码解读总结概念sync.Once是Go语言标准库中的一个同步原语,用于确保某个操

虚拟机与物理机的文件共享方式

《虚拟机与物理机的文件共享方式》文章介绍了如何在KaliLinux虚拟机中实现物理机文件夹的直接挂载,以便在虚拟机中方便地读取和使用物理机上的文件,通过设置和配置,可以实现临时挂载和永久挂载,并提供... 目录虚拟机与物理机的文件共享1 虚拟机设置2 验证Kali下分享文件夹功能是否启用3 创建挂载目录4

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

Linux之软件包管理器yum详解

《Linux之软件包管理器yum详解》文章介绍了现代类Unix操作系统中软件包管理和包存储库的工作原理,以及如何使用包管理器如yum来安装、更新和卸载软件,文章还介绍了如何配置yum源,更新系统软件包... 目录软件包yumyum语法yum常用命令yum源配置文件介绍更新yum源查看已经安装软件的方法总结软

linux报错INFO:task xxxxxx:634 blocked for more than 120 seconds.三种解决方式

《linux报错INFO:taskxxxxxx:634blockedformorethan120seconds.三种解决方式》文章描述了一个Linux最小系统运行时出现的“hung_ta... 目录1.问题描述2.解决办法2.1 缩小文件系统缓存大小2.2 修改系统IO调度策略2.3 取消120秒时间限制3

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

Linux:alias如何设置永久生效

《Linux:alias如何设置永久生效》在Linux中设置别名永久生效的步骤包括:在/root/.bashrc文件中配置别名,保存并退出,然后使用source命令(或点命令)使配置立即生效,这样,别... 目录linux:alias设置永久生效步骤保存退出后功能总结Linux:alias设置永久生效步骤

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动