1.1查看表空间

db2 list tablespaces show detail

1.2查看数据库的表死锁

方法一:

打开监控   db2 update monitor switches using lock on

查看锁表  db2 get snapshot for locks on 数据库名称

db2 "force application (handle id)"

停止锁的进程

List Of Locks   #在application handle紧跟后面出现list of locks表明该application handle 锁了表或对象

Lock Name                = 0x030039020DFF11000000000052

Lock Attributes             = 0x00000000

Release Flags               = 0x00000004

Lock Count                  = 1

Hold Count                  = 0

Lock Object Name            = 1163533    #被锁对象名称

Object Type                 = Row        #被锁对象类型

Tablespace Name             = tbs_data    #被锁对象所在的表空间

Table Schema                = DB2INST1

Table Name                  = t_mytable1   #被锁的表名

Mode                        = X

方法二:

使用select agent_id,tabname,lock_mode from table(snap_get_lock('dbname')) as aa

查看:进程hander,表名,锁模式

1.3查看和更改快照参数

db2 get monitor switches

监控开关 数据库管理器参数 注释

  BUFFERPOOL DFT_MON_BUFPOOL 缓冲区的读写情况和发生时间

  LOCK DFT_MON_LOCK 锁持有,锁等待,以及死锁的发生情况

  SORT DFT_MON_SORT Heap的使用情况,排序性能

  STATEMENT DFT_MON_STMT 语句起始时间,语句内容

  TABLE DFT_MON_TABLE Measure of activity (rows read/written)

  UOW DFT_MON_UOW Start/end times, completion status

  TIMESTAMP DFT_MON_TIMESTAMP Timestamps

为了观察快照中的锁和执行语句情况,一般把LOCK和STATEMENT选项设为ON,也可以酌情把其他开关打开,示例如下: db2 update monitor switches using lock on statement on

1.4查看和更改与锁相关的主要配置参数

CLP方式:

  db2 get db cfg

  在参数列表中寻找DLCHKTIME和LOCKTIMEOUT两个参数。

  -DLCHKTIME 单位是毫秒,是DB2检查死锁的间隔时间,假设该值为10000ms,则意味着每隔10秒钟检查一下当前数据库中有无死锁存在,如有死锁,会选择回滚其中的某一个事务,让另外一个事务完成交易。

  -LOCKTIMEOUT单位是秒,是锁等待最长时间,超过该时间仍未获得锁,则返回错误。

  设置提示:

  -缺省情况下,LOCKTIMEOUT是-1,意味着锁等待时间无限期,这和实际应用需求一般是不太相符的,需要将其值设为大于0的一个数。

  -DLCHKTIME时间通常要设得比LOCKTIMEOUT时间小一些,否则未等发现死锁,就会被以锁等待超时而返回错误。

  更改示例(CLP方式)

  db2 update db cfg using locktimeout 10

1.5查看当前并发应用

CLP方式:

  db2 list applications

  或db2 list applications show detail

  或 db2 list applications for database dbname [ show detail]

  该命令可以查看当前是否有多个应用在连接着数据库,从而排查是否有并发的存在。

  注意Application Name 和Application Id两栏,Application Name栏列出了应用的名字,db2bp通常意味着目前有CLP在连接数据库,java则意味着可能有db2cc或用户自己的java应用在连接数据库,在application Id栏中可以看到这些应用来自于哪些机器,本机的就显示为 LOCAL + 用户名 + 开始连接上的时间,远程的就会显示为16进制的IP地址+用户名+开始连接上的时间。通过排查并发应用从而消除测试中不必要的锁现象。

1.6使用事件查看器

使用事件监控器,首先要选定所关注的事件类型,DB2中有很多事件类型,可以用于锁分析的通常会用到以下三种:

  DEADLOCKS

  DEADLOCKS

WITH DETAILS

  STATEMENTS

  步骤:

  -创建事件监控器

  create event monitor evmname for eventtype write to file ‘directory’

  例:create event monitor mymonitor for deadlocks, statements

  write to file ‘c: emp’

  -把事件监控器打开

  接上例:

  Db2 “set event monitor mymonitor state 1”

  注:1为打开,0为关闭

  事件监控器开始工作,当所有应用断掉连接后,将事件记录下来

  -格式化监控器的文件

db2evmon –db dbname -evm mymonitor >snap.txt

-察看监控器的文件

More snap.txt

1.6.1查看执行最耗时的SQL

Select stmt_text ,(stop_time-start_time) from stmt_ monitor_name Where stmt_operation not in (7,8,9,19) order by decimal(stop_time-start_time) desc fetch first 10 rows only

1.6.2查看按照顺序降序排列执行次数最多的SQL

