今天碰到了一个问题,锁定穷根追底把postgresql的锁研究了一番。

数据库查看锁

可以通过表 pg_locks来查看有哪些锁。sql如下:

select a.locktype,a.database,a.pid,a.mode,a.relation,b.relname
from pg_locks a
join pg_class b on a.relation = b.oid and b.relname not like 'pg%';

可以通过pg_stat_query表找到具体的sql,根据pid,正如文档2里面所说,很鸡肋,木有神马作用。顶多知道出于神马状态。

 锁的定位一般步骤

鉴于这次的问题发生在“idle in transaction”, 因此针对这个具体做了下攻关:(参考文档2)

1. 设置PostgreSQL\x.x\data\下的postgresql.conf文件中的两个参数:

log_line_prefix , 日志行的前缀(支持比较多的参数,具体看conf文件后面的说明。修改为 '%m %u@%d %p'。

log_min_duration_statement , 是否记录所有的sql,默认为-1,即不记录,0则为记录。修改为0

2. 这一步可以不做。 清空原来的日志,位于PostgreSQL\x.x\data\pg_log下面。需要先停掉postgres然后再开启。便于我们观察不受影响。

3. 重复你产生问题的操作。

4. 定位哪些sql操作时间比较长。(可能需要制作一个工具分析下日志得到报表)

5. 定位具体有问题的代码。

参考:

文档1:http://blog.sina.com.cn/s/blog_79d599dc0100qpra.html

文档2:http://www.depesz.com/2008/08/28/hunting-idle-in-transactions/

文档3:http://blog.sina.com.cn/s/blog_544a710b01019u1f.html  (pg_stat_query表结构参考)

附录:

python+django.db快速将日志导入数据表中源码:

sqldb.py

#coding=utf-8
__author__ = 'tommy.yu' from django.db import connection
from django.conf import settings settings.configure(
DATABASES = { 'default': {
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'NAME': 'django',
'USER': 'openerp',
'PASSWORD': '1',
'HOST': 'localhost',
'PORT': '5432',
}, },
TIME_ZONE = 'Hongkong'
) class cursor(object):
def __init__(self):
self.cr = connection.cursor() def query(self,sql):
self.cr.execute(sql)
res = self.cr.fetchall()
self.cr.close()
return res def un_query(self,sql):
return self.cr.execute(sql)

main.py

#coding=utf-8
__author__ = 'tommy.yu'
from sqldb import cursor
import os class odoo_sql_log2db(object):
def __init__(self,log_dir, delimiter, db_table):
self.table=db_table
self.delimiter = delimiter
self.log_dir = log_dir
self.cr = cursor()
# self.cr.un_query("""
# create table %s (
# sql text,
# dura float
# );
# """%self.table) def _sync_line(self, line):
res = {}
#FORMAT EG.
#2014-11-17 16:19:27.965 HKT openerp@ES_IT_TEST 3376日志: 执行时间: 0.000 ms 语句: SELECT nextval('mail_message_id_seq')
try:
t = line.split(': ',3)
if t:
res.update(sql = t[-1])
res.update(dura = t[-2].split(' ')[0])
res.update(ret = self.cr.un_query("""insert into %s(sql, dura) values ('%s', %s)"""%(self.table, res.get('sql').replace('\'','‘'), float(res.get('dura')))))
return res
except Exception,ex:
print ex.message def parse_log(self, file_name):
data = []
line = ''
with open(file_name) as f:
for temp_line in f:
if not temp_line.startswith(self.delimiter):
line += ' '+ temp_line
else:
if line:
data.append(self._sync_line(line))
line = temp_line
return data def parse_logs(self):
#os.path.dirname(self.log_dir)
for (cur, dirs, files) in os.walk(self.log_dir):
for fname in files:
log_path = os.path.join(self.log_dir,cur,fname)
print('begin parsing data for file %s .................................'%fname)
res= self.parse_log(log_path)
print('job done. %s records of log file %s have been inserted to the db'%(len(res),fname))
#print log_path o = odoo_sql_log2db(r'D:\Program Files\PostgreSQL\9.3\data\pg_log','2014-11-17', 'x_sql_log')
o.parse_logs()

 

转载请注明本文来自:http://www.cnblogs.com/Tommy-Yu/p/4103289.html,谢谢!

postgresql 锁的定位的更多相关文章

  1. postgresql异常快速定位

    今天下午在使用.NET链接postgresql的时候报了“3D000”的错误,经过测试得知原来是web.config中的数据库配置问题. 在这里有个小情况需要注意,postgresql是不允许创建相同 ...

  2. PostgreSQL 锁等待诊断详解

    摘要PostgreSQL和大多数传统RDBMS一样,都设计了大量的锁来保证并发操作的数据一致性. 同时PG在设计锁等待时,以队列方式存储等待锁. 参考 ProcSleep()@src/backend/ ...

  3. Postgresql 锁查看

    之前版本 PostgreSQL 的 pg_stat_activity 视图的 waiting 字段判断会话是否等待锁资源(通俗地讲, waiting 值为true表示申请不到锁资源处于等待状态),但是 ...

  4. PostgreSQL 锁机制浅析

    锁机制在 PostgreSQL 里非常重要 (对于其他现代的 RDBMS 也是如此).对于数据库应用程序开发者(特别是那些涉及到高并发代码的程序员),需要对锁非常熟悉.对于某些问题,锁需要被重点关注与 ...

  5. PostgreSQL 锁 之 关系级锁

    1.关于锁的基本信息 PostgreSQL 有各种各样的技术来锁定某些东西(或者至少是这样称呼的).因此,我将首先用最笼统的术语解释为什么需要锁,可用的锁类型以及它们之间的区别.然后我们将弄清楚 Po ...

  6. PostgreSQL 锁监控

    PG>9.2 postgres=# SELECT blocked_locks.pid AS blocked_pid,postgres-# blocked_activity.usename AS ...

  7. PostgreSQL锁级别及什么操作获取什么锁

    表级锁 大多数的表级锁是由内置的 SQL 命令获得的,但他们也可以通过锁命令来明确获取.可使用的表级锁包括: 访问共享(ACCESS SHARE) - SELECT 命令可在查询中引用的表上获得该锁. ...

  8. postgresql 锁表查询语句

    1 查找锁表的pid select pid from pg_locks l join pg_class t on l.relation = t.oid where t.relkind = 'r' an ...

  9. POSTGRESQL 锁表的问题

    一.找出所的语句 select wait.pid, wait.query as wait_query, wait.query_start as wait_query_start, wait.lockt ...

随机推荐

  1. [工具类]文件或文件夹xx已存在,则重命名为xx(n)(2)

    写在前面 最近一直在弄文件传输组件,其中一个功能就是,在接收端接收文件时,如果文件已经存在了,则对其进行文件名+索引的方式进行自动重命名,之前也写个类似的工具类,总感觉代码太冗余,每回头想想,总觉得心 ...

  2. 分布式Web服务器架构

    最开始,由于某些想法,于是在互联网上搭建了一个网站,这个时候甚至有可能主机都是租借的,但由于这篇文章我们只关注架构的演变历程,因此就假设这个时候已经是托管了一台主机,并且有一定的带宽了,这个时候由于网 ...

  3. c#批量插入示例

    var sql = @"Data Source=(LocalDb)\v11.0;Initial Catalog=aspnet-MvcApplication1-20131029153010;I ...

  4. 使用Web Deploy进行远程部署

    Web Deploy支持直接从本地Visual Studio的工程文件部署网站到远程服务器,部署的过程中可以对比哪些文件变化了需要拷贝,而不是一股脑的全部拷贝,效率和准确性会更好. 部署的过程主要要注 ...

  5. OC基础--关键字@property 和 @synthesize

    一.@property关键字需要掌握的知识: 1.用在@interface中,用来自动生成setter和getter的声明 例:@property int age;--相当于执行了右边的代码--> ...

  6. bootstrap fileinput添加上传成功回调事件

    国外牛人做的bootstrap fileinput挺酷的,但是可惜没有提供自定义上传成功回调事件的接口,因此感到非常头疼,但是很幸运的是,我在网上搜索到一个提问帖子,它问到使用Jquery的on函数绑 ...

  7. Matlab最短路径问题记录

    利用graphshortestpath 可以求最短路径,具体用法参考MATLAB帮助 S=[1 1 2 2 3 3 4 4 4 4 5 6 6 7 8]; %起始节点向量 E=[2 3 5 4 4 6 ...

  8. myEclipse中新建的项目导入到Eclipse之后项目出现一个红色的叉叉

    1.在eclipse中打开Problems,然后看看报哪些错,

  9. ISO 基础之 (十三) protocol 协议

    一 简绍 protocol,简单来说就是一系列不属于任何类的方法列表,其中声明的方法可以被任何类实现.这种模式一般称为代理(delegation)模式.通过Protocol定义各种行为,在不同的场景采 ...

  10. NYOJ298点的转换(矩阵十大问题之一)

    点的变换 时间限制:2000 ms  |  内存限制:65535 KB 难度:5   描述 平面上有不超过10000个点,坐标都是已知的,现在可能对所有的点做以下几种操作: 平移一定距离(M),相对X ...