MPP - GreenPlum数据库安装以及简单使用

Posted blitheg

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MPP - GreenPlum数据库安装以及简单使用相关的知识,希望对你有一定的参考价值。

 

一、集群介绍

共3台主机,ip 为193.168.0.93   193.168.0.94  193.168.0.95

集群对应master和segment如下,193.168.0.93为master节点。193.168.0.94  193.168.0.95为segment节点,每个segment节点配置两个primary segment和两个mirror segment(也可以为master做一个备份,目前没有做)

 

架构图入下

 技术分享图片

 


二、服务器修改(all host)

2.1配置hosts

  vi /etc/hosts

 

192.168.0.93 gpdb-1 mdw

192.168.0.94 gpdb-2 sdw1

192.168.0.95 gpdb-3 sdw2

 

2.2创建用户及用户组

2.2.1创建用户组,组id为530
groupadd -g 530 gpadmin
2.2.2创建用户,赋予gpadmin用户组,并自定用户根目录
useradd -g 530 -u 530 -d /home/gpadmin -s /bin/bash gpadmi
2.2.3授权/home/gpadmin
chown -R  gpadmin:gpadmin /home/gpadmin
2.2.4修改密码
passwd gpadmin
2.3关闭防火墙

2.3.1关闭默认防火墙

        systemctl stop firewalld

2.3.2关闭iptables

        systemctl stop iptables
2.4修改network文件
  vi /etc/sysconfig/network

NETWORKING=yes

HOSTNAME=对应的主机名称
2.5修改系统文件

2.5.1修改内核配置

  vi /etc/sysctl.conf

kernel.shmmax = 5000000000

kernel.shmmni = 4096

kernel.shmall = 4000000000

kernel.sem = 250 512000 100 2048

kernel.sysrq = 1

kernel.core_uses_pid = 1

kernel.msgmnb = 65536

kernel.msgmax = 65536

kernel.msgmni = 2048

net.ipv4.tcp_syncookies = 1

net.ipv4.ip_forward = 0

net.ipv4.conf.default.accept_source_route = 0

net.ipv4.tcp_tw_recycle = 1

net.ipv4.tcp_max_syn_backlog = 4096

net.ipv4.conf.all.arp_filter = 1

net.ipv4.ip_local_port_range = 1025 65535

net.core.netdev_max_backlog = 10000

net.core.rmem_max = 2097152

net.core.wmem_max = 2097152

vm.overcommit_memory = 2

执行命令 sysctl -p  使修改数值生效

 

2.5.2修改限制配置

  vi /etc/security/limits.conf

* soft nofile 65536

* hard nofile 65536

* soft nproc 131072

* hard nproc 131072

2.5.3禁用SELINUX

  vi /etc/selinux/config

SELINUX=disabled

 

 

三、安装依赖及创建安装目录(all host)

3.1安装依赖

yum install -y epel-release

yum install -y apr-devel bison bzip2-devel cmake3 flex gcc gcc-c++ krb5-devel libcurl-devel libevent-devel libkadm5 libyaml-devel libxml2-devel perl-ExtUtils-Embed python-devel python-paramiko python-pip python-psutil python-setuptools readline-devel xerces-c-devel zlib-devel

pip install lockfile conan

yum install openssl-devel

 

3.2创建安装目录

mkdir /opt/greenplum

chown -R gpadmin:gpadmin /opt/greenplum

chown -R gpadmin:gpadmin /usr/local/yiliao/

 

 

----------------------------------------以下用gpadmin用户------------------------------------------------------------

四、安装gpdb

4.1上传安装包并解压(Master)

unzip gpdb-5.6.0.zip

cd gpdb-5.6.0

4.2编译gpdb(Master)

4.2.1安装
./configure --with-perl --with-python --with-libxml --with-gssapi --disable-orca --prefix=/opt/greenplum/db

make

make install
4.2.2引入脚本
source /opt/greenplum/db/greenplum_path.sh

 

4.3编辑节点服务器文件(Master)

                 (目录: /home/gpadmin/gpconfig/)

mkdir gpconfig


vi all_hosts

    mdw
    sdw1
    sdw2


vi  seg_hosts

    sdw1
    sdw2

4.4打通节点(Master)

gpssh-exkeys -f all_hosts

gpssh-exkeys -f seg_hosts

 

 

4.5打包分发安装文件(Master)

4.5.1打包分发
tar -cf gp5.6.tar db/

gpscp -f /home/gpadmin/gpconfig/seg_hosts  gp5.6.tar =:/opt/greenplum
4.5.2解压分发文件(目录结构要和主节点一直)并创建数据目录
gpssh -f all_hosts(连接all节点,批量)

cd /opt/greenplum/

tar -xf gp5.6.tar

mkdir -p /usr/local/yiliao/gpdata/gpmaster

mkdir -p /usr/local/yiliao/gpdata/gpp1

mkdir -p /usr/local/yiliao/gpdata/gpp2

mkdir -p /usr/local/yiliao/gpdata/gpm1

mkdir -p /usr/local/yiliao/gpdata/gpm2

 