Select distinct(stmt_text),count(*) Count from stmt_monitor_name Where stmt_operation not in (7,8,9,19) group by stmt_text order by count(*) desc fetch first 10 rows only

1.6.3查看耗CPU时间最多的SQL

Select stmt_text ,user_cpu_time from stmt_monitor_name where stmt_operation not in (7,8,9,19) order by  user_cpu_time  desc fetch first 10 rows only

1.6.4查看总排序时间降序排列排序时间最长的SQL

Select stmt_text,total_sort_time from stmt_monitor_name where stmt_operation not in (7,8,9,19) order by  decimal(total_sort_time)  desc fetch first 10 rows only

1.7查看表上的索引

describe indexes for table 表名

1.8得到误删除表的ID

list history dropped table all for 数据库名 得到删除表的tableid

1.9数据库导入导出

db2move databasename export -sn 模块名 –tn 表名 -u db2admin -p *****

db2look -d databasename -e -a -o db2look_htdctr.sql

db2move test import -u 用户名 -p 密码

1.10编目数据库

db2set DB2_CREATE_DB_ON_PATH=YES

CATALOG TCPIP NODE Server51
    REMOTE IP_Address
    SERVER 51000
    REMOTE_INSTANCE DB2
    OSTYPE NT;

1.11查询SQLCODE

Db2 ? 22001

Db2 ? sql-204

1.12 备份数据库

备份表空间

Db2 “backup database databasename” tablespace tablespaceName to /path

Db2 backup database dbname to /path

1.13停止单个数据库

db2 connect to sample
db2 quiesce db immediate force connections
db2 terminate
db2 deactivate db sample
db2 connect to sample
db2 unquiesce db

1.14查看并修改DB2端口

C:/WINDOWS/SYSTEM32/DRIVERS/ETC/services

db2 get dbm cfg 查看SVCENAME名称

修改db2端口

update dbm cfg using svcename 50000

1.15查看数据库

db2 list db directory

1.16插入空值到表中

import from /dev/null of del replace into db2inst1.表名

1.17建立nickname

1、在db2命令窗口下,运行connect to 目标库 user 用户名 using 密码

2、显示所有对象 list tables

3、建立nickname create nickname  nickname的名字  for server名.schma名.table名

1.18查看前几条记录

查看记录

select * from table fetch first 10 rows only

1.19查看db2实例

Db2ilist

1.20查看数据库语句执行时间

见1.6

1.21创建数据库

db2 "CREATE DATABASE MIBSSE AUTOMATIC STORAGE YES  ON '/db2/xbank2' DBPATH ON '/db2/xbank2' USING CODESET UTF-8 TERRITORY CN COLLATE USING SYSTEM PAGESIZE 4096"

1.22查看BufferPool

db2 "select * from syscat.bufferpools"

1.23单表导入导出

db2 Export to "F:/fund/FssProduct.txt" of del select * from tablename

db2 import from “F:/fund/FssProduct.txt” of del messages “d:/msgs.txt” insert into tablename

1.24 数据库所有快照

db2 get snapshot for dynamic sql on mibsse >snap.out

通过Linux命令查出所有的执行最大次数

grep -n "Number of executions" snap.out |grep -v "= 0" |sort -k 5,5rn|more

1.25查看临时表空间使用情况

db2 get snapshot for tables on mibsse >snap2.out

db2 get snapshot for application agented <agent ID>

1.26通过性能管理视图监控数据库

db2 list tables for schema sysibmadm;

或在db2客户端察看视图

1.26.1监控缓冲池命中率

--需要开启BUFFERPOOL监控

db2 update dbm cfg using DFT_MON_BUFPOOL on

Select substr(bp_name,1,30) as bp_name,data_hit_ratio_percent,index_hit_ratio_percent,total_hit_ratio_percent
from sysibmadm.bp_hitratio where bp_name not like 'IBMSYSTEM%';

1.26.2监控Package Cache 大小

with dbcfg1 as (select int(value) as pckcachesz from sysibmadm.dbcfg where name ='pckcachesz')
Select pckcachesz as package_Cache_Size ,pkg_cache_lookups as lookups, pkg_cache_inserts as inserts,pkg_cache_num_overflows as overflows, 100*pkg_cache_size_top/(pckcachesz * 4096) as pkg_Cache_alloc
from dbcfg1,sysibmadm.snapdb

1.26.3监控执行成本最高的SQL

Select agent_id ,rows_selected,rows_read from sysibmadm.APPLICATION_PERFORMANCE[Z1] ;

1.26.4监控允许最长的SQL

Select appl_name,elapsed_time_min as elapsedmin,appl_status as status,authid as auth_id,inbound_comm_address as ip_address,stmt_text as SQL_statement
from sysibmadm.long_running_sql order by 2 desc

1.26.5监控SQL准备和预编译时间最长的SQL

