CentOS plproxy查询安装pgsql编译源码

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

pgCluster全热备集群都读写每台节点都保持数据完整  


pg Slony-I or II主从集群从只读主读写  


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

CREATE OR REPLACE FUNCTION plproxyget_cluster_partitions(cluster_name text)  


RETURNS SETOF text AS $$  


BEGIN  



IF cluster_name = 'MyCluster' THEN  




RETURN NEXT 'dbname=test1 host=1921681190';<----节点ip  




RETURN NEXT 'dbname=test2 host=1921681193';<----节点ip 
RETURN;  


END IF;  


RAISE EXCEPTION 'Unknown cluster';  


END;  


$$ LANGUAGE plpgsql; 
CREATE OR REPLACE FUNCTION plproxyget_cluster_version(cluster_name text)  


RETURNS int4 AS $$  


BEGIN  



IF cluster_name = 'MyCluster' THEN  



RETURN 1;  


END IF;  


RAISE EXCEPTION 'Unknown cluster';  


END;  


$$ LANGUAGE plpgsql; 
create or replace function plproxyget_cluster_config(cluster_name text, out key text, out val text)  


returns setof record as $$  


begin  



key := 'statement_timeout';  




val := 60;  



return next;  


return;  


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地址

相关推荐