前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Postgresql部署及简单操作

Postgresql部署及简单操作

原创
作者头像
July
修改2019-08-14 14:48:34
1.7K0
修改2019-08-14 14:48:34
举报
文章被收录于专栏:数据库干货铺数据库干货铺

PostgreSQL是一个功能强大的开源对象关系数据库管理系统(ORDBMS),在开源数据库使用上与MySQL各领风骚。但也有不少人质疑postgresql的未来,正所谓,赞扬或批判一种数据库都必须先了解它,然后才可有话语权。为了更多的了解postgresql,我们就先部署一套实例作为了解它的基础。

一 、 环境介绍

操作系统: centos

CPU:  4核

内存: 16G

postgresql:  postgresql-11.4

二、 编译安装

1. 安装依赖包

代码语言:javascript
复制
 yum install -y perl-ExtUtils-Embed readline-devel zlib-devel pam-devel libxml2-devel libxslt-devel openldap-devel python-devel gcc-c++ openssl-devel cmake

 2. 下载并解压

代码语言:javascript
复制
wget https://ftp.postgresql.org/pub/source/v11.4/postgresql-11.4.tar.gz
tar -zxvf postgresql-11.4.tar.gz

3. 创建用户

代码语言:javascript
复制
 # 查看用户是否存在
id postgres
# 添加用户组及用户
 groupadd postgres
 useradd -g postgres  postgres
# 再次查看可以查看对应的uid gid 
id postgres

4. 创建 postgresql数据目录并授权

选择对应的磁盘空间较大的盘创建数据目录

代码语言:javascript
复制
mkdir -p /data/postgresql/data
chown -R postgres:postgres data

5. 编译postgresql源码

代码语言:javascript
复制
cd /data/postgresql-11.4

./configure --prefix=/data/postgresql

  PostgreSQL配置脚本选项

6. 开始安装

代码语言:javascript
复制
make
make install

编译后结果如下

至此,postgresql安装完成。

7. 配置环境变量

代码语言:javascript
复制
# 切换到postgres用户
su - postgres
# 编辑postgres用户环境变量
vim .bash_profile

# 添加如下内容
export PGHOME=/data/postgresql
export PGDATA=/data/postgresql/data
PATH=$PATH:$HOME/bin:$PGHOME/bin 

# 使环境变量生效
source .bash_profile

8. 初始化数据库

在postgres用户下运行initdb命令即可初始化数据库

代码语言:javascript
复制
initdb

 此时,postgresql数据目录下已经生成对应的文件。

代码语言:javascript
复制
cd /data/postgresql/data
 ll -h 

9. 配置文件修改

修改数据目录下的postgresql.conf  及 pg_hba.conf文件

postgresql.conf   配置PostgreSQL数据库服务器的相应的参数。  pg_hba.conf        配置对数据库的访问权限

初期测试使用时,可以简单修改部分配置,其他值使用默认值。

1)修改 postgresql.conf

代码语言:javascript
复制
vim postgresql.conf
修改 listen_addresses 为 * ,代表所有主机皆可访问
listen_addresses = '*' 

内存配置等参数后续将介绍其含义及配置建议。

2)修改 pg_hba.conf

添加如下记录

10.  配置服务

如需配置为服务启动方式,可以按照如下步骤操作

代码语言:javascript
复制
# 进入postgresql源码目录
cd /data/postgresql-11.4/contrib/start-scripts
# 此目录下有各系统的启动目录,需先将其添加执行权限
chmod +x  linux 
# 将启动服务拷贝至启动服务下
cp linux  /etc/init.d/postgresql

 因启动服务命令里配置上了默认安装路径目录及数据目录,如与默认路径不一致,需手动调整

代码语言:javascript
复制
vim  /etc/init.d/postgresql

修改 prefix及PGDATA

11 . 启动服务

a)  通过服务启动postgresql

代码语言:javascript
复制
/etc/init.d/postgresql  start

b)  通过服务关闭postgresql

代码语言:javascript
复制
/etc/init.d/postgresql  stop

c)  通过pg_ctl 启动

复制代码
复制代码
代码语言:javascript
复制
#  将postgresql安装路径bin目录下的命令赋权给postgres用户
cd  /data/postgresql/bin
chown -R  postgres:postgres  .
# 切换至postgres用户启动服务
 su - postgres
# 启动服务
pg_ctl -D /data/postgresql/data/ -l logfile  start
复制代码
复制代码

至此,便可以通过客户端连接数据库进行操作了。

三、简单操作

1. 创建数据库

代码语言:javascript
复制
createdb gjc

2.  连接数据库

代码语言:javascript
复制
# 使用psql连接gjc数据库
psql gjc

3.  创建表、索引、并插入数据

代码语言:javascript
复制
gjc=# create table  test1(id int  not null  primary key,name  varchar(20),age int );
CREATE TABLE
gjc=# create index idx_test1_name on test1(name);
CREATE INDEX
gjc=# insert into test1 values(1,'gjc',28);
INSERT 0 1
gjc=# select * from test1

id | name | age ----+------+----- 1 | gjc | 28 (1 row)

其他的操作,大家可以参考官方文档或中文社区进行学习实践,如有问题也可以与我联系沟通,共同探索。

看完别忘了点个赞哦。

最近刚开通微信公众号,希望大家拿出小手机关注一下(微信公众号:数据库干货铺),不胜感激。

数据库干货铺
数据库干货铺

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一 、 环境介绍
  • 二、 编译安装
    • 1. 安装依赖包
      •  2. 下载并解压
        • 3. 创建用户
          • 4. 创建 postgresql数据目录并授权
            • 5. 编译postgresql源码
              • 6. 开始安装
                • 7. 配置环境变量
                  • 8. 初始化数据库
                    • 9. 配置文件修改
                      • 10.  配置服务
                        • 11 . 启动服务
                        • 三、简单操作
                          • 1. 创建数据库
                            • 2.  连接数据库
                              • 3.  创建表、索引、并插入数据
                              相关产品与服务
                              数据库
                              云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
                              领券
                              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档