django - 解释 django 项目中的 pgbouncer 日志条目

标签 django pgbouncer

我在我的 Django Web 应用程序中使用 pgbouncer。应用服务器和数据库服务器是两个独立的虚拟机。 pgbouncer 安装在应用服务器上。 pgbouncer.ini 中的相关设置是:

[databases]
dbname = host=80.211.128.113 port=5432 dbname=dbname

pool_mode = transaction
max_client_conn = 250
default_pool_size = 100

pgbouncer 接手后,我检查了 pgbouncer.log 并发现了很多条目,如下所示:
2016-11-15 12:26:27.514 582 LOG S-0x1192740: dbname/myuser@80.211.128.113:5432 new connection to server
2016-11-15 12:26:27.517 582 LOG C-0x11afcb8: dbname/myuser@127.0.0.1:42262 login attempt: db=dbname user=myuser
2016-11-15 12:26:27.523 582 LOG S-0x1192a10: dbname/myuser@80.211.128.113:5432 new connection to server
2016-11-15 12:26:27.528 582 LOG C-0x11af880: dbname/myuser@127.0.0.1:42250 closing because: client close request (age=0)
2016-11-15 12:26:27.528 582 LOG S-0x1191a98: dbname/myuser@80.211.128.113:5432 closing because: unclean server (age=0)
2016-11-15 12:26:27.548 582 LOG C-0x11afb50: dbname/myuser@127.0.0.1:42258 closing because: client close request (age=0)
2016-11-15 12:26:27.556 582 LOG C-0x11aff88: dbname/myuser@127.0.0.1:42256 closing because: client close request (age=0)
2016-11-15 12:26:27.556 582 LOG S-0x1191c00: dbname/myuser@80.211.128.113:5432 closing because: unclean server (age=0)
2016-11-15 12:26:27.564 582 LOG C-0x11aff88: dbname/myuser@127.0.0.1:42264 login attempt: db=dbname user=myuser
2016-11-15 12:26:27.569 582 LOG C-0x11afb50: dbname/myuser@127.0.0.1:42265 login attempt: db=dbname user=myuser
2016-11-15 12:26:27.570 582 LOG S-0x1191c00: dbname/myuser@80.211.128.113:5432 new connection to server
2016-11-15 12:26:27.593 582 LOG C-0x11af448: dbname/myuser@127.0.0.1:42255 closing because: client close request (age=0)
2016-11-15 12:26:27.593 582 LOG C-0x11afcb8: dbname/myuser@127.0.0.1:42262 closing because: client close request (age=0)
2016-11-15 12:26:27.593 582 LOG S-0x1191c00: dbname/myuser@80.211.128.113:5432 closing because: unclean server (age=0)
2016-11-15 12:26:27.597 582 LOG C-0x11afb50: dbname/myuser@127.0.0.1:42265 closing because: client close request (age=0)
2016-11-15 12:26:27.603 582 LOG C-0x11afb50: dbname/myuser@127.0.0.1:42267 login attempt: db=dbname user=myuser
2016-11-15 12:26:27.604 582 LOG C-0x11afcb8: dbname/myuser@127.0.0.1:42268 login attempt: db=dbname user=myuser

如果仔分割析,可以在日志文件中找到许多 closing because: unclean serverclosing because: client close request 的实例。谁能解释一下这些是什么?也许我做错了什么。从表面上看,到目前为止,我的应用程序似乎运行正常。但我需要了解我在日志文件中看到的内容,以便确定是什么。提前致谢。

