CentOS plproxy查询安装pgsql编译源码

系统 Linux
安装CentOS plproxy只在proxy上安装,node不用安装解包make && make install添加CentOS plproxy支持psql -f /usr/local/pgsql/share/contrib/plproxysql 数据库名在P1上创建schema psql testproxy 用psql客户端连接数据库create schema plproxy; 生成schemavi MyClusterInitsql,然后把下面的内容保存:(去掉注释)begin

CentOS plproxy经过长时间的发展,这里我发表一下个人理解,下面就这就来讲术CentOS plproxy。CentOS plproxy需求: 工作需要3种集群模式.

  1. pgCluster全热备集群都读写每台节点都保持数据完整  
  2. pg Slony-I or II主从集群从只读主读写  
  3. pg plporxy分流特性负载平衡分布到节点上 

目的: 在 CentOS plproxy 上做查询,从node返回结果环境: 3台centos:  1台做CentOS plproxy   2台做node步骤: 如下:
 
1 安装pgsql,所有pgsql都要装版本3xx编译源码,rpm 都可以安装方法看readme或者install文档源码安装默认都装在/usr/local/pgsql/下处理一下环境变量的问题export PATH=$PATH:/usr/local/pgsql/bin初始化数据库目录initdb -D /usr/local/pgsql/data
  
生成一个数据库createdb 数据库名添加plpgsql语言支持createlang plpgsql 数据库名修改 pgsql 的配置文件vi /usr/local/pgsql/data/postgresqlconf取消注释listen_addresses = '*'port = 5432添加用户认证host 数据库名 用户名 ip地址 trust
  
2   安装CentOS plproxy只在proxy上安装,node不用安装解包make && make install添加CentOS plproxy支持psql -f /usr/local/pgsql/share/contrib/plproxysql 数据库名在P1上创建schema psql testproxy 用psql客户端连接数据库create schema plproxy; 生成schemavi MyClusterInitsql,然后把下面的内容保存:(去掉注释)begin

  1. CREATE OR REPLACE FUNCTION plproxyget_cluster_partitions(cluster_name text)  
  2. RETURNS SETOF text AS $$  
  3. BEGIN  
  4. IF cluster_name = 'MyCluster' THEN  
  5. RETURN NEXT 'dbname=test1 host=1921681190';<----节点ip  
  6. RETURN NEXT 'dbname=test2 host=1921681193';<----节点ip 
  1. RETURN;  
  2. END IF;  
  3. RAISE EXCEPTION 'Unknown cluster';  
  4. END;  
  5. $$ LANGUAGE plpgsql; 
  1. CREATE OR REPLACE FUNCTION plproxyget_cluster_version(cluster_name text)  
  2. RETURNS int4 AS $$  
  3. BEGIN  
  4. IF cluster_name = 'MyCluster' THEN  
  5. RETURN 1;  
  6. END IF;  
  7. RAISE EXCEPTION 'Unknown cluster';  
  8. END;  
  9. $$ LANGUAGE plpgsql; 
  1. create or replace function plproxyget_cluster_config(cluster_name text, out key text, out val text)  
  2. returns setof record as $$  
  3. begin  
  4. key :'statement_timeout';  
  5. val :60;  
  6. return next;  
  7. return;  
  8. end; $$ language plpgsql; 

end psql -f MyClusterInitsql -d testproxy执行上述sql语句以上CentOS plproxy设置完成开始节点的设置:给每个节点都创建一个函数:方法同上:

vi到一个文件中,然后执行这个文件内容如下:
begin create or replace function publicdquery(query text) returns setof record as $$declare   ret record;beginfor ret in execute query loopreturn next ret;end loop;return;end;$$ language plpgsql;create or replace function publicddlExec(query text) returns integer as $$declare   ret integer;begin execute query;   return 1;end;$$ language plpgsql;create or replace function publicdmlExec(query text) returns integer as $$declare   ret integer;begin execute query;   return 1;end;$$ language plpgsql; end psql -f 这个文件名 -d database name -h ip地址

4 然后在proxy上建立相同的函数,用于集群检索建立,执行方法同上:
CREATE OR REPLACE FUNCTION publicdquery(query text) RETURNS setofrecord AS $$CLUSTER 'MyCluster';RUN ON ALL;$$ LANGUAGE CentOS plproxy;CREATE OR REPLACE FUNCTION publicddlexec(query text) RETURNS setof integerAS $$CLUSTER 'MyCluster';RUN ON ALL;$$ LANGUAGE CentOS plproxy;CREATE OR REPLACE FUNCTION publicdmlexec(query text) RETURNS setof integerAS $$CLUSTER 'MyCluster';RUN ON ANY;$$ LANGUAGE plproxy; done  

5 CentOS plproxy测试   方法:在proxy,nodes上建立相同的表   用select,insert,del 在proxy执行然后每个node上都有响应   代码: select * from publicddlexec( 'create table usertable(id primary key,username varchar(20)'   );在数据节点上生成一个表usertable,然后可以插入一些数据测试:
select * from publicddlexec(
'insert into usertable(id,username) values(1,'aaa')');
  
 6 CentOS plproxy如果失败请:  参考 pgsql 官方手册

【编辑推荐】

  1. CentOS SYN Flood攻击原理Linux下设置
  2. CentOS VNC试验用的工控机不支持鼠标
  3. CentOS gcc安装问题的解决方法
  4. CentOS系统是Linux常见版本之一
  5. CentOS PPPOE安装配置客户端软件和前提条件
责任编辑:佚名 来源: CSDN
相关推荐

2021-01-04 08:15:16

CentOS 7Python3.9Python

2011-02-24 15:04:58

ProftpdCentos

2010-01-13 16:55:10

CentOS PHP安

2010-01-13 15:07:51

2010-01-15 20:59:54

2010-02-23 14:45:52

CentOS LEMP

2010-06-02 13:05:14

Sendmail 安装

2010-01-14 16:53:40

CentOS Apac

2013-04-10 15:12:03

MySQL 5.6

2010-01-13 16:46:44

CentOS Apac

2021-06-08 07:49:29

MySQL数据库索引

2010-01-15 10:16:50

CentOS rpm安

2010-04-01 13:37:24

CentOS系统5

2010-01-13 14:18:36

CentOS Open

2017-03-20 15:08:04

RedisNoSQLcentos6

2010-02-03 09:26:52

Linux Mysql

2010-01-15 20:43:42

CentOS PHP编

2010-02-22 16:09:18

CentOS安装

2010-01-13 10:14:45

2010-01-15 17:35:09

点赞
收藏

51CTO技术栈公众号