4.5.3 编辑.bash_profile

vi ~/.bash_profile

source /opt/greenplum/db/greenplum_path.sh

export MASTER_DATA_DIRECTORY=/usr/local/yiliao/gpdata/gpmaster/gpseg-1

export PGPORT=5432

export PGDATABASE=testDB

生效     . ~/.bash_profile

 

 

 

4.5.4编辑数据库启动文件(/home/gpadmin/gpconfig/)
ARRAY_NAME="Greenplum"

MACHINE_LIST_FILE=/home/gpadmin/gpconfig/seg_hosts

SEG_PREFIX=gpseg

PORT_BASE=40000

declare -a DATA_DIRECTORY=(/usr/local/yiliao/gpdata/gpp1 /usr/local/yiliao/gpdata/gpp2)

MASTER_HOSTNAME=mdw

MASTER_DIRECTORY=/usr/local/yiliao/gpdata/gpmaster

MASTER_PORT=5432

TRUSTED_SHELL=ssh

ENCODING=UNICODE

MIRROR_PORT_BASE=50000

REPLICATION_PORT_BASE=41000

MIRROR_REPLICATION_PORT_BASE=51000

declare -a MIRROR_DATA_DIRECTORY=(/usr/local/yiliao/gpdata/gpm1 /usr/local/yiliao/gpdata/gpm2)

 

4.5.5初始化数据库
gpinitsystem -c /home/gpadmin/gpconfig/gpinitsystem_config -a

 

4.5.6用psql测试是否安装成功
psql -d postgres

CREATE USER yiliaodb PASSWORD yiliaodb CREATEDB;

 

4.5修改文件(Master)

  cd /usr/local/yiliao/gpdata/gpmaster/gpseg-1/

  vi pg_hba.conf

host     all         yiliaodb           0.0.0.0/0     md5

 

说明:

(1).其中,"trust"和"password"为postgresql数据库登陆验证的方式,"trust"表示信任,即不需要输入密码(即使有密码),"password"表示需         要输入密码。

(2).host all all 127.0.0.1/31 trust表示本地连接数据库不需要输入密码(即使有密码,设为trust后就不需要密码)

(3).host all all 0.0.0.0/0 所有主机连接数据库需要输入密码(如果有密码)

(4).当然,这两个综合后表现的结果就是:对于本机链接表示信任(不需要输入密码),对于非本机链接需要输入密码

4.6安装注意事项

1.每次服务器重启以后需要关闭防火墙

2.每次需加载gpdb环境变量才能有gpdb数据库命令 “. ~/.bash_profile”

3.gpstop 命令关闭gpdb

4.gpstart -a 命令开启gpdb

 

4.7 gp基本命令

  1.Shell命令:

su - gpadmin

gpstart                      #正常启动

gpstop                       #正常关闭

gpstop  -M  fast #快速关闭

gpstop  -r               #重启

gpstop  -u               #重新加载配置文件

 

 

  2.gp命令

a) 登陆与退出Greenplum
      # 默认数据库登陆

        psql

      # 登陆gpdb数据库

        psql gpdb

        psql -d gpdb

      # 以gpadmin用户,gphostm server,5432端口登陆gpdb数据库

        psql -d gpdb -h gphostm -p 5432 -U gpadmin        

         # 退出

             在gp数据库中: q


b) 查看greenplum数据库下所有默认数据表:

    select * from pg_tables;

 

c)进入数据库以后,就可以通过命令,查看数据库种的数据库:

    select * from pg_database; d)数据库中查看用户和数据库     用户: du     数据库:l

 

 

  3.检查及修复无效的segment节点

# status命令查看状态

  Show detailed status information of a Greenplum Database system:
        gpstate -s


Do a quick check for down segments in the master host system catalog:
        gpstate -Q


Show information about mirror segment instances:
       gpstate -m
 

Show information about the standby master configuration:
       gpstate -f

Display the Greenplum software version information:
       gpstate -i

# 恢复节点
    gprecoverseg -r

 

五、数据备份和恢复

5.1 了解GreenPlum数据库的备份恢复

5.1.1并行备份(gp_dump)

1)      GP同时备份Master和所有活动的Segment实例

2)      备份消耗的时间与系统中实例的数量没有关系

3)      在Master主机上备份所有DDL文件和GP相关的数据字典表

4)      每个Segment备份各自的数据

5)      所有备份文件组成一个完整的备份集合,通过唯一14位数字的时间戳来识别

 

5.1.2 并行恢复(gp_restore)

1)      通过gp_dump产生的时间戳来辨识备份集合,恢复数据库对象和数据到分布式数据库

2)      每个Segment并行恢复各自的数据

3)      被恢复的GP系统必须与备份的系统同构

 

5.1.3非并行备份(pg_dump/pg_dumpall)

1)      GP依然支持常规的PostgreSQL备份命令pg_dump和pg_dumpall

2)      备份将在Master主机上创建一个包含所有Segment数据的大的备份文件

3)      不适合于全部数据备份,适用于小部分数据的迁移或备份

