OceanBase logo

OceanBase

A unified distributed database ready for your transactional, analytical, and AI workloads.

DEPLOY YOUR WAY

OceanBase Cloud

The best way to deploy and scale OceanBase

OceanBase Enterprise

Run and manage OceanBase on your infra

TRY OPEN SOURCE

OceanBase Community Edition

The free, open-source distributed database

OceanBase seekdb

Open source AI native search database

Customer Stories

Real-world success stories from enterprises across diverse industries.

View All
BY USE CASES

Mission-Critical Transactions

Global & Multicloud Application

Elastic Scaling for Peak Traffic

Real-time Analytics

Active Geo-redundancy

Database Consolidation

Resources

Comprehensive knowledge hub for OceanBase.

Blog

Live Demos

Training & Certification

Documentation

Official technical guides, tutorials, API references, and manuals for all OceanBase products.

View All
PRODUCTS

OceanBase Cloud

OceanBase Database

Tools

Connectors and Middleware

QUICK START

OceanBase Cloud

OceanBase Database

BEST PRACTICES

Practical guides for utilizing OceanBase more effectively and conveniently

Company

Learn more about OceanBase – our company, partnerships, and trust and security initiatives.

About OceanBase

Partner

Trust Center

Contact Us

International - English
中国站 - 简体中文
日本 - 日本語
Sign In
Start on Cloud

A unified distributed database ready for your transactional, analytical, and AI workloads.

DEPLOY YOUR WAY

OceanBase Cloud

The best way to deploy and scale OceanBase

OceanBase Enterprise

Run and manage OceanBase on your infra

TRY OPEN SOURCE

OceanBase Community Edition

The free, open-source distributed database

OceanBase seekdb

Open source AI native search database

Customer Stories

Real-world success stories from enterprises across diverse industries.

View All
BY USE CASES

Mission-Critical Transactions

Global & Multicloud Application

Elastic Scaling for Peak Traffic

Real-time Analytics

Active Geo-redundancy

Database Consolidation

Comprehensive knowledge hub for OceanBase.

Blog

Live Demos

Training & Certification

Documentation

Official technical guides, tutorials, API references, and manuals for all OceanBase products.

View All
PRODUCTS
OceanBase CloudOceanBase Database
ToolsConnectors and Middleware
QUICK START
OceanBase CloudOceanBase Database
BEST PRACTICES

Practical guides for utilizing OceanBase more effectively and conveniently

Learn more about OceanBase – our company, partnerships, and trust and security initiatives.

About OceanBase

Partner

Trust Center

Contact Us

Start on Cloud
编组
All Products
    • Databases
    • iconOceanBase Database
    • iconOceanBase Cloud
    • iconOceanBase Tugraph
    • iconInteractive Tutorials
    • iconOceanBase Best Practices
    • Tools
    • iconOceanBase Cloud Platform
    • iconOceanBase Migration Service
    • iconOceanBase Developer Center
    • iconOceanBase Migration Assessment
    • iconOceanBase Admin Tool
    • iconOceanBase Loader and Dumper
    • iconOceanBase Deployer
    • iconKubernetes operator for OceanBase
    • iconOceanBase Diagnostic Tool
    • iconOceanBase Binlog Service
    • Connectors and Middleware
    • iconOceanBase Database Proxy
    • iconEmbedded SQL in C for OceanBase
    • iconOceanBase Call Interface
    • iconOceanBase Connector/C
    • iconOceanBase Connector/J
    • iconOceanBase Connector/ODBC
    • iconOceanBase Connector/NET
icon

OceanBase Migration Assessment

V4.2.3Enterprise Edition

  • Product Introduction
    • Overview
    • Application scenarios
    • System architecture
    • Product form
  • Install OMA
  • Compatibility assessment
    • Overview
    • Assess the compatibility with objects
    • Assess the compatibility with SQL statements
    • Assess the compatibility with business code
    • Export SQL statements from an OceanBase database
    • Database assessment
      • Overview
      • Assess an Oracle database
      • Assess a MySQL database
      • Assess a TiDB database
      • Assess a PostgreSQL database
      • Assess a DB2 LUW database
  • Performance assessment
    • Standalone edition
      • Overview
      • Assess the performance differences between an Oracle database and an OceanBase database
      • Assess the performance differences between a MySQL database and an OceanBase database
      • Assess the performance differences between different versions of OceanBase Database

Download PDF

Overview Application scenarios System architecture Product form Install OMA Overview Assess the compatibility with objects Assess the compatibility with SQL statements Assess the compatibility with business code Export SQL statements from an OceanBase database Overview Assess an Oracle database Assess a MySQL database Assess a TiDB database Assess a PostgreSQL database Assess a DB2 LUW database Overview Assess the performance differences between an Oracle database and an OceanBase database Assess the performance differences between a MySQL database and an OceanBase database Assess the performance differences between different versions of OceanBase Database
OceanBase logo

