安装与卸载
目前 Yukon 1.0.1 版本支持开源数据库openGauss和PostgreSQL,以及商用数据库GaussDB。 在安装 Yukon 之前必须先安装数据库。 开源数据库安装指导参见: openGauss 或 PostgreSQL 。 商用数据库GaussDB请联系高斯数据库服务提供商。
Note
openGauss 支持的操作系统有: centos_x86_64、openeuler_aarch64、openeuler_x86_64,请优先在这些操作系统进行安装。
数据库安装成功后,开始 Yukon 产品的安装。
获取安装包
下载地址:
链接:https://pan.baidu.com/s/1PkcGEpYjqT2sTdKm6cd-NA?pwd=c0bx 提取码:c0bx
安装包
Yukon-1.0.1-openGauss3.1.0-CentOS_x64.tar.gz
Yukon-1.0.1-openGauss3.1.0-openeuler_aarch64.tar.gz
Yukon-1.0.1-postgres13-CentOS_x64.tar.gz
Yukon-Pro-1.0.1-GaussDB_kylin10-aarch64.tar.gz
从 Yukon 开源仓库下载对应平台的安装包
登录 Yukon For openGauss 源码托管网站下载适配 openGauss3.1.0的安装包。
登录 Yukon For PostgreSQL 源码托管网站下载适配 PostgreSQL13 的安装包
登录账号,点击
Yukon-1.0.1-xxx-xxx.tar.gz
下载。
- 检查安装包解压安装包,检查安装目录及文件是否齐全。在安装包所在目录执行以下命令:
mkdir yukon tar -xf Yukon-1.0.1-xxx-xxx.tar.gz -C yukon ls -l yukon
执行 ls 命令,显示类似如下信息:
ls -l drwxr-xr-x 8 root root 138 Dec 29 21:52 . dr-xr-x---. 20 root root 4096 Dec 30 14:33 .. drwxr-xr-x 2 root root 75 Dec 29 21:52 bin drwxr-xr-x 2 root root 278 Dec 29 21:52 data drwxr-xr-x 2 root root 8192 Dec 29 21:52 extension -rw-r--r-- 1 root root 7649776 Dec 29 21:52 Yukon 1.0.1 说明文档.pdf -rw-r--r-- 1 root root 4367 Dec 29 21:52 install.sh drwxr-xr-x 2 root root 220 Dec 29 21:52 lib drwxr-xr-x 2 root root 4096 Dec 29 21:52 license lrwxrwxrwx 1 root root 13 Dec 29 21:52 yk_tool -> ./bin/yk_tool drwxr-xr-x 2 root root 4096 Dec 29 21:52 yukon_dep
软硬件环境要求
软件环境要求
软件类型 |
配置描述 |
---|---|
Linux 操作系统
|
ARM:
- openEuler 20.03LTS
- 麒麟 v10
X86:
- openEuler 20.03LTS
- Centos 7.6
|
数据库
|
- openGuass3.1.0
- GuassDB
- PostgreSQL 13
|
软件依赖要求
为了尽可能的与操作系统的默认软件保持兼容,我们在软件的安装包中自带和操作系统软件源中版本一致的依赖软件,列表如下:
软件名称 |
Centos(7.6)版本 |
openEuler(20.03)版本 |
---|---|---|
libtiff |
4.0.3 |
4.1.0 |
libcurl |
7.29.0 |
7.71.1 |
gmp |
6.0.0 |
6.2.0 |
mpfr |
3.1.1 |
4.1.0 |
libuuid |
2.23.2 |
2.35.2 |
json-c |
0.11 |
0.15 |
libxml2 |
2.9.1 |
2.9.10 |
安装包安装
单节点安装
安装时请使用数据库所属用户,这里假设 openGauss/GaussDB 数据库所属用户为 omm, PostgreSQL 所属用户为 postgres
使用 omm/postgres 用户登录到 Yukon 包要安装的主机,解压 Yukon 压缩包到任意目录(假定目录为 /opt/software/yukon)
tar -xf Yukon-1.0.1-xxx-xxx.tar.gz -C /opt/software/yukon
进入解压后的目录
cd /opt/software/yukon
3.检查数据库环境变量
--检查pg_config命令是否正常运行以及输出结果是否正确 pg_config --检查PGDATA环境变量,输出结果是否为空以及是否正确 echo $PGDATA --检查LD_LIBRARY_PATH环境变量,输出结果是否为空以及是否包含数据库lib目录 echo $LD_LIBRARY_PATH
4.配置数据库环境变量[可选]
如果检查数据库环境变量存在问题,请按照以下步骤重新配置PATH、LD_LIBRARY_PATH、PGDATA环境变量,并且配置后需要重新检查。
(1)PostgreSQL配置参考
--设置PGHOME环境变量,指定数据库安装目录,请根据实际数据库安装参数进行设置 export PGHOME=/opt/pg13 --设置PATH环境变量 export PATH=$PATH:$PGHOME/bin --设置PGDATA环境变量,指定数据库的数据目录位置,请根据实际数据库安装参数进行设置 export PGDATA=$PGHOME/data --设置LD_LIBRARY_PATH环境变量 echo export LD_LIBRARY_PATH='$LD_LIBRARY_PATH':$PGHOME/lib >>/home/pg13/.bashrc source /home/pg13/.bashrc(2)openGauss/GaussDB配置参考 openGauss/GaussDB数据库安装后会生成用户环境变量文件,PATH/LD_LIBRARY_PATH一般会自动加载,不需要手动; 如果遇到需要手动加载的情况,可直接source用户环境变量文件。
--手动source环境变量文件 source /home/omm/env_single --设置PGDATA环境变量,需要根据数据库的数据目录datanode进行设置,可查看数据库配置文件cluster_config.xml export PGDATA=$GAUSSHOME/dn1
执行安装脚本安装 Yukon
sh install.sh -i
上述命令中使用
-i
参数表示安装,卸载时可使用-r
参数。安装完成后会显示如下界面
\ \ / / | | \ \_/ /_ _ | | __ ___ _ __ \ /| | | || |/ // _ \ | _ \ | | | |_| || <| (_) || | | | |_| \____||_|\_\\___/ |_| |_|
Note
安装脚本是通过 pg_config 命令获取 Yukon 的文件应该被安装到那些位置。因此你首先应该确定 pg_config 的位置是否正确,同时 Yukon for Postgres 需要在 postgresql.conf 中添加 shared_preload_libraries = citus 才能支持 citus 插件。而该文件一般在数据库实例的数据目录文件夹内,并由 PGDATA 变量表示。
多节点安装
每个节点分别执行单节点安装,具体步骤参考“单节点安装”。
编译安装
获取 Yukon 源码
安装 git 工具,在 Yukon 的 Gitee 仓库获取源码,以 Yukon for openGauss 为例:
git clone https://gitee.com/opengauss/Yukon.git
准备编译环境
安装下列软件依赖包
以上安装包可以通过源码安装,也可以直接使用 yum 工具直接安装。如果还缺少其他依赖,可自行安装。
三方库的编译过程可参考 编译 。
开始编译
准备好编译环境以后,就可以开始进行编译安装:
# 如果您想使用 SFCGAL 作为 PostGIS 的处理后端,那么在准备安装环境时,需要预先安装 SFCGAL 进入Yukon目录后运行配置文件: cd Yukon ./configure --with-pgconfig=/pg_config --without-topology --without-address-standardizer \ --without-interrupt-tests CFLAGS='-O2 -fpermissive -DPGXC -pthread ' CC=g++ make make install
Note
安装时可能会提示 openGauss 目录下缺少部分头文件,此时需要从 openGauss源码库 中的 src/include 目录 下拷贝对应文件到提示的目录下,出于方便也可以直接全部覆盖。
如果在安装 gdal、 geos、 json-c、 libxml2、porj、 sfcgal时自定义了安装路径,那么运行配置文件时需要添加以下的配置选项:
--with-gdalconfig=/path/gdal-config --with-geosconfig=/path/geos-config \ --with-xml2config=/path/xml2-config --with-jsondir=/path/json-c \ --with-projdir=/path/proj4 --with-sfcgal=/path/sfcgal-config
同时,需要将这些依赖的动态库的路径添加到 /etc/ld.so.conf 文件中,然后使用
ldconfig
命令加载路径,或者将路径添加到 LD_LIARARY_PATH 环境变量中。开始使用
以上安装完成后,可以进入数据库操作。这里我们以 openGauss 为例:
--- 切换到 omm (数据库安装用户) su omm --- 连接到 postgres 数据库 gsql -d postgres
--- 创建 postgis 扩展 CREATE EXTENSION postgis; --- 创建 postgis_raster 扩展 CREATE EXTENSION postgis_raster; --- 创建 yukon_geomodel 扩展 CREATE EXTENSION yukon_geomodel; --- 创建 yukon_geogridcoder 扩展 CREATE EXTENSION yukon_geogridcoder; -- 如果在编译时支持了 SFCGAL 则可以创建 SFCGAL 扩展 CREATE EXTENSION postgis_sfcgal;
容器安装
目前 1.0.1 版本提供的 Docker 镜像如下:
supermap/yukon:1.0.1-opengauss3.1.0-amd64
supermap/yukon:1.0.1-opengauss3.1.0-arm64
supermap/yukon:1.0.1-postgresql13-amd64
启动Yukon
--Yukon for openGauss
docker run --name Yukon --privileged=true -d -e GS_PASSWORD=Bigdata@123 supermap/yukon:1.0.1-opengauss3.1.0-amd64
--Yukon for PostgreSQL
docker run --name Yukon --privileged=true -d -e POSTGRES_PASSWORD=Bigdata@123 supermap/yukon:1.0.1-postgresql13-amd64
环境变量
openGauss镜像支持以下变量的设定:
GS_PASSWORD
:【必须设置】,该参数设置了 openGauss 数据库的超级用户 omm 以及外部连接用户 gaussdb 的密码。openGauss 安装时默认会创建 omm 超级用户,测试用户 gaussdb 是在 entrypoint.sh 中自定义创建的用户,openGauss 设置的密码要符合复杂度要求:最少包含8个字符。
不能和用户名、当前密码(ALTER)、或当前密码反序相同。
至少包含大写字母(A-Z),小写字母(a-z),数字,非字母数字字符(限定为~!@#$%^&*()-_=+|[{}];:,<.>/?)四类字符中的三类字符。
GS_NODENAME
:【可选设置】,该参数设置了 openGauss 数据库的节点名称,默认为 gaussdb,可以在entrypoint.sh
中进行查看GS_USERNAME
:【可选设置】,该参数设置了 openGauss 数据库的外部连接用户名,默认为 gaussdb,可以在entrypoint.sh
中进行查看GS_PORT
:【可选设置】,该参数设置了 openGauss 数据库的连接端口,默认为 5432,可以在entrypoint.sh
中进行查看。
PostgreSQL 镜像支持以下变量的设定:
POSTGRES_PASSWORD
:【必须设置】,设置 PostgreSQL 密码
体验 Yukon
稍等片刻,等 Yukon 启动后,可以使用如下命令体验 Yukon。以 Yukon for openGauss 为例:
sudo docker exec -it Yukon /bin/bash
su omm
gsql -d postgres
连接成功后,可以看到类似如下的字符:
[omm@367dd3bb5d10 /]$ gsql -d postgres
gsql ((openGauss 2.1.0 build 590b0f8e) compiled at 2021-09-30 14:29:04 commit 0 last mr )
Non-SSL connection (SSL connection is recommended when requiring high-security)
Type "help" for help.
openGauss=#
postgres 数据库默认已经创建了 postgis , postgis_raster , postgis_sfcgal , yukon_geomodel, yukon_geogridcoder 扩展,可以直接使用。
-- 查询 yukon_geomodel 的版本及其编译时间
select yukon_version();
-- 输出 1.0.1 Compiled at:2022-12-24 08:49:42 Commit ID:e1cdae4
外部连接数据库
openGauss 的默认监听端口为 5432
,如果想要从容器外部访问数据库,则需要在 docker run
的时候指定 -p
进行端口映射:
docker run --name Yukon --privileged=true -d -e GS_PASSWORD=Bigdata@123 -p 5432:5432 supermap/yukon:1.0.1-opengauss3.1.0-amd64
现在就可以使用 openGauss 的数据库管理工具 DataStudio,或者使用开源的 DBeaver 连接数据库(第一次连接时间可能较长,需要等待数据库安装初始化完成)。
持久化存储数据
容器一旦被删除,容器内的所有数据和配置也均会丢失,而从镜像重新运行一个容器的话,则所有数据又都是呈现在初始化状态,因此对于数据库容器来说,为了防止因为容器的消亡或者损坏导致的数据丢失,需要进行持久化存储数据的操作。通过在
docker run
的时候指定 -v
参数来实现,或者可以指定已经建立好的
Volume 。使用以下命令将 openGauss 的所有数据文件存储在宿主机的
/Yukon/opengauss 下。
mkdir -p /Yukon/opengauss
docker run --name Yukon --privileged=true -d -e GS_PASSWORD=Bigdata@123 \
-v /Yukon/opengauss:/var/lib/opengauss -p 5432:5432 \
supermap/yukon:1.0.1-opengauss3.1.0-amd64
主备节点安装
如果是在 openGauss 集群下安装 Yukon,需要在主机间执行命令,传送文件等操作。
在主机之间建立互信的基础上,只需执行安装包里的脚本文件 sh install_cluster.sh -f hostfile -U username
即可(openGauss安装集群时,会在主机间建立互信,如果此时没有互信,可以再重新手动建立互信)。
hostfile
:存放有openGauss中所有主机IP的配置文件。
例: /opt/software/openGauss> vim hostfile
username
:openGauss集群所使用的安装用户,默认为omm
用户。
数据库参数修改
数据库参数的修改均位于数据目录下的 postgresql.conf
和
pg_hba.conf
两个文件中,下面为假定的配置文件所在位置:
openGauss/GaussDB
/opt/openGauss/cluster/dn1/postgresql.conf
/opt/openGauss/cluster/dn1/pg_hba.conf
PostgreSQL13
/opt/postgres13/data/postgresql.conf
/opt/postgres13/data/pg_hba.conf
修改 openGauss/GaussDB 的加密方式
对于 openGauss/GaussDB 来说,需要将其加密方式改为 MD5,否则将会导致数据库工具软件无法连接。
# openGauss/GaussDB: /opt/openGauss/cluster/dn1/postgresql.conf 将 password_encryption_type 修改为 0 ,并取消注释 password_encryption_type = 0
修改监听地址
一般情况下,我们并不会只在本地连接到数据库,也会在其他主机连接数据库,因此,我们需要修改一下监听的网卡 IP 地址,使其他主机也能够连接到数据库。这里我们修改为
*
表示监听所有网卡地址。# openGauss/GaussDB: /opt/openGauss/cluster/dn1/postgresql.conf # PostgreSQL: /opt/postgres13/data/postgresql.conf listen_addresses = '*' # what IP address(es) to listen on;
修改可接受的远程 IP 地址
一般情况下,我们会通过 IP 将数据库可接受的连接接限制在某个范围。因此我们可以在
pg_hba.conf
加入下面的一行表示可接受位于192.168.13.1/24
网段内的所有主机。如果想接受所有请求,可以将子网掩码设置为 0.# openGauss/GaussDB: /opt/openGauss/cluster/dn1/pg_hba.conf # PostgreSQL: /opt/postgres13/data/pg_hba.conf host all all 192.168.13.1/24 md5
openGauss/GaussDB 数据库提供了gs_guc工具设置配置文件(“postgresql.conf”、“pg_hba.conf”)中的参数,详见 openGauss
Note
gs_guc 工具不支持包含’.’符号的参数设置。例如:postgis.backend 无法通过 gs_guc 进行配置。可以通过 set 命令进行修改。
数据库参数修改完成后重新启动数据库,使参数生效。
验证
在本节我们会使用一款开源的数据库工具软件 DBeaver(22.3.0) 来连接数据库。
创建用户
openGauss/GaussDB
openGauss/GaussDB 在外部连接时不能使用 omm 用户,因此这里我们新建一个用户用于测试,后续您可以将其删除。
连接到数据库
gsql -d postgres -p 5432
创建用户
创建一个用户名为 test 密码为 Bigdata@123 的新用户。
CREATE USER test with PASSWORD 'Bigdata@123' SYSADMIN;
输出如下则说明创建成功:
NOTICE: The encrypted password contains MD5 ciphertext, which is not secure. CREATE ROLE
如果没有输出 MD5 的提示,请检查是否将 openGauss/GaussDB 的加密方式修改为 MD5。
PostgreSQL
连接到数据库
psql -d postgres -p 5432
创建用户
创建一个用户名为 test 密码为 Bigdata@123 的新用户。
CREATE USER test WITH PASSWORD 'Bigdata@123' Superuser;
输出如下则说明创建成功:
CREATE ROLE
新建一个 数据库连接
这里我们统一使用 PostgreSQL JDBC 来连接数据库
输入数据库连接信息
填写我们第一步创建好的用户信息
在 Host 位置写入数据库主机的 IP 地址,在 Username 写入我们刚刚创建的用户名
test
,在 Password 位置写入我们的密码Bigdata@123
。测试连接
点击左下角的 Test Connection 测试是否可以连接到数据库。如果连接成功会显示数据库的信息。第一次连接时需要下载 JDBC 驱动,点击下载即可。
openGauss/GaussDB 连接成功时,显示如下:
PostgreSQL 连接成功时,显示如下:
显示矢量数据
DBeaver 自带了显示 GIS 数据的能力,我们可以使用他来查看 GIS 数据。
首先创建 postgis 扩展
CREATE EXTENSION POSTGIS;
查询矢量数据
select 'SRID=4326;Point(116.4034318 39.9237871)'::geometry;
升级
Yukon提供扩展模块的升级功能,支持从1.0升级到当前1.0.1版本。 以Yukon for openGauss为例,操作过程:
安装新版本Yukon 1.0.1,登录到需要升级的数据库,对不同的扩展模块执行SQL:
ALTER EXTENSION name UPDATE [ TO new_version ]
比如,要将yukon_geogridcoder更新到版本 1.0.1,请执行:
#升级到最新版本
alter extension yukon_geogridcoder update;
或
#升级到指定版本
alter extension yukon_geogridcoder update to '1.0.1';
Note
建议重启数据库后再进行升级操作,以及openGauss/GaussDB需要在postgresql.conf中添加兼容参数support_extended_features=on,才能正常升级,参考 openGauss文档 。
卸载
如果使用安装包进行安装,执行 sh install.sh -r
命令即可卸载,也可以使用yk_tool -r 进行卸载,详情见 yk_tool 工具说明 。
如果使用源码进行编译安装,在源码根目录下,执行命令 make uninstall
进行卸载。
如果使用 Docker 进行安装,直接删除 Docker 容器和镜像即可。
您也可以手动检查以下三个地方查看是否有卸载残留,以openGauss为例:
$GAUSSHOME/lib/postgresql/
目录下与 postgis 和 yukon 相关的文件$GAUSSHOME/share/postgresql/extension/
目录下与 postgis 和 yukon 相关的文件$GAUSSHOME/lib
目录下是否有yukon相关的三方库文件