如何将当前的 pgAdmin 用户或当前的数据库用户记录到文件中?
How to log current pgAdmin user or current DB user to file?
我想在 pgAdmin-4(3.0 版)上进行审计跟踪,关于哪个用户 运行 哪个查询。我已将 pgAdmin 的配置设置为显示所需的日志,但它不显示当前连接的 pgAdmin 用户或当前数据库用户。它只显示记录器名称,即 pgadmin。日志示例:
2019-04-15 11:38:56,769: SQL pgadmin: Execute (async) for server #8 - CONN:2363996 (Query-id: 780067):
select * from my_table limit 5;
2019-04-15 11:38:57,135: SQL pgadmin: Polling result for (Query-id: 780067)
2019-04-15 11:38:57,136: SQL pgadmin: Execute (dict) for server #8 - DB:mydb_development (Query-id: 5477805):
这是我试过的 pgAdmin 配置 (config_local.py):
DEBUG = False
CONSOLE_LOG_LEVEL = 30
FILE_LOG_LEVEL = 25
CONSOLE_LOG_FORMAT = '%(asctime)s: %(levelname)s\t%(name)s:\t%(message)s'
FILE_LOG_FORMAT = '%(asctime)s: %(levelname)s\t%(name)s:\t%(message)s'
LOG_FILE = '/var/log/pgadmin/pgadmin4.log'
我想要的是能够打印当前使用的 pgAdmin 用户,或者如果无法完成,则只打印当前的数据库用户。
示例:
2019-04-15 11:38:56,769: SQL my_pgadmin_user: Execute (async) for server #8 - CONN:2363996 (Query-id: 780067):
select * from my_table limit 5;
或
2019-04-15 11:38:56,769: SQL my_postgres_user: Execute (async) for server #8 - CONN:2363996 (Query-id: 780067):
select * from my_table limit 5;
感谢任何帮助。谢谢
我最终修改了文件 pgadmin4/pgadmin/utils/driver/psycopg2/connection.py
上的 pgadmin 代码以显示数据库角色。
方法名称:execute_async
变化
d = self.conn.get_dsn_parameters()
current_app.logger.log(
30,
u"Execute (async) by {db_user} for server #{server_id} - {conn_id} (Query-id: "
u"{query_id}):\n{query}".format(
db_user=d['user'],
server_id=self.manager.sid,
conn_id=self.conn_id,
query=query.decode('utf-8'),
query_id=query_id
)
)
我想在 pgAdmin-4(3.0 版)上进行审计跟踪,关于哪个用户 运行 哪个查询。我已将 pgAdmin 的配置设置为显示所需的日志,但它不显示当前连接的 pgAdmin 用户或当前数据库用户。它只显示记录器名称,即 pgadmin。日志示例:
2019-04-15 11:38:56,769: SQL pgadmin: Execute (async) for server #8 - CONN:2363996 (Query-id: 780067):
select * from my_table limit 5;
2019-04-15 11:38:57,135: SQL pgadmin: Polling result for (Query-id: 780067)
2019-04-15 11:38:57,136: SQL pgadmin: Execute (dict) for server #8 - DB:mydb_development (Query-id: 5477805):
这是我试过的 pgAdmin 配置 (config_local.py):
DEBUG = False
CONSOLE_LOG_LEVEL = 30
FILE_LOG_LEVEL = 25
CONSOLE_LOG_FORMAT = '%(asctime)s: %(levelname)s\t%(name)s:\t%(message)s'
FILE_LOG_FORMAT = '%(asctime)s: %(levelname)s\t%(name)s:\t%(message)s'
LOG_FILE = '/var/log/pgadmin/pgadmin4.log'
我想要的是能够打印当前使用的 pgAdmin 用户,或者如果无法完成,则只打印当前的数据库用户。
示例:
2019-04-15 11:38:56,769: SQL my_pgadmin_user: Execute (async) for server #8 - CONN:2363996 (Query-id: 780067):
select * from my_table limit 5;
或
2019-04-15 11:38:56,769: SQL my_postgres_user: Execute (async) for server #8 - CONN:2363996 (Query-id: 780067):
select * from my_table limit 5;
感谢任何帮助。谢谢
我最终修改了文件 pgadmin4/pgadmin/utils/driver/psycopg2/connection.py
上的 pgadmin 代码以显示数据库角色。
方法名称:execute_async 变化
d = self.conn.get_dsn_parameters()
current_app.logger.log(
30,
u"Execute (async) by {db_user} for server #{server_id} - {conn_id} (Query-id: "
u"{query_id}):\n{query}".format(
db_user=d['user'],
server_id=self.manager.sid,
conn_id=self.conn_id,
query=query.decode('utf-8'),
query_id=query_id
)
)