最佳答案

  • LOG C - 带有此 header 的日志与连接到的客户端有关
    pgbouncer(不是 postgresql 服务器)。
  • LOG S - 关于
    pgbouncer 和服务器之间的通信(真正的连接到
    posgres 服务器)。
  • age=0 - 告诉使用时间,即带有 LOG Cage=0
    意味着客户端使用连接的时间不到一秒钟。


  • 答案 :

    closing because: client close request



    没什么好担心的,完全正常。它记录了客户端已经相当,即客户端不再有与 pgbouncer 的实时连接。

    通常日志类似于 :

    第一次尝试连接到 pgbouncer

    第 1 行 - 尝试连接 pgbouncer。

    第 2 行 - pgbouncer 尝试连接到 postgresql 服务器。

    第 3 行 - 客户端请求完成并关闭 client-pgbouncer 连接
    2016-11-15 12:26:27.517 582 LOG C-0x11afcb8: dbname/myuser@127.0.0.1:42262 login attempt: db=dbname user=myuser
    2016-11-15 12:26:27.523 582 LOG S-0x1192a10: dbname/myuser@80.211.128.113:5432 new connection to server
    2016-11-15 12:26:27.528 582 LOG C-0x11af880: dbname/myuser@127.0.0.1:42250 closing because: client close request (age=0)
    

    第 1 行 - 新客户端尝试连接 pgbouncer。它将重用已经打开的到 postgresql 服务器的连接(为最后一个客户端打开)

    第 2 行 - 客户端请求完成且客户端-pgbouncer 连接关闭
    2016-11-15 12:26:27.569 582 LOG C-0x11afb50: dbname/myuser@127.0.0.1:42265 login attempt: db=dbname user=myuser
    2016-11-15 12:26:27.593 582 LOG C-0x11af448: dbname/myuser@127.0.0.1:42255 closing because: client close request (age=0)
    

    Line 1 & 2 - 2 并发客户端尝试连接到 pgbouncer

    第 3 行 - pgbouncer 尝试第二次连接 postgresql 服务器,用于第二个客户端(第一个将重新使用已经打开的客户端)

    第 4 行和第 5 行 - 客户端请求完成并关闭客户端-pgbouncer 连接
    2016-11-15 12:26:27.564 582 LOG C-0x11aff88: dbname/myuser@127.0.0.1:42264 login attempt: db=dbname user=myuser
    2016-11-15 12:26:27.569 582 LOG C-0x11afb50: dbname/myuser@127.0.0.1:42265 login attempt: db=dbname user=myuser
    2016-11-15 12:26:27.570 582 LOG S-0x1191c00: dbname/myuser@80.211.128.113:5432 new connection to server
    2016-11-15 12:26:27.593 582 LOG C-0x11af448: dbname/myuser@127.0.0.1:42255 closing because: client close request (age=0)
    2016-11-15 12:26:27.593 582 LOG C-0x11afcb8: dbname/myuser@127.0.0.1:42262 closing because: client close request (age=0)
    

    closing because: unclean server



    可能是一个问题,因为 pgbouncer 似乎正在获取和关闭与 postgres 服务器的新连接,每个新客户端都连接到它(pgbouncer)。

    可能的解决方案 /way-out - 可能与 Django works by default 的方式有关。

    与普通池一样,pgbouncer 不能关闭它与 postgres 服务器的连接(在关闭客户端连接时) - 当连接可能到达 server_lifetimeserver_idle_timeout 空闲时,您可能会收到此服务器连接关闭消息/日志,否则不会。

    关于django - 解释 django 项目中的 pgbouncer 日志条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40610456/

    相关文章:

    python - Django 休息框架 : redirect to Amazon S3 fails when using Token Authentication

    ruby-on-rails - 在 Rails 中禁用连接池以使用 PgBouncer

    php - 是否可以检测到 PHP 通过 PgBouncer 池连接到 PostgreSQL 数据库?

    postgresql - Golang - pgbouncer 和事务使用

    python - django queryset values()方法字段顺序与返回的顺序不同

    python - 每天使用 Django Models 添加新数据

    python - Tastypie 与 Django 1.8 给出内容类型未找到错误

    python - Django 'type' 对象不可迭代

    postgresql - pq 驱动程序 : prepared statement does not exist

    postgresql - 准备好的语句不存在