一、Pgbouncer 的介绍

  • Pgbouncer是一个针对PostgreSQL数据库的轻量级连接池,任何目标应用都可以把 pgbouncer 当作一个 PostgreSQL 服务器来连接,然后pgbouncer 会处理与服务器连接,或者是重用已存在的连接。
  • pgbouncer 的目标是降低因为新建到 PostgreSQL 的连接而导致的性能损失。

二、PgBouncer的作用

  • PgBouncer可以在后端数据库和前端应用间建立连接的桥梁,由PgBouncer去处理和后端数据库的连接关系。

  • 对客户端连接进行限制,预防过多或者恶意的连接请求。

三、概念图(下图很形象)

四、 PgBouncer的优点

  • 内存消耗低(默认为2k/连接),因为Bouncer不需要每次都接受完整的数据包
  • 可以把不同的数据库连接到一个机器上,而对客户端保持透明
  • 支持在线的重新配置而无须重启
  • pgbouncer 可以限制每一对用户+数据库 到PostgreSQL Cluster的总连接数

五、 PgBouncer缺点

  • 仅支持V3协议,因此后端版本须>=7.4

  • 并没有真正实现数据库的负载均衡,如果单一的对一个数据库操作会使某个数据节点读写量增大
  • 当某个数据库down掉后,就不能通过pgbouncer连接起来,缺少了数据库备份的功能

六、总结

  • 主要工作还是每一个数据节点对数据的存取,pgbouncer只是提供给客户端数据节点的分配和链接以及限制客户端连接的数量。
  • 但整体上实现了对数据的负载均衡

七、重要的配置文件(例子)

[databases]

osdba=host=127.0.0.1 port=5432 user=osdba dbname=osdb

  • “本句话说明该pgbouncer创建了针对127.0.0.1的osdb的一个连接池,该链接池对调用方的呈现的数据库名称是osdba,它映射到本机的osdb数据库上。所有访问pgbouncer上的osdba的请求都会转到osdb上完成。这意味着,客户端通过pgbouncer单次连接时,只能连接到某台主机上的某个数据库”

postgres1= host= 192.168.12.32 port=5432 user=ddong dbname=template1

postgres2=host=192.168.12.33 port=5432 user=ddong dbname=template1

[pgbouncer]

listen_port=64321

listen_addr=127.0.0.1

auth_type=md5

auth_file=users.txt

logfile=pgbouncer.log

pidfile=pgbouncer.pid

admin_users = bntest

  • 在装有psql的机器上使用命令:psql -h 127.0.0.1 -p 64321 -U <用户名> <数据库名>(如数据库:osdba、postgres1、postgres2)

  • 用户名为users.txt文件里的用户
  • 如:psql -h 127.0.0.1 -p 64321 -U ddong postgres1 即通过pgbouncer登录到主机为192.168.12.32的数据库为template1的机器上
  • Pgbouncer的配置文件有映射关系,如上例所示

八、手册参考

九、注意事项

  • 基于pgbouncer的数据库集群 以上配置文件和参考文档针对软件包:PostgreSQL-9.0.13.tar.gz pgbouncer-1.3.4.tgz
  • 安装完成后,须有bin目录和lib目录下的环境变量配置,安装目录所属用户

