重庆思庄Oracle、Redhat认证学习论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3881|回复: 0
打印 上一主题 下一主题

[范例] 数据库重放测试

[复制链接]
跳转到指定楼层
楼主
发表于 2016-12-25 11:41:57 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Database Replay主要利用2个package: DBMS_WORKLOAD_CAPTURE 和 DBMS_WORKLOAD_REPLAY,分4个步骤:
1. 捕捉产品数据库的负载。
2. 预处理捕获的负载信息。
3. 重播数据库负载。
4. 创建报告并分析结果。



捕获:
mkdir /home/oracle/db_replay_capture
CONN / AS SYSDBA
CREATE OR REPLACE DIRECTORY db_replay_capture_dir AS '/home/oracle/db_replay_capture/';
BEGIN
  DBMS_WORKLOAD_CAPTURE.start_capture (name     => 'test_capture_1',
                                       dir      => 'DB_REPLAY_CAPTURE_DIR',
                                       duration => NULL);
END;
/
CREATE USER db_replay_test IDENTIFIED BY db_replay_test QUOTA UNLIMITED ON users;
GRANT CONNECT, CREATE TABLE TO db_replay_test;
CONN db_replay_test/db_replay_test
CREATE TABLE db_replay_test_tab (
  id           NUMBER,
  description  VARCHAR2(50),
  CONSTRAINT db_replay_test_tab_pk PRIMARY KEY (id)
);

BEGIN
  FOR i IN 1 .. 500000 LOOP
    INSERT INTO db_replay_test_tab (id, description)
    VALUES (i, 'Description for ' || i);
  END LOOP;
  COMMIT;
END;
/
CONN / AS SYSDBA
BEGIN
  DBMS_WORKLOAD_CAPTURE.finish_capture;
END;
/
$ cd /home/oracle/db_replay_capture
$ ls
wcr_4f9rtgw00238y.rec  wcr_cr.html       wcr_scapture.wmd
wcr_4f9rtjw002397.rec  wcr_cr.text
wcr_4f9rtyw00239h.rec  wcr_fcapture.wmd
CONN / AS SYSDBA
SELECT DBMS_WORKLOAD_CAPTURE.get_capture_info('DB_REPLAY_CAPTURE_DIR') FROM   dual;
COLUMN name FORMAT A30
SELECT id, name FROM dba_workload_captures;
DECLARE
  l_report  CLOB;
BEGIN
  l_report := DBMS_WORKLOAD_CAPTURE.report(capture_id => 12,
                                           format     => DBMS_WORKLOAD_CAPTURE.TYPE_HTML);
END;
/
BEGIN
  DBMS_WORKLOAD_CAPTURE.export_awr (capture_id => 12);
END;
/
$ cd /home/oracle/db_replay_capture
$ ls
wcr_4f9rtgw00238y.rec  wcr_ca.dmp   wcr_cr.text
wcr_4f9rtjw002397.rec  wcr_ca.log   wcr_fcapture.wmd
wcr_4f9rtyw00239h.rec  wcr_cr.html  wcr_scapture.wmd


重放:
mkdir /home/oracle/db_replay_capture
CONN / AS SYSDBA
CREATE OR REPLACE DIRECTORY db_replay_capture_dir AS '/home/oracle/db_replay_capture/';
BEGIN
  DBMS_WORKLOAD_REPLAY.process_capture('DB_REPLAY_CAPTURE_DIR');
  DBMS_WORKLOAD_REPLAY.initialize_replay (replay_name => 'test_capture_1',
                                          replay_dir  => 'DB_REPLAY_CAPTURE_DIR');
  DBMS_WORKLOAD_REPLAY.prepare_replay (synchronization => TRUE);
END;
/
$ wrc mode=calibrate replaydir=/home/oracle/db_replay_capture
$ wrc system/123456 mode=replay replaydir=/home/oracle/db_replay_capture
CONN / AS SYSDBA
BEGIN
  DBMS_WORKLOAD_REPLAY.start_replay;
END;
/
SELECT table_name FROM dba_tables WHERE owner = 'DB_REPLAY_TEST';
SELECT COUNT(*) FROM db_replay_test.db_replay_test_tab;
COLUMN name FORMAT A30
SELECT id, name FROM dba_workload_replays;
DECLARE
  l_report  CLOB;
BEGIN
  l_report := DBMS_WORKLOAD_REPLAY.report(replay_id => 1,
                                          format     => DBMS_WORKLOAD_REPLAY.TYPE_HTML);
END;
/
set long 100000
select dbms_workload_replay.report(1,'TEXT') from dual;


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 支持支持 反对反对
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|重庆思庄Oracle、Redhat认证学习论坛 ( 渝ICP备12004239号-4 )

GMT+8, 2024-12-1 09:22 , Processed in 0.114502 second(s), 21 queries .

重庆思庄学习中心论坛-重庆思庄科技有限公司论坛

© 2001-2020

快速回复 返回顶部 返回列表