WEB开发网
开发学院操作系统CentOS CentOS plproxy查询安装pgsql编译源码 阅读

CentOS plproxy查询安装pgsql编译源码

 2010-05-08 23:01:41 来源:WEB开发网   
核心提示:CentOS plproxy经过长时间的发展,这里我发表一下个人理解,CentOS plproxy查询安装pgsql编译源码,下面就这就来讲术CentOS plproxy,CentOS plproxy需求: 工作需要3种集群模式.pgCluster全热备集群都读写每台节点都保持数据完整 pg Slony-I or I

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 官方手册

Tags:CentOS plproxy 查询

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接