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地址
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 官方手册
【编辑推荐】