Select num_executions, average_execution_time_s,prep_time_ms,prep_time_percent, stmt_text 
       from sysibmadm.query_prep_cost
       where average_execution_time_s>0 order by prep_time_percent des

1.26.6监控执行次数最多的SQL

select  "NUM_EXECUTIONS", "AVERAGE_EXECUTION_TIME_S",
    "STMT_SORTS", "SORTS_PER_EXECUTION", "STMT_TEXT", "DBPARTITIONNUM"
  from "SYSIBMADM"."TOP_DYNAMIC_SQL"
  where NUM_EXECUTIONS>0
  order by 1 desc fetch first 5 rows only;

1.26.7监控排序次数最多的SQL

select  "NUM_EXECUTIONS", "AVERAGE_EXECUTION_TIME_S",
    "STMT_SORTS", "SORTS_PER_EXECUTION", "STMT_TEXT", "DBPARTITIONNUM"
  from "SYSIBMADM"."TOP_DYNAMIC_SQL"
  where NUM_EXECUTIONS>0
  order by STMT_SORTS desc fetch first 5 rows only

1.26.8监控LOCK WAIT等待时间

select ai.appl_name,ai.primary_auth_id,ap.lock_waits,ap.lock_wait_time/1000 as "Total Wait (s)",(ap.lock_wait_time/ap.lock_waits) as "Avg Wait(ms)"
from sysibmadm.snapappl_info ai,sysibmadm.snapappl ap
where ai.agent_id = ap.agent_id
and ap.lock_waits>0;

1.26.9 监控LOCK CHAIN

select ai_h.appl_name,ai_h.primary_auth_id,lw.authid,lw.lock_mode,lw.tabname,lw.tabschema,timestampdiff(2,char(lw.snapshot_timestamp-lw.lock_wait_start_time)) as "Wating(s)"
from sysibmadm.lockwaits lw,sysibmadm.snapappl_info ai_h
where lw.agent_id_holding_lk = ai_h.agent_id;

1.26.10监控锁内存使用
1.26.11 监控锁升级、死锁和锁超时
1.26.12监控全表扫描的SQL

Select substr(authid,1,10) as authid,substr(appl_name,1,20) as appl_name,percent_rows_selected from sysibmadm.appl_performance

1.26.13监控Page Cleaners是否足够
1.26.14监控Prefecher是否够用
1.26.15监控内存使用情况

Select pool_id,pool_secondary_id,pool_current_size,pool_watermark from sysibmadm.snapdb_memory_pool

1.27db2pd工具
1.27.1诊断数据库加锁的表的情况

db2pd -db dbname -applications | more

得到下表

Address            AppHandl [nod-index] NumAgents  CoorEDUID  Status

00xC0000000D0300080 27898    [000-27898] 1          45348      Lock-wait

再通过db2pd -db dbname –transactions

找寻 status=Lock-Wait 对应的AppHandl句柄27898对应的TranHdl 122

Address            AppHandl [nod-index] TranHdl

0xC0000003417F2680 27898    [000-27898] 122

再通过db2pd -db dbname–locks 查询 122 对应的锁状态

Address            TranHdl    Lockname                   Type

0xC0000003418AF400 122        000200A8000000020040000552 Row        .NS  W   315

0xC0000003418A6A80 122        000000F4000000010001EB0056 Internal V

1.27.2诊断锁超时

db2pd –db dbname –locks –transactions –applications –dynamic

1.27.3捕获正在等待的锁定

db2pd –db dbname –locks wait

1.27.4监控动态的SQL语句

db2pd –db dbname –app –dyn

1.27.5监控内存使用情况

db2pd –memblock

1.27.6监控哪个应用程序用光了 表空间
1.27.7监控全表扫描的表

db2pd –db dbname -tcbstats

1.27.8监视恢复
1.27.9监控事务正在使用的资源量
1.27.10监控日志使用情况

db2pd –db dbname –logs

1.27.11收集操作系统信息

db2pd –osinfo

1.27.12获取数据库管理器配置参数

db2pd –db dbname -dbmcfg

1.27.13获取数据库配置参数

db2pd –db dbname -dbcfg

1.28扩大数据库事务日志

db2 get db cfg

使用db2 update db cfg using 改变

Log file size (4KB)                         (LOGFILSIZ) = 10000

Number of primary log files                (LOGPRIMARY) = 32

Number of secondary log files               (LOGSECOND) = 24

1.29db2mtrk使用方法

db2mtrk –i –d –v

db2mtrk –i  #显示当前实例的内存使用情况

db2mtrk –I –v #显示当前实例的内存使用详细情况

db2mtrk  –d #显示数据库的内存使用情况

db2mtrk –d –v #显示数据库的内存使用情况的详细信息

