一、系统准备与设置

1.四台Linux系统电脑准备,可用虚拟机创建。

master:192.168.26.137

sgement1:192.168.26.139

segment2:192.168.26.140

segment3:192.168.26.136

2.文件夹创建: mkdir /root/study   (所有节点)

3.安装包准备:greenplum-db-6.1.0-rhel7-x86_64,放在刚创建的/root/study目录下(可 Windows cmd scp命令操作 )

4.关闭防火墙 (所有节点)

关闭:systemctl stop firewalld 永久关闭 :systemctl disable firewalld

5.关闭SELINUX (所有节点)

vi /etc/selinux/config   修改内容如下:SELINUX=disabled

6.配置/etc/hosts (所有节点)

内容如下:

192.168.26.137                gp_1             mdw

192.168.26.139                gp_2             sdw1

192.168.26.140                gp_3             sdw2

192.168.26.136                gp_4             sdw3

7.配置sysctl.conf (所有节点)

vi /etc/sysctl.conf

修改内容如下:

kernel.shmall = 197951838 # echo $(expr $(getconf _PHYS_PAGES) / 2)
kernel.shmmax = 810810728448 # echo $(expr $(getconf _PHYS_PAGES) / 2 \* $(getconf PAGE_SIZE))
kernel.shmmni = 4096
vm.overcommit_memory = 2
vm.overcommit_ratio = 75 #vm.overcommit_ratio = (RAM - 0.026 * gp_vmem_rq) / RAM #gp_vmem_rq = ((SWAP + RAM) – (7.5GB + 0.05 * RAM)) / 1.7
net.ipv4.ip_local_port_range = 10000 65535
kernel.sem = 500 2048000 200 4096
kernel.sysrq = 1
kernel.core_uses_pid = 1
kernel.msgmnb = 65536
kernel.msgmax = 65536
kernel.msgmni = 2048
net.ipv4.tcp_syncookies = 1
net.ipv4.conf.default.accept_source_route = 0
net.ipv4.tcp_max_syn_backlog = 4096
net.ipv4.conf.all.arp_filter = 1
net.core.netdev_max_backlog = 10000
net.core.rmem_max = 2097152
net.core.wmem_max = 2097152
vm.swappiness = 10
vm.zone_reclaim_mode = 0
vm.dirty_expire_centisecs = 500
vm.dirty_writeback_centisecs = 100
#vm.min_free_kbytes = 487119#awk 'BEGIN {OFMT = "%.0f";} /MemTotal/ {print "vm.min_free_kbytes =", $2 * .03;}' /proc/meminfo

#对于大于64GB的主机,加上下面4行
vm.dirty_background_ratio = 0
vm.dirty_ratio = 0
vm.dirty_background_bytes = 1610612736 # 1.5GB
vm.dirty_bytes = 4294967296 # 4GB
#对于小于64GB的主机删除dirty_background_bytes dirty_bytes,加上下面2行
vm.dirty_background_ratio = 3
vm.dirty_ratio = 10

8.配置资源限制参数 (所有节点)

vi /etc/security/limits.conf

* soft nofile 524288
* hard nofile 524288
* soft nproc 131072
* hard nproc 131072
“*” 星号表示所有用户

9.创建用户 (所有节点)

groupadd gpyh
useradd gpyh -g gpyh -s /bin/bash
chown -R gpyh:gpyh /root/study     #我很暴力,直接给了root目录权限
passwd gpyh

10.同步集群时钟(NTP)  /脑仁疼,暂未设置/ (所有节点)

为了保证集群各个服务的时间一致,首先在master 服务器上,编辑 /etc/ntp.conf,配置时钟服务器为数据中心的ntp服务器。若没有,先修改master 服务器的时间到正确的时间,再修改其他节点的 /etc/ntp.conf,让他们跟随master服务器的时间。
 [root@mdw ~]# vi /etc/ntp.conf
 在server 最前面加上
 master:
 把server1,2,3,4全删
 改成 server xxx,如果没有就设置成
 server 1.cn.pool.ntp.org
 segment:
 server mdw prefer  # 优先主节点
 server smdw        # 其次standby 节点,若没有standby ,可以配置成数据中心的时钟服务器
 [root@mdw ~]# service ntpd restart  # 修改完重启ntp服务

二、数据库安装以及初始化

1.安装数据库到指定文件夹 (master)