PS:   

  一般情况不使用pg_dump,它适用于PostgreSQL迁移到Greenplum。

  pg_dump一次只能备份一个单独的数据库,且不能备份角色和表空间信息(因为这些信息是cluster-wide,而不是在某个数据库中(per-database))

 

5.1.4非并行恢复(pg_restore)

1) 使用由pg_dump或pg_dumpall创建的备份文件来恢复

2) 使用非并行恢复可以实现异构系统恢复

 

5.1.5备份数据库的四种选择

1) 为每个实例创建一个备份文件

  可用于全库备份或者相同配置的系统之间迁移数据;

2) 使用gpcrondump进行定期备份

  对gp_dump进行包装,使用cron调度GP数据库的后台进行备份;

  调用gpcrondump的调度作业应该部署在GP的Master主机;

  gpcrondump命令还备份数据库角色和服务器配置等数据库之外的对象

3) 使用pg_dump或pg_dumpall创建单个备份文件

  可用于不同数据库之间少量数据迁移或备份;

4) 文件系统备份

  借助操作系统或者其他第三方工具来进行备份,实现增量备份

 

5.2创建GP用户和数据库

5.2.1切换到测试用户,并配置环境变量

           su gptestusr

    source /opt/greenplum/db/greenplum_path.sh

5.2.2创建数据库用户,并进入数据库

  CREATE USER testdb WITH PASSWORD password;

  CREATE DATABASE testdb;

  GRANT ALL PRIVILEGES ON DATABASE testdb to testdb;

  ALTER ROLE testdb CREATEROLE CREATEDB;

  修改greenplum配置文件:

           vi /usr/local/yiliao/gpdata/gpmaster/gpseg-1/pg_hba.conf

  进入数据库,输入密码的模式

    psql -U testdb -d testdb -W

 

5.3 备份实例

测试数据库时表:

create table syn_test(id int,name varchar(10)) distributed by (id);

insert into syn_test values(1,ab),(2,dc),(3,dfs),(4,sfs);

create table syn_test2(id int,cost varchar(10)) distributed by (id);

insert into syn_test2 values(11,aa),(22,bb),(55,cc),(77,dd);

 

5.3.1 pg_dump & pg_restore

  # 创建备份目录(root用户下)

           mkdir      /gpbackup

      chown     gpadmin.gpadmin   /gpbackup/

  # <1>表级别备份恢复

    备份:pg_dump -t syn_test -Fc -U testdb -W testdb -f /gpbackup/syn_test_pgdump.dmp

 

 

    恢复:pg_restore -d testdb /gpbackup/syn_test_pgdump.dmp

 

  # <2>database级别备份恢复

           备份:pg_dump testdb -Fc -Ugpadmin -W  -f /gpbackup/testdb_pgdump.dmp

 

 

     恢复:恢复之前需先创建空的数据库

 

5.3.2 pg_dumpall

  gp_dump同时只能备份一个数据库。为了解决这个问题,就要使用pg_dumpall工具,它备份每个数据库和角色、表空间定义。

  执行pg_dumpall需要超级用户权限。

 

# <1>导出所有role和tablespace

  pg_dumpall  -g >/gpbackup/role_tbs.sql

 

# <2>导出所有database

  pg_dumpall  >/gpbackup/all.dmp

 

5.3.3 gp_dump & gp_restore

# gp_dump

  gp_dump是Greenplum的并行备份工具,Master和segment同时备份,备份保存在每个节点中。备份时间最长的节点决定着整个备份时长。

  Segment节点备份的只有数据,而Master备份的是所有DDL命令和一些全局系统表(如gp_segment_configuration)。

  执行gp_dump时,只有Segment的primary和active Master运行备份操作,Mirror和stanby Master不参与备份。

  gp_dump在每个Segment上运行gp_dump_agent代理进程,将备份状态报告给Master的gp_dump进程。

 

      备份:gp_dump testdb --table=syn_test --gp-d=/gpbackup/ --gp-r=/gpbackup/

 

# gp_restore

  gp_restore命令使用gp_dump生成的备份文件恢复数据定义和用户的数据。特别要注意的时,gp_restore时需指定gp_dump备份时的时间戳(在gp_dump_.rpt中)。

 

  执行gp_restore有如下要求:

    gp_dump做的备份文件,并且备份文件在原始位置。

    GPDB正常运行

    GPDB的Segment节点数(包含primary和mirror)和备份时一致

    要被恢复的数据库(database)已创建

    使用gp_dump备份时指定了参数如-s (schema only) , -a (data only), --gp-c (compressed), --gp-d (alternate dump file location) ,那么使用gp_restore恢复时也要加上

 

 

      恢复:gp_restore --gp-d=/gpbackup/ --gp-r=/gpbackup/ --gp-k=201807041720





以上是关于MPP - GreenPlum数据库安装以及简单使用的主要内容,如果未能解决你的问题,请参考以下文章

MPP架构海量数据分析仓库——Greenplum介绍

Greenplum 架构详解 & Hash Join 算法介绍

GreenPlum 与hadoop啥关系

GREENPLUM

vertica和greeplum的区别

greenPlum的查询原理