前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PostgreSQL之Foreign Data Wrappers使用指南

PostgreSQL之Foreign Data Wrappers使用指南

作者头像
星哥玩云
发布2022-08-17 16:54:25
5340
发布2022-08-17 16:54:25
举报
文章被收录于专栏:开源部署开源部署

PostgreSQL的fdw实现的功能是各个postgresql数据库及远程数据库之间的跨库操作,功能和Oracle的dblink一样。 本文中的环境如下图所示:

PostgreSQL之Foreign Data Wrappers使用指南
PostgreSQL之Foreign Data Wrappers使用指南
1.1、目标端安装软件包
代码语言:javascript
复制
[root@hdp06 ~]# yum -y install postgresql10-contrib.x86_64
1.2、目标端创建用户

这里的源端不需要创建用户。因为源端已经存在了一个rhnuser用户,直接使用。根据实际情况赋予用户权限,一般就是select、update、delete以及insert。这里的用户已经拥有这些权限了,所以不需要再赋予权限。

代码语言:javascript
复制
postgres=# CREATE USER rhnadmin WITH password 'RedHat' CREATEDB SUPERUSER replication bypa***ls createrole login;
1.3、目标端安装Postgres_fdw
代码语言:javascript
复制
postgres=# create extension postgres_fdw;
CREATE EXTENSION
postgres=# \dx postgres_fdw
PostgreSQL之Foreign Data Wrappers使用指南
PostgreSQL之Foreign Data Wrappers使用指南
1.4、赋予用户权限
代码语言:javascript
复制
postgres=# grant usage on FOREIGN DATA WRAPPER postgres_fdw to rhnadmin;
1.5、创建服务器定义
代码语言:javascript
复制
postgres=# CREATE SERVER rhnsrv FOREIGN DATA WRAPPER postgres_fdw OPTIONS (dbname 'rhnschema', host 'oln', port '5432');
postgres=# GRANT USAGE ON FOREIGN SERVER rhnsrv TO rhnadmin;
PostgreSQL之Foreign Data Wrappers使用指南
PostgreSQL之Foreign Data Wrappers使用指南
1.6、创建用户映射
代码语言:javascript
复制
rhnschema=# CREATE USER MAPPING for rhnadmin SERVER rhnsrv OPTIONS (user 'rhnuser', password 'redhat');
PostgreSQL之Foreign Data Wrappers使用指南
PostgreSQL之Foreign Data Wrappers使用指南
1.7、修改pg_hba文件

如下图所示,允许特定网段的机器访问。这里全部放开。

PostgreSQL之Foreign Data Wrappers使用指南
PostgreSQL之Foreign Data Wrappers使用指南
1.8、导入源端schema
代码语言:javascript
复制
rhnschema=# IMPORT FOREIGN SCHEMA "public" FROM SERVER rhnsrv INTO public;
ERROR:  type "public.evr_t" does not exist
--首次导入报错了,因为目标端没有创建evr_t类型,使用下面的语句创建类型再次导入。
rhnschema=# CREATE TYPE evr_t AS (epoch character varying(16),version character varying(512),release character varying(512));
rhnschema=# ALTER TYPE public.evr_t OWNER TO rhnadmin;
rhnschema=# IMPORT FOREIGN SCHEMA public FROM SERVER rhnsrv INTO public;
IMPORT FOREIGN SCHEMA

如果只想导入个别表,需要使用下面的语法:

代码语言:javascript
复制
rhnschema=# IMPORT FOREIGN SCHEMA "public" limit to (rhnpackagefile) FROM SERVER rhnsrv INTO public;
1.9、查询验证

导入完成后,可以查询pg_foreign_table表,获取已导入的表名称信息:

代码语言:javascript
复制
rhnschema=# select *from pg_foreign_table;
rhnschema=# select *from log limit 20;
PostgreSQL之Foreign Data Wrappers使用指南
PostgreSQL之Foreign Data Wrappers使用指南
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.1、目标端安装软件包
  • 1.2、目标端创建用户
  • 1.3、目标端安装Postgres_fdw
  • 1.4、赋予用户权限
  • 1.5、创建服务器定义
  • 1.6、创建用户映射
  • 1.7、修改pg_hba文件
  • 1.8、导入源端schema
  • 1.9、查询验证
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档