db2mtrk –p #显示代理进程专用内存使用率

-m 参数选项用于显示最大的内存使用上限

-w 参数选项用于显示使用过程中内存达到的最大值

-r  参数选项用于重复显示

Interval 指定以秒为单位的重复的间隔

count 指定间隔次数

1.30列出所有的db2注册变量

db2set -lr

DB2命令大全的更多相关文章

  1. DB2 命令大全

    check Archiving processing 查看日志归档情况 db2 "SELECT DATE(CAST(START_TIME as TIMESTAMP)) as DATE, co ...

  2. db2常用命令大全

    #显示这个DB2错误的解释信息(SQLSTATE 5位数字)db2 ? 42704 #显示这个SQLCODE的解释信息(SQLCODE 四位数字) db2 ? SQL0204N ##查看数据库指定配置 ...

  3. DB2 函数大全

    DB2函数大全 函数名 函数解释 函数举例 AVG() 返回一组数值的平均值. SELECTAVG(SALARY)FROMBSEMPMS; CORR(),CORRELATION() 返回一对数值的关系 ...

  4. Android系统在超级终端下必会的命令大全(adb shell命令大全)

    . 显示系统中全部Android平台: android list targets . 显示系统中全部AVD(模拟器): android list avd . 创建AVD(模拟器): android c ...

  5. DB2函数大全

    DB2函数大全 函数名 函数解释 函数举例 AVG() 返回一组数值的平均值. SELECTAVG(SALARY)FROMBSEMPMS; CORR(),CORRELATION() 返回一对数值的关系 ...

  6. .NET Core dotnet 命令大全

    dotnet 命令大全,让你理解dotnet 命令. 本文将以一个实例串起 dotnet 所有命令,让你玩转dotnet 命令. 本篇文章编写环境为windows 10 ,dotnet 命令同样适用于 ...

  7. 【转】Hadoop命令大全

    Hadoop命令大全 本节比较全面的向大家介绍一下Hadoop命令,欢迎大家一起来学习,希望通过本节的介绍大家能够掌握一些常见Hadoop命令的使用方法.下面是Hadoop命令的详细介绍. 1.列出所 ...

  8. CMD命令大全

    有关某个命令的详细信息,请键入 HELP 命令名 ASSOC 显示或修改文件扩展名关联. AT 计划在计算机上运行的命令和程序. ATTRIB 显示或更改文件属性. BREAK 设置或清除扩展式 CT ...

  9. DOS命令大全!

    一)MD——建立子目录 1.功能:创建新的子目录 2.类型:内部命令 3.格式:MD[盘符:][路径名]〈子目录名〉 4.使用说明: (1)“盘符”:指定要建立子目录的磁盘驱动器字母,若省略,则为当前 ...

随机推荐

  1. IntelliJ IDEA手动配置连接MySQL数据库

    先从菜单View→Tool Windows→Database打开数据库工具窗口,如下图所示: 点击Database工具窗口左上角添加按钮"+",选择数据库类型,这里以MySQL为例 ...

  2. linux常用方法

    同步时间 ntpdate us.pool.ntp.org 查看http的并发请求数及其TCP连接状态 netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in ...

  3. android学习笔记43——图形图像处理3——Path

    Path类 Path类可以预先在View上将N个点连成一条“路径”,然后调用Canavas的drawPath(path,paint)即可沿着路径绘制图形. android还为路径绘制提供了PathEf ...

  4. HDU2829

    题目大意:给定一个长度为n的序列,至多将序列分成m+1段,每段序列都有权值,权值为序列内两个数两两相乘之和.m<=n<=1000. 分析:令w[i,j]表示区间[i,j]中两两乘积之和,f ...

  5. 【MySQL】技巧 之 count(*)、count(1)、count(col)

    只看结果的话,Select Count(*) 和 Select Count(1) 两着返回结果是一样的. 假如表沒有主键(Primary key), 那么count(1)比count(*)快,如果有主 ...

  6. Akka(一) - akka的wordcount

    1. 启动类 object Application extends App{ val _system = ActorSystem("HelloAkka") //构建akka容器 v ...

  7. Java的clone机制(及String的特殊性)

    1. Clone&Copy 假设现在有一个Employee对象,Employee tobby =new Employee(“CMTobby”,5000),通常我们会有这样的赋值Employee ...

  8. BIP_开发案例07_将原有Report Builer报表全部转为XML Publisher形式(案例)

    2014-05-31 Created By BaoXinjian

  9. 转_IOS开源

    http://www.csdn.net/article/2013-06-05/2815530-GitHub-iOS-open-source-projects-one 苹果App Store本身所具有的 ...

  10. maven问题

    pom.xml ... </dependencies> <repositories> <repository> <id>sf-nexus</id& ...