rpm -i –prefix=/home/gpadmin    greenplum-db-6.0.0-rhel6-x86_64.rpm

greenplum有docker镜像吗 greenplum 搭建_linux

 2.进入gpyh用户,应用环境变量,打通集群ssh免密登录 (master)

su gpyh
source /root/study/greenplum-db/greenplum_path.sh
ssh-keygen -t rsa  #一路回车

(master)

> ssh-copy-id mdw
> ssh-copy-id sdw1
> ssh-copy-id sdw2
> ssh-copy-id sdw3

创建 hostlist,seg_hosts (master)

> mkdir /root/study/hostlist/
> vi /root/study/hostlist/hostlist
mdw
sdw1
sdw2
sdw3
> vi /root/study/hostlist/sge_hosts
sdw1
sdw2
sdw3
gpssh-exkeys -f hostlist

 3.打包以及分发数据库 (master)

tar -cf /root/study/gp6.tar greenplum-db-6.1.0/
gpscp -f /root/study/hostlist/hostlist /root/study/gp6.tar =:/root/study/

解压

> gpssh -f /root/study/hostlist/hostlist
=> cd /root/study
=> tar -xf gp6.tar
=> ln -s greenplum-db-6.1.0 greenplum-db

 4.创建数据存储空间 (master)

master节点

> mkdir -p /root/study/data/master

 sgement节点

> source /root/study/greenplum-db/greenplum_path.sh
> gpssh -f /root/study/hostlist/seg_hosts -e 'mkdir -p /root/study/data/primary'
> gpssh -f /root/study/hostlist/seg_hosts -e 'mkdir -p /root/study/data/mirror'

5.配置 .bash_profile 环境变量 (master)

 vi /root/.bash_profile

source /root/study/greenplum/greenplum-db/greenplum_path.sh
export MASTER_DATA_DIRECTORY=/root/study/data/master/gpseg-1
export PGPORT=5432
export PGUSER=gpyh

6.配置初始化文件 (master)

> mkdir /root/study/gpadmin/gpconfigs
> cp $GPHOME/docs/cli_help/gpconfigs/gpinitsystem_config /root/study/gpconfigs/gpinitsystem_config
 vi /root/study/gpconfigs/gpinitsystem_config
#数据库代号
ARRAY_NAME="Greenplum"
#segment前缀
SEG_PREFIX=gpseg
#primary segment 起始的端口号
PORT_BASE=33000
#指定primary segment的数据目录,网上写的是多个相同目录,多个目录表示一台机器有多个segment
declare -a DATA_DIRECTORY=(/root/study/data/primary)
#master所在机器的host name
MASTER_HOSTNAME=mdw
#master的数据目录
MASTER_DIRECTORY=/root/study/data/master
#master的端口
MASTER_PORT=5432
#指定bash的版本
TRUSTED_SHELL=/usr/bin/ssh
#将日志写入磁盘的间隔,每个段文件通常 =16MB < 2 * CHECK_POINT_SEGMENTS + 1
CHECK_POINT_SEGMENTS=8
#字符集
ENCODING=UNICODE
#mirror segment 起始的端口号
MIRROR_PORT_BASE=44000
# mirror的数据目录,和主数据一样,一个对一个,多个对多个
declare -a MIRROR_DATA_DIRECTORY=(/root/study/data/mirror)

7.初始化数据库 (master)

> gpinitsystem -c /root/study/gpconfigs/gpinitsystem_config -h /root/study/hostlist/hostlist

 可能会遇到的错:

greenplum有docker镜像吗 greenplum 搭建_linux_02

 网上百度的解决方法:root 用户执行

echo “RemoveIPC=no”>>/etc/systemd/logind.conf

service systemd-logind restart

但是没用,然后我是重启reboot,gpyh用户登录 重申变量 source /root/.bash_profile 再初始化就好了,如果遇到文件存在或端口占用就执行下:rm -rf /root/study/data/master/gpseg*,rm -f /tem/.s.PGSQL.5432 /tem/.s.PGSQL.5432.lock

三、使用数据库

psql -d postgres
\q 退出
\l 显示数据库列表
testdb=# alter role gpyh with password '123456'; #给用户设置数据库密码
ALTER ROLE

pgadmin使用

vi /root/study/data/master/gpseg-1/pg_hba.conf
pg_ctl reload -D /home/gpadmin/data/master/gpseg-1
gpstop
gpstart