概述
本地集群 123.249.4.215
源集群(想要访问的集群 )43.143.154.123
目标:本地集群与源集群是两个独立集群,通过DBlink能够实现本地集群可以直接访问源集群的数据
安装透明网关(可以装在本地集群节点 或者 新增一个节点)
[gbase@hw-01 ~]$ cd /opt/
[gbase@hw-01 opt]$ ll
-rw-r--r-- 1 gbase gbase 182435840 Nov 12 17:01 GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14.tar
[gbase@hw-01 opt]$ tar -xvf GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14.tar
[gbase@hw-01 opt]$ chmod -R +x GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14
修改透明网关系统配置文件
[gbase@hw-01 conf]$ cd /opt/GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14/conf/
[gbase@hw-01 conf]$ vi conf.properties
gbase.gt.load.data.type=0
gbase.gt.gc.paging.query=1
配置源库
[gbase@hw-01 opt]$ cd GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14/conf/dataSource/sample
[gbase@hw-01 sample]$ cp gbase_link1.properties gbase_link1.properties.bak
[gbase@hw-01 sample]$ vi gbase_link1.properties
[gbase@hw-01 sample]$ cp gbase_link1.properties /opt/GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14/conf/dataSource
[gbase8a cluster]
dataSource_IP=43.143.154.123 #这里写源集群的IP 也就是想要访问的集群
dataSource_port=5258
dataSource_dbname=test #这里写想要访问的数据库,如果没有 记得先创建
dataSource_dbtype=gcluster
dataSource_user=gbase
dataSource_pwd=gbase20110531
dataSource_charset=utf8
启动透明网关
[gbase@hw-01 sample]$ cd /opt/GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14
[gbase@hw-01 GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14]$ sh gt.sh
停止透明网关(这是笔记 不要执行)
[gbase@hw-01 GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14]$ ps -ef | grep GBaseGateway
[gbase@hw-01 GBase8a_MPP_Cluster_Gateway_8.5.1.2_build4.14]$ kill -9 18787
配置DBlink(本地集群)
[gbase@hw-01 gcluster]$ cd /opt/gbase/192.168.0.213/gcluster/config
[gbase@hw-01 config]$ cp gbase_8a_gcluster.cnf gbase_8a_gcluster.cnf.bak
[gbase@hw-01 config]$ vi gbase_8a_gcluster.cnf
[gbased]
gbase_dblink_gateway_ip = 124.249.4.215 #这里写透明网关的IP
gbase_dblink_gateway_port = 9898
gcluster_dblink_direct_data_exchange = 0 #局域网内两个集群可以相互通信时 可以不加这个参数
值为 1 表示:数据从数据源集群的计算节点直接发送给目标集群。
值为 0 表示:数据从数据源集群发送给网关,然后由网关转发给目标集群。
注:仅当数据源集群和目标集群的节点间在网络上不可直接连接时,调整此参数为 0。
开放端口
[root@hw-01 ~]# firewall-cmd --zone=public --add-port=9898/tcp --permanent
[root@hw-01 ~]# firewall-cmd --reload
重启服务
[gbase@hw-01 gcluster]$ gcluster_services all restart
[gbase@hw-01 gcluster]$ gcware_services all restart
源集群创建测试库 (DBlink要访问的节点)
43.143.154.123节点
[gbase@tx gcinstall]$ gccli -uroot -p
gbase> create database test;
gbase> use test;
gbase> create table t1(no int);
gbase> insert into t1 values(1);
本地集群使用DBlink访问源集群
[gbase@hw-01 gcluster]$ gccli -uroot -p
gbase> create database test;
Query OK, 1 row affected (Elapsed: 00:00:00.00)
gbase> create database link dblink_test1 connect to '' identified by '' using 'gbase_link1'; --注意这里的名称要跟上面源配置文件名称保持一致 gbase_link1.properties
Query OK, 0 rows affected (Elapsed: 00:00:00.00)
gbase> select * from gbase.db_links;
+--------+--------------+-------------+----------+----------+-------------+---------------------+
| owner | db_link | dblink_priv | username | password | host | created |
+--------+--------------+-------------+----------+----------+-------------+---------------------+
| public | dblink_test1 | PUBLIC | | NULL | gbase_link1 | 2022-11-14 21:05:20 |
+--------+--------------+-------------+----------+----------+-------------+---------------------+
1 row in set (Elapsed: 00:00:00.00)
gbase> use test;
Query OK, 0 rows affected (Elapsed: 00:00:00.00)
gbase> select * from t1;
ERROR 1146 (42S02): Table 'test.t1' does not exist
gbase> select * from t1@dblink_test1;
+------+
| no |
+------+
| 1 |
+------+
1 row in set (Elapsed: 00:00:00.10)
最后
以上就是无聊红牛为你收集整理的GBase 8a DBlink配置(跨集群访问)的全部内容,希望文章能够帮你解决GBase 8a DBlink配置(跨集群访问)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复