The Unified Distributed Database for the AI Era.

Follow Us
Products
OceanBase CloudOceanBase EnterpriseOceanBase Community EditionOceanBase seekdb
Resources
DocsBlogLive DemosTraining & Certification
Company
About OceanBaseTrust CenterLegalPartnerContact Us
Follow Us

© OceanBase 2026. All rights reserved

Cloud Service AgreementPrivacy PolicySecurity
Contact Us
Document Feedback
  1. Documentation Center
  2. OceanBase Migration Assessment
  3. V4.2.3
iconOceanBase Migration Assessment
V 4.2.3Enterprise Edition
Enterprise Edition
  • V 4.4.2
  • V 4.2.5
  • V 4.2.4
  • V 4.2.3
  • V 4.2.2
  • V 4.2.0
  • V 3.3.2

Assess the performance differences between different versions of OceanBase Database

Last Updated:2026-04-14 07:41:18  Updated
share
What is on this page
Procedure

folded

share

This topic describes how to assess the performance differences between different versions of OceanBase Database. Replay from an OceanBase database of the source version to that of the destination version is mainly intended to check whether an upgrade of OceanBase Database meets the expectation.

Procedure

  1. Collect data from the source OceanBase database for analysis.

    sh bin/start.sh \
    # The task name.
    --name ob_collect \  
    # A fixed value that specifies to perform a database replay.
    --mode REPLAY \  
    # A fixed value that specifies the COLLECT phase of replay.
    --replay-phase COLLECT \  
    # The number of parallel threads, which affects the replay performance. We recommend that you set the value to be as large as possible if the server performance permits.
    --parallel-count 20 \
    # The IP address of the source OceanBase database.
    --source-db-host xxx.xxx.xxx.xxx \
    # The port number of the source OceanBase database.
    --source-db-port 2883 \
    # The complete username of the source OceanBase database. We recommend that you use the SYS user.
    --source-db-user  "SYS@oms_oracle#ob.admin" \
    # The password of the source OceanBase database.
    --source-db-password pass \
    # The schema from which data is to be collected.
    --schemas "schema_name,TBCS" \
    # The tenant from which data is to be collected.
    --source-tenant tenant \
    # The mode of OceanBase Dtatabase, supporting ORACLE or MYSQL.
    --ob-mode MYSQL \
    # The duration of data collection, in minutes.
    --collect-during-time 30
    # The start time of data collection. The default value of this parameter is one hour ago.
    --collect-start-time  "2023-01-01\ 00:00:00" \ 
    # The end time of data collection. The default value of this parameter is the current time.
    --collect-end-time  "2023-01-01\ 00:00:00" \ 
    # The type of the source database.
    --source-type OBMYSQL \ 
    # The version of OceanBase Database.
    --source-db-version "4.2.1" 
    

    After the analysis is completed, a folder named after the task name is generated in the ./dump/ directory. Example: test-20210530_233520. The folder stores replayable files in JSON format.

  2. Replay the files.

    Run start.sh by referring to the following sample commands. For more information about the parameters in the script, see Product form. In Microsoft Windows, replace sh bin/start.sh with start.bat.

    bin/start.sh \
    # The task name.
    --name send1 \
    # A fixed value that specifies to perform a database replay.
    --mode REPLAY \
    # A fixed value that specifies the SEND phase of replay.
    --replay-phase SEND \
    # The replay mode. Valid values: READ, WRITE, READ_WRITE, PL, and ALL. Default value: READ.
    --replay-mode ALL \  
    # The path of files to be replayed.  
    --source-file "./dump/test" \   
    # Specifies to replay in order.
    --replay-process-name "sort" \
    # Specifies the period after which the replay will be restarted, in the unit of seconds. Default value: 0, which specifies to immediately start the replay.
    --delay-start-time 5 \
    # The replay scale. The default value of this parameter is 1, which indicates that the replay will run at the original speed.   
    --replay-scale 5 \    
    # The sampling ratio, which ranges from 0 to 1. The default value is 1, which indicates full sampling.  
    --replay-sample 1 \     
    # The maximum number of threads, which is 400 by default and cannot exceed 2,000.     
    --max-parallel 400 \     
    # The system warm-up time, in seconds. Default value: 0.
    # Due to the cold start during a replay, a warm-up time must be specified.
    --warm-up 30 \          
    # The IP address of the destination database. You can specify only one destination database for replay.
    --target-db-host xxx.xxx.xxx.xxx \  
    # The port number of the destination database.
    --target-db-port 2883 \
    # The tenant name and cluster name, which must be separated with a number sign (#). The tenant name precedes the cluster name.
    # You can replay calls from multiple users, but the users must belong to the same tenant.
    --target-db-tenant-cluster "oms_oracle#ob_100811****.admin" \   
    # The login username and password, which must be separated with a colon (:). Multiple username/password pairs must be separated with commas (,).
    # Note that only one hyphen (-) is added to the beginning of this parameter. The first username must be that of the SYS user, which is used to obtain information from the SQL_AUDIT view.
    -DuserAndPassword=<sys_name>:<sys_password>,schema_name:123456,schema_name2:123456 \  
    # The custom configuration for the JDBC connection. Specify the JDBC parameters based on the actual situation. For example, you can set useUnicode to true and characterEncoding to utf8 as needed. This parameter is optional.
    -DjdbcConnectionConfigure=useUnicode:true,characterEncoding:utf8 \
    # The process self-monitoring parameter, in minutes. Default value: 10. We recommend that you set this parameter to 30.
    # If you set this parameter to XX, the system will forcibly exit the main process when the main process has not sent any data for XX minutes.
    --monitor-processor-time 30 \  
    # The interval for scanning the SQL_AUDIT view, in seconds. Default value: 60. Set this parameter based on your requirements.
    --sql-audit-interval 300 \   
    # Indicates that transactions are to be replayed.
    # Specifies to replay transactions. If this parameter is absent, transactions are not replayed.
    --with-replay-transaction
    # The mode of OceanBase Database.
    --ob-mode MYSQL \
    # The Schema of OceanBase Database that needs to be replayed. 
    --target-db-schemas  "AAA,BBB" 
    

    After this command is executed, the real-time replay progress is displayed.

    Destination SCHEMA :::SCHEMA : [ schema_name ] :
    -----================ [ schema_name ] Traffic histogram [ Step size: 12 seconds ]===============-------
     4412.0┤  █    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─  
     4191.4┤  █    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─    ─  
     3970.8┤  █    ─    ─    ─    ─    ─    ─    ─    █    █    ─    ─    ─    ─    █    ─  
     3750.2┤  █    ─    ─    ─    ─    ─    ─    ─    █    █    ─    ─    ─    ─    █    ─  
     3529.6┤  █    ─    ─    ─    ─    ─    ─    ─    █    █    ─    ─    ─    ─    █    ─  
     3309.0┤  █    ─    ─    ─    ─    ─    ─    ─    █    █    █    ─    ─    █    █    ─  
     3088.4┤  █    ─    ─    ─    ─    ─    ─    █    █    █    █    █    ─    █    █    █  
     2867.8┤  █    ─    ─    █    ─    ─    █    █    █    █    █    █    █    █    █    █  
     2647.2┤  █    ─    ─    █    ─    ─    █    █    █    █    █    █    █    █    █    █  
     2426.6┤  █    ─    ─    █    █    ─    █    █    █    █    █    █    █    █    █    █  
     2206.0┤  █    ─    ─    █    █    █    █    █    █    █    █    █    █    █    █    █  
     1985.4┤  █    █    █    █    █    █    █    █    █    █    █    █    █    █    █    █  
     1764.8┤  █    █    █    █    █    █    █    █    █    █    █    █    █    █    █    █  
     1544.2┤  █    █    █    █    █    █    █    █    █    █    █    █    █    █    █    █  
     1323.6┤  █    █    █    █    █    █    █    █    █    █    █    █    █    █    █    █  
     1103.0┤  █    █    █    █    █    █    █    █    █    █    █    █    █    █    █    █  
      882.4┤  █    █    █    █    █    █    █    █    █    █    █    █    █    █    █    █  
      661.8┤  █    █    █    █    █    █    █    █    █    █    █    █    █    █    █    █  
      441.2┤  █    █    █    █    █    █    █    █    █    █    █    █    █    █    █    █  
      220.6┤  █    █    █    █    █    █    █    █    █    █    █    █    █    █    █    █  
    Start time: 2021-05-31 00:14:04 End time: 2021-05-31 00:17:15 Time spent (seconds): 190 Requests: 50774
    ******************************************************************************************
    
  3. View the replay report.

    After the replay is completed, you can perform the following steps to view the workload replay report.

    1. Go to the replayReportTool directory and double-click the index.html file.

    2. On the page that appears, click Authorize and View Report.

    3. Select and open the oma.sqlite file.

      Generally, the oma.sqlite file is stored in the db folder under the root directory of OMA.

    4. On the page that appears after you open the oma.sqlite file, click Select Report in the upper-right corner and select the workload replay report that you want to view from the drop-down list.

      You can view the users who support the replay calls in the destination database, replay success rate, replay traffic comparison chart, and list of replay information in the workload replay report.

Previous topic

Assess the performance differences between a MySQL database and an OceanBase database
Last
What is on this page
Procedure