pgbouncer介绍的更多相关文章

  1. PL/Proxy介绍

    PL/Proxy 介绍 一.概述 1.PL/Proxy 是一个采用PL Language语言的数据库分区系统. 目的:轻松访问分区数据库 它的理念是代理远程函数体内指定.函数调用同样标签创建的函数,所 ...

  2. 使用PgBouncer连接池

    1.pgbouncer 的介绍 pgbouncer是一个针对PostgreSQL数据库的轻量级连接池,任何目标应用都可以把 pgbouncer 当作一个 PostgreSQL/Greenplum 服务 ...

  3. PostgreSQL Replication之第八章 与pgbouncer一起工作(5)

    8.5 维护 pgbouncer 除了我们在本章已经说明的,pgbouncer有一个很好的能够执行基本管理和监控任务的交互式管理界面. 它是如何工作的呢?pgbouncer提供给您一个虚假的称为pgb ...

  4. PostgreSQL Replication之第八章 与pgbouncer一起工作(4)

    8.4 提升性能 从一开始考虑pgbouncer的时候,性能就是一个关键的因素.为了确保高性能,有些问题必须认真对待.首先,确保参与您设置的所有节点相互之间的距离较近.这对于降低网络往返时间有很多的帮 ...

  5. CSS3 background-image背景图片相关介绍

    这里将会介绍如何通过background-image设置背景图片,以及背景图片的平铺.拉伸.偏移.设置大小等操作. 1. 背景图片样式分类 CSS中设置元素背景图片及其背景图片样式的属性主要以下几个: ...

  6. MySQL高级知识- MySQL的架构介绍

    [TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...

  7. Windows Server 2012 NIC Teaming介绍及注意事项

    Windows Server 2012 NIC Teaming介绍及注意事项 转载自:http://www.it165.net/os/html/201303/4799.html Windows Ser ...

  8. Linux下服务器端开发流程及相关工具介绍(C++)

    去年刚毕业来公司后,做为新人,发现很多东西都没有文档,各种工具和地址都是口口相传的,而且很多时候都是不知道有哪些工具可以使用,所以当时就想把自己接触到的这些东西记录下来,为后来者提供参考,相当于一个路 ...

  9. JavaScript var关键字、变量的状态、异常处理、命名规范等介绍

    本篇主要介绍var关键字.变量的undefined和null状态.异常处理.命名规范. 目录 1. var 关键字:介绍var关键字的使用. 2. 变量的状态:介绍变量的未定义.已定义未赋值.已定义已 ...

随机推荐

  1. 自定义MapReduce的类型

    package org.apache.hadoop.mapreduce.io; import java.io.DataInput; import java.io.DataOutput; import ...

  2. 网页引导:jQuery插件实现的页面功能介绍引导页效果

    现在很多网站不仅是介绍,更多的是有一些功能,怎么样让客户快速的知道网站有哪些功能呢?这里pagewalkthrough.js插件能帮我们实现,它是一个轻量级的jQuery插件,它可以帮助我们创建一个遮 ...

  3. 一起找bug

    帮同学找的一个bug,错误代码如下: package dai_test; public class Test1 { public static void main(String[] args) { / ...

  4. Linux中服务器软件为什么需要编译安装

    为什么服务器软件需要编译安装?一个流传很广的说法是编译安装性能更好,其实这是个谣言. 服务器CPU事实已经被Intel垄断了,就那么几种型号,编来编去生成的机器码是一样的.Intel宣传自己的编译工具 ...

  5. [译]Node.js : Building RESTful APIs using Loopback and MySQL

    国庆后可能就要使用StrongLoop那套东西来做项目了 原文:http://www.javabeat.net/loopback-mysql/ Loopback是什么? Loopback是一个开源的N ...

  6. 笔记之Python网络数据采集

    笔记之Python网络数据采集 非原创即采集 一念清净, 烈焰成池, 一念觉醒, 方登彼岸 网络数据采集, 无非就是写一个自动化程序向网络服务器请求数据, 再对数据进行解析, 提取需要的信息 通常, ...

  7. 使用Javascript实现返回顶部功能。

    为了提高网站的浏览体验及友好度,相信大部分网站需要一个返回顶部的按钮,如果使用传统的a标记,再做一个div加上链接的话,非常麻烦,不仅每个页面都需要添加,而且不能实现非常智能的效果及简化维护时间. 下 ...

  8. C#深入浅出 C#语法中的重中之重——委托(四)

    入行半年多了,委托干什么用的还不知道,真心说不过去了,关键对这东西有点恐惧,主要是被老师吓的,记得我C#专业课老师在讲到委托时,原话是这样的,同学们,委托这个地方是难点,暂时不讲,讲了你也不懂,等你有 ...

  9. POJ 2115 C Looooops

    扩展GCD...一定要(1L<<k),不然k=31是会出错的 ....                        C Looooops Time Limit: 1000MS   Mem ...

  10. PHP函数preg_replace() 正则替换所有符合条件的字符串

    PHP preg_replace() 正则替换,与JavaScript 正则替换不同,PHP preg_replace() 默认就是替换所有符号匹配条件的元素. preg_replace (正则表达式 ...