经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » PostgreSQL » 查看文章
Postgresql部署及简单操作
来源:cnblogs  作者:懂点IT的耿小厨  时间:2019/8/12 8:59:07  对本文有异议

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

 

一 、 环境介绍

操作系统: centos

CPU:  4核

内存: 16G

postgresql:  postgresql-11.4

 

二、 编译安装

1. 安装依赖包

  1. 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. 下载并解压

  1. wget https://ftp.postgresql.org/pub/source/v11.4/postgresql-11.4.tar.gz
  2. tar -zxvf postgresql-11.4.tar.gz

3. 创建用户

  1. # 查看用户是否存在
    id postgres
    # 添加用户组及用户
  2. groupadd postgres
  3. useradd -g postgres postgres
  4. # 再次查看可以查看对应的uid gid
    id postgres

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

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

  1. mkdir -p /data/postgresql/data
  2. chown -R postgres:postgres data

5. 编译postgresql源码

  1. cd /data/postgresql-11.4
  2. ./configure --prefix=/data/postgresql

  PostgreSQL配置脚本选项

6. 开始安装

  1. make
  2. make install

编译后结果如下

至此,postgresql安装完成。

7. 配置环境变量

  1. # 切换到postgres用户
  2. su - postgres
  3. # 编辑postgres用户环境变量
  4. vim .bash_profile
  5. # 添加如下内容
  6. export PGHOME=/data/postgresql
  7. export PGDATA=/data/postgresql/data
  8. PATH=$PATH:$HOME/bin:$PGHOME/bin

    # 使环境变量生效
    source .bash_profile

 

8. 初始化数据库

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

  1. initdb

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

  1. cd /data/postgresql/data
  2. ll -h

 

9. 配置文件修改

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

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

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

1)修改 postgresql.conf

  1. vim postgresql.conf
  2. 修改 listen_addresses * ,代表所有主机皆可访问
  3. listen_addresses = '*'

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

2)修改 pg_hba.conf

添加如下记录

 

10.  配置服务

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

  1. # 进入postgresql源码目录
  2. cd /data/postgresql-11.4/contrib/start-scripts
  3. # 此目录下有各系统的启动目录,需先将其添加执行权限
  4. chmod +x linux
  5. # 将启动服务拷贝至启动服务下
  6. cp linux /etc/init.d/postgresql

 

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

  1. vim /etc/init.d/postgresql
  2. 修改 prefixPGDATA

 

11 . 启动服务

a)  通过服务启动postgresql

  1. /etc/init.d/postgresql start

b)  通过服务关闭postgresql

  1. /etc/init.d/postgresql stop

c)  通过pg_ctl 启动

 

  1. # 将postgresql安装路径bin目录下的命令赋权给postgres用户
  2. cd /data/postgresql/bin
  3. chown -R postgres:postgres .
  4. # 切换至postgres用户启动服务
  5. su - postgres
  6. # 启动服务
  7. pg_ctl -D /data/postgresql/data/ -l logfile start

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

 

三、简单操作

1. 创建数据库

  1. createdb gjc

2.  连接数据库

  1. # 使用psql连接gjc数据库
  2. psql gjc

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

  1. gjc=# create table test1(id int not null primary key,name varchar(20),age int );
  2. CREATE TABLE
  3. gjc=# create index idx_test1_name on test1(name);
  4. CREATE INDEX
  5. gjc=# insert into test1 values(1,'gjc',28);
  6. INSERT 0 1
  7. gjc=# select * from test1

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

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

 

耿小厨已开通个人微信公众号,想进一步沟通或想了解其他文章的同学可以关注我

 

我的博客即将同步至腾讯云+社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=33ja5r1x478ks

原文链接:http://www.cnblogs.com/gjc592/p/11313878.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号