All Products
Search
Document Center

Data Transmission Service:Sinkronisasi ApsaraDB for MongoDB ke RDS for MySQL

Last Updated:Jun 22, 2026

Layanan Transmisi Data (DTS) menyinkronkan data dari MongoDB ke database MySQL. Topik ini menjelaskan cara menyinkronkan data dari replika set ApsaraDB for MongoDB ke instans ApsaraDB RDS for MySQL.

Prasyarat

  • Jika instans sumber ApsaraDB for MongoDB merupakan kluster sharded, ajukan titik akhir untuk setiap node shard dan pastikan semuanya menggunakan akun dan kata sandi yang sama. Untuk informasi selengkapnya, lihat Ajukan titik akhir shard.

  • Buat instans target ApsaraDB RDS for MySQL dengan ruang penyimpanan lebih besar daripada yang digunakan oleh instans sumber ApsaraDB for MongoDB. Untuk petunjuknya, lihat Buat instans ApsaraDB RDS for MySQL.

    Catatan

    Instans target harus memiliki ruang penyimpanan minimal 10% lebih besar daripada yang digunakan oleh database sumber.

  • Di instans target ApsaraDB RDS for MySQL, buat database dan tabel dengan kunci primer untuk menyimpan data. Untuk informasi selengkapnya, lihat Kelola database.

    Penting
    • Pastikan tipe data kolom di tabel target kompatibel dengan data sumber. Misalnya, jika bidang _id di instans MongoDB sumber berupa ObjectId, kolom yang sesuai di instans target ApsaraDB RDS for MySQL harus berupa varchar.

    • Nama kolom di tabel ApsaraDB RDS for MySQL target tidak boleh _id atau _value.

Catatan

Tipe

Deskripsi

Batasan database sumber

  • Kebutuhan bandwidth: Server tempat database sumber berada harus memiliki bandwidth outbound yang mencukupi. Jika tidak, kecepatan sinkronisasi dapat terpengaruh.

  • Untuk mengedit objek (seperti mengganti nama koleksi), satu tugas sinkronisasi mendukung hingga 1.000 koleksi. Jika melebihi batas ini, tugas akan gagal dengan error setelah dikirim. Untuk mengatasinya, bagi koleksi menjadi beberapa batch dan konfigurasikan beberapa tugas. Atau konfigurasikan tugas sinkronisasi seluruh database.

  • Jika MongoDB sumber Anda adalah instans kluster sharded, bidang _id di koleksi yang akan disinkronkan harus memiliki nilai unik. Jika tidak, ketidakkonsistenan data dapat terjadi.

  • Jika MongoDB sumber Anda adalah instans kluster sharded, jumlah node Mongos tidak boleh melebihi 10. Pastikan juga tidak ada dokumen orphaned di instans kluster sharded MongoDB Anda. Jika tidak, ketidakkonsistenan data atau kegagalan tugas dapat terjadi. Untuk informasi selengkapnya, lihat dokumen orphaned dan Cara membersihkan dokumen orphaned di MongoDB (arsitektur kluster sharded).

  • Jika instans sumber Anda adalah kluster sharded MongoDB yang dikelola sendiri:

    • Access Method hanya mendukung Express Connect, VPN Gateway, or Smart Access Gateway dan Cloud Enterprise Network (CEN).

    • Jika versi MongoDB Anda 8.0 atau lebih baru dan Migration Method adalah Oplog, pastikan akun Shard yang digunakan oleh tugas sinkronisasi memiliki izin directShardOperations. Tambahkan izin ini menggunakan perintah db.adminCommand({ grantRolesToUser: "username", roles: [{ role: "directShardOperations", db: "admin"}]}).

      Catatan

      Ganti username dalam perintah dengan akun Shard yang digunakan oleh tugas sinkronisasi.

    • Jika Migration Method adalah Oplog dan tugas mencakup sinkronisasi data penuh, pastikan akun Mongos untuk kluster sharded MongoDB sumber memiliki izin untuk menjalankan perintah db.runCommand({"balancerStatus":1}). DTS memeriksa apakah Balancer dinonaktifkan menggunakan perintah ini selama pemeriksaan awal.

  • Database sumber Anda tidak mendukung MongoDB standalone, Azure Cosmos DB for MongoDB, atau Amazon DocumentDB (kluster elastis).

  • Database sumber Anda harus mengaktifkan Oplog dan menyimpan Oplog minimal selama tujuh hari. Atau aktifkan Change Streams dan pastikan DTS dapat berlangganan perubahan data dalam tujuh hari terakhir melalui Change Streams. Jika tidak, DTS mungkin gagal menangkap perubahan data, menyebabkan kegagalan tugas. Dalam kasus ekstrem, hal ini dapat menyebabkan ketidakkonsistenan atau kehilangan data. Masalah ini tidak dicakup oleh Perjanjian Tingkat Layanan (SLA) DTS.

    Penting
    • Kami merekomendasikan penggunaan Oplog untuk menangkap perubahan data.

    • Hanya MongoDB 4.0 dan versi lebih baru yang mendukung Change Streams. Change Streams tidak mendukung sinkronisasi dua arah.

    • Jika database sumber Anda adalah Amazon DocumentDB (kluster non-elastis), aktifkan Change Streams secara manual. Saat mengonfigurasi tugas, atur Migration Method ke ChangeStream dan atur Architecture ke Sharded Cluster.

  • Batasan operasi database sumber:

    • Selama sinkronisasi data penuh, jangan mengubah skema database atau koleksi (termasuk pembaruan data bertipe array). Jika tidak, tugas sinkronisasi mungkin gagal atau menyebabkan ketidakkonsistenan data antara database sumber dan tujuan.

    • Jika MongoDB sumber Anda adalah instans kluster sharded, selama instans sinkronisasi berjalan, jangan jalankan perintah yang mengubah distribusi data pada objek yang akan disinkronkan di database sumber (misalnya, shardCollection, reshardCollection, unshardCollection, moveCollection, atau movePrimary). Jika tidak, ketidakkonsistenan data dapat terjadi.

  • Jika MongoDB sumber Anda adalah kluster sharded dan Balancer melakukan penyeimbangan data, latensi dapat terjadi.

  • DTS tidak mendukung koneksi ke database MongoDB menggunakan alamat SRV.

Batasan lainnya

  • Hanya sinkronisasi tingkat koleksi yang didukung.

  • Tabel di instans tujuan RDS MySQL yang menerima data harus memiliki kolom kunci primer unik (bukan kunci primer komposit). Saat Anda mengonfigurasi bidang sinkronisasi di bagian Selected Objects, Assignment untuk kolom kunci primer ini harus berupa bson_value("_id").

  • Tabel yang menerima data di instans target RDS MySQL tidak boleh memiliki bidang bernama _id dan _value, atau sinkronisasi akan gagal.

  • Jika tipe data di instans RDS MySQL tidak kompatibel dengan MongoDB, tugas akan gagal.

  • DTS tidak mendukung sinkronisasi data dari database admin, config, dan local.

  • Informasi transaksi tidak dipertahankan. Transaksi di database sumber menjadi catatan individual di database tujuan.

  • Jika data Anda mencakup karakter empat byte—seperti karakter Tionghoa langka atau emoji—database dan tabel tujuan harus menggunakan charset utf8mb4.

    Catatan

    Jika Anda menggunakan DTS untuk menyinkronkan skema tabel, atur parameter character_set_server di tingkat instans di database tujuan ke utf8mb4.

  • Evaluasi kinerja database sumber dan tujuan sebelum sinkronisasi. Jalankan sinkronisasi selama jam sepi. Jika tidak, sinkronisasi data penuh akan mengonsumsi sumber daya baca dan tulis, meningkatkan beban database.

  • Sinkronisasi data penuh menjalankan operasi INSERT secara konkuren. Hal ini menciptakan fragmentasi di koleksi database tujuan. Setelah sinkronisasi penuh, ruang penyimpanan koleksi di database tujuan lebih besar daripada di instans sumber.

  • Konfirmasi bahwa presisi sinkronisasi DTS untuk kolom FLOAT atau DOUBLE memenuhi ekspektasi bisnis Anda. DTS membaca kolom ini menggunakan ROUND(COLUMN,PRECISION). Jika presisi tidak ditentukan, DTS menggunakan 38 digit untuk FLOAT dan 308 digit untuk DOUBLE.

  • DTS mencoba memulihkan tugas sinkronisasi yang gagal dalam waktu tujuh hari. Sebelum mengalihkan traffic ke instans tujuan, akhiri atau lepas tugas tersebut. Atau gunakan perintah revoke untuk mencabut izin tulis akun DTS di instans tujuan. Hal ini mencegah pemulihan otomatis menimpa data tujuan dengan data sumber.

  • DTS menghitung latensi sinkronisasi inkremental dengan membandingkan timestamp dokumen terakhir yang disinkronkan dengan timestamp saat ini. Jika database sumber tidak memiliki pembaruan dalam waktu lama, informasi latensi mungkin tidak akurat. Jika latensi tampak terlalu tinggi, jalankan operasi pembaruan di database sumber untuk memperbarui informasi latensi.

  • DTS tidak mendukung sinkronisasi koleksi time-series yang diperkenalkan di MongoDB 5.0 dan versi lebih baru.

  • Jika tugas gagal, staf dukungan DTS akan mencoba memulihkannya dalam waktu delapan jam. Selama pemulihan, mereka mungkin me-restart tugas atau menyesuaikan parameternya.

    Catatan

    Hanya parameter tugas DTS yang dimodifikasi—bukan parameter database. Parameter yang mungkin disesuaikan termasuk yang tercantum di Modifikasi parameter instans.

Penagihan

Tipe

Biaya

Sinkronisasi data penuh

Gratis.

Sinkronisasi data inkremental

Dikenai biaya. Untuk detailnya, lihat Ikhtisar penagihan.

Deskripsi tipe sinkronisasi

Type

Deskripsi

Sinkronisasi data penuh

Menyinkronkan semua data yang ada dari instans sumber ApsaraDB for MongoDB ke instans tujuan ApsaraDB RDS for MySQL.

Sinkronisasi data inkremental

Setelah sinkronisasi data penuh, pembaruan inkremental dari instans sumber ApsaraDB for MongoDB disinkronkan ke instans tujuan ApsaraDB RDS for MySQL.

Catatan
  • Hanya mendukung operasi insert, update, dan delete pada dokumen dalam koleksi.

  • Untuk pembaruan dokumen, hanya mereplikasi operasi yang menggunakan perintah $set.

Izin akun database

Database

Izin

Aksi

Instans sumber ApsaraDB for MongoDB

Izin baca pada database yang akan disinkronkan, database admin, dan database local.

Manajemen akun

Instans target ApsaraDB RDS for MySQL

Izin baca dan tulis pada database target.

Buat akun dan Modifikasi izin akun

Langkah-langkah

  1. Buka halaman daftar tugas sinkronisasi di wilayah tujuan. Anda dapat menggunakan salah satu dari dua metode berikut:

    Dari Konsol DTS

    1. Masuk ke Konsol Data Transmission Service (DTS).

    2. Di panel navigasi kiri, klik Data Synchronization.

    3. Di pojok kiri atas halaman, pilih wilayah tempat instans sinkronisasi berada.

    Dari Konsol DMS

    Catatan

    Operasi aktual dapat berbeda tergantung pada mode dan tata letak Konsol DMS. Untuk informasi selengkapnya, lihat Mode sederhana dan Sesuaikan tata letak dan gaya antarmuka DMS.

    1. Masuk ke Data Management (DMS).

    2. Di bilah menu atas, pilih Data + AI > Data Transmission (DTS) > Data Synchronization.

    3. Di sebelah kanan Data Synchronization Tasks, pilih wilayah tempat instans sinkronisasi berada.

  2. Klik Create Task untuk membuka halaman konfigurasi tugas.

  3. Konfigurasikan database sumber dan tujuan.

    Kategori

    Parameter

    Deskripsi

    N/A

    Task Name

    DTS secara otomatis menghasilkan nama tugas. Kami merekomendasikan agar Anda menentukan nama deskriptif untuk memudahkan identifikasi. Nama ini tidak harus unik.

    Source Database

    Select Existing Connection

    • Untuk menggunakan instans database yang ditambahkan ke sistem (baru dibuat atau disimpan), pilih instans database dari daftar drop-down. Informasi database akan dikonfigurasi secara otomatis.

      Catatan

      Di Konsol DMS, item konfigurasi ini bernama Select a DMS database instance..

    • Jika Anda belum menambahkan instans database ke sistem, atau tidak perlu menggunakan instans yang sudah ditambahkan, konfigurasikan informasi database berikut secara manual.

    Database Type

    Pilih MongoDB.

    Access Method

    Pilih Alibaba Cloud Instance.

    Instance Region

    Pilih wilayah instans sumber ApsaraDB for MongoDB.

    Replicate Data Across Alibaba Cloud Accounts

    Contoh ini menggunakan instans database yang dimiliki oleh Akun Alibaba Cloud saat ini. Pilih No.

    Architecture

    Dalam contoh ini, pilih Replica Set.

    Catatan

    Jika instans sumber ApsaraDB for MongoDB Anda adalah Sharded Cluster, Anda juga harus menentukan Shard account dan Shard password.

    Migration Method

    Pilih metode untuk sinkronisasi data inkremental berdasarkan kebutuhan Anda.

    • Oplog (Direkomendasikan):

      Opsi ini tersedia jika Oplog diaktifkan untuk database sumber.

      Catatan

      Oplog diaktifkan secara default untuk database MongoDB yang dikelola sendiri dan instans ApsaraDB for MongoDB. Metode ini menawarkan latensi lebih rendah untuk tugas sinkronisasi inkremental karena log diambil lebih cepat. Kami merekomendasikan memilih Oplog.

    • ChangeStream:

      Opsi ini tersedia jika Change Streams diaktifkan untuk database sumber.

      Catatan
      • Jika database sumber adalah instans Amazon DocumentDB (kluster non-elastis), Anda hanya dapat memilih ChangeStream.

      • Jika Anda mengatur Architecture database sumber ke Sharded Cluster, Anda tidak perlu menentukan Shard account dan Shard password.

    Instance ID

    Pilih ID instans sumber ApsaraDB for MongoDB.

    Authentication Database

    Masukkan nama database tempat akun database sumber berada di instans ApsaraDB for MongoDB. Nilai default adalah admin.

    Database Account

    Masukkan akun database instans sumber ApsaraDB for MongoDB. Untuk informasi tentang izin yang diperlukan, lihat Izin yang diperlukan untuk akun database.

    Database Password

    Masukkan kata sandi yang sesuai dengan akun database.

    Encryption

    DTS mendukung tiga metode koneksi: Non-encrypted, SSL-encrypted, dan Mongo Atlas SSL. Opsi untuk Encryption bervariasi berdasarkan Access Method dan Architecture yang dipilih. Opsi yang ditampilkan di konsol berlaku.

    Catatan
    • Database MongoDB dengan Architecture Sharded Cluster dan Migration Method Oplog tidak mendukung SSL-encrypted.

    • Jika sumber adalah database MongoDB yang dikelola sendiri (Access Method bukan Alibaba Cloud Instance) dengan arsitektur Replica Set, dan Anda memilih SSL-encrypted, DTS juga memungkinkan Anda mengunggah sertifikat CA untuk memverifikasi koneksi.

    Destination Database

    Select Existing Connection

    • Untuk menggunakan instans database yang ditambahkan ke sistem (baru dibuat atau disimpan), pilih instans database dari daftar drop-down. Informasi database akan dikonfigurasi secara otomatis.

      Catatan

      Di Konsol DMS, item konfigurasi ini bernama Select a DMS database instance..

    • Jika Anda belum menambahkan instans database ke sistem, atau tidak perlu menggunakan instans yang sudah ditambahkan, konfigurasikan informasi database berikut secara manual.

    Database Type

    Pilih MySQL.

    Access Method

    Pilih Alibaba Cloud Instance.

    Instance Region

    Pilih wilayah instans tujuan ApsaraDB RDS for MySQL.

    Replicate Data Across Alibaba Cloud Accounts

    Contoh ini menggunakan instans database yang dimiliki oleh Akun Alibaba Cloud saat ini. Pilih No.

    RDS Instance ID

    Pilih ID instans tujuan ApsaraDB RDS for MySQL.

    Database Account

    Masukkan akun database untuk instans tujuan ApsaraDB RDS for MySQL. Untuk informasi tentang izin yang diperlukan, lihat Izin yang diperlukan untuk akun database.

    Database Password

    Masukkan kata sandi yang sesuai dengan akun database.

    Encryption

    Pilih Non-encrypted atau SSL-encrypted sesuai kebutuhan. Jika Anda memilih SSL-encrypted, Anda harus mengaktifkan enkripsi SSL untuk instans RDS for MySQL terlebih dahulu. Untuk informasi selengkapnya, lihat Gunakan sertifikat cloud untuk mengaktifkan enkripsi SSL dengan cepat.

  4. Setelah menyelesaikan konfigurasi, klik Test Connectivity and Proceed di bagian bawah halaman.

    Catatan
    • Pastikan blok CIDR alamat IP server DTS telah ditambahkan ke pengaturan keamanan database sumber dan tujuan untuk mengizinkan akses dari server DTS. Hal ini dapat dilakukan secara otomatis atau manual. Untuk informasi selengkapnya, lihat Tambahkan blok CIDR alamat IP server DTS ke daftar putih.

    • Jika database sumber atau tujuan adalah database yang dikelola sendiri (di mana Access Method bukan Alibaba Cloud Instance), Anda juga harus mengklik Test Connectivity di kotak dialog CIDR Blocks of DTS Servers.

  5. Konfigurasikan objek tugas.

    1. Di halaman Configure Objects, konfigurasikan objek yang akan disinkronkan.

      Parameter

      Deskripsi

      Synchronization Types

      Incremental Data Synchronization dipilih. Anda hanya dapat memilih Full Data Synchronization. Schema Synchronization tidak didukung. Setelah pemeriksaan awal selesai, DTS menyinkronkan data objek yang dipilih dari instans sumber ke kluster tujuan. Ini berfungsi sebagai data garis dasar untuk sinkronisasi data inkremental berikutnya.

      Processing Mode of Conflicting Tables

      • Precheck and Report Errors: Memeriksa koleksi dengan nama yang sama di database tujuan. Jika ditemukan koleksi dengan nama yang sama, error dilaporkan dan tugas sinkronisasi data tidak dimulai. Jika tidak, pemeriksaan awal berhasil.

        Catatan

        Jika Anda tidak dapat menghapus atau mengganti nama koleksi dengan nama yang sama di database tujuan, Anda dapat mengubah nama koleksi di database tujuan. Untuk informasi selengkapnya, lihat Atur nama objek sinkronisasi di instans tujuan.

      • Ignore Errors and Proceed: Melewati pemeriksaan koleksi dengan nama yang sama di database tujuan.

        Peringatan

        Memilih Ignore Errors and Proceed dapat menyebabkan ketidakkonsistenan data dan membahayakan bisnis Anda. Misalnya:

        • Jika catatan di database tujuan memiliki nilai kunci primer atau kunci unik yang sama dengan catatan di database sumber, catatan di database tujuan dipertahankan. Catatan dari database sumber tidak disinkronkan ke database tujuan.

        • Hal ini dapat menyebabkan inisialisasi data gagal, hanya sebagian data yang disinkronkan, atau seluruh sinkronisasi gagal.

      Capitalization of Object Names in Destination Instance

      Anda dapat mengonfigurasi kebijakan sensitivitas huruf besar/kecil untuk nama objek database dan koleksi dalam bahasa Inggris yang disinkronkan ke instans tujuan. Anda dapat memilih DTS default policy, yang merupakan opsi default, atau menggunakan kebijakan default database sumber atau tujuan. Untuk informasi selengkapnya, lihat Kebijakan sensitivitas huruf besar/kecil untuk nama objek tujuan.

      Source Objects

      Di kotak Source Objects, klik objek yang akan disinkronkan, lalu klik 向右 untuk memindahkannya ke kotak Selected Objects.

      Catatan

      Anda hanya dapat memilih objek di tingkat koleksi.

      Selected Objects

      1. Petakan nama database.

        1. Di kotak Selected Objects, klik kanan database yang berisi koleksi yang akan disinkronkan.

        2. Ubah Schema Name menjadi nama database tujuan di instans ApsaraDB RDS for MySQL.

        3. Klik OK.

      2. Petakan nama tabel.

        1. Di kotak Selected Objects, klik kanan koleksi yang akan disinkronkan.

          Dalam contoh ini, jalur pohon objek tujuan adalah dtsdb > Table > class.

        2. Ubah Table Name menjadi nama tabel yang akan menerima data di instans tujuan ApsaraDB RDS for MySQL.

        3. Opsional: Atur kondisi filter untuk sinkronisasi data penuh. Untuk informasi selengkapnya, lihat Atur kondisi filter.

          Untuk ApsaraDB for MongoDB, sintaksis kondisi filter berbeda dari klausa WHERE SQL standar. Misalnya, untuk memfilter berdasarkan ID pengguna, masukkan {"_id": {$gt:"user100844658590795**",$lte:"user101674868045948**"}}. Dalam contoh ini, gt berarti "lebih besar dari", dan lte berarti "kurang dari atau sama dengan".

        4. Opsional: Di area Select DDL and DML Operations to Be Synchronized, pilih operasi untuk sinkronisasi data inkremental.

          Operasi DML yang dapat dipilih meliputi insert, update, dan delete. Operasi DDL yang dapat dipilih meliputi CREATE TABLE, DROP TABLE, dan ALTER TABLE.

      3. Konfigurasikan bidang yang akan disinkronkan dari MongoDB.

        DTS secara otomatis memetakan data koleksi yang akan disinkronkan dan mengonfigurasi ekspresi di kolom Parameter Value. Anda harus memeriksa apakah ekspresi tersebut memenuhi kebutuhan Anda dan mengonfigurasi parameter seperti Column Name, Type, Length, dan Precision.

        Penting
        • Anda harus memberikan nilai bson_value("_id") ke kolom kunci primer tabel tujuan.

        • Saat Anda mengonfigurasi ekspresi bson_value(), Anda harus menentukan jalur hingga subfield tingkat terendah dalam hierarki. Jika tidak, kehilangan data atau kegagalan tugas dapat terjadi.

        1. Di ekspresi bson_value() di kolom Parameter Value, lihat nama bidang di MongoDB.

          Nama bidang dalam "" adalah nama bidang di MongoDB. Misalnya, jika ekspresinya adalah bson_value("age"), bidang yang sesuai di MongoDB adalah age.

        2. Opsional: Hapus bidang yang tidak perlu disinkronkan.

          Catatan

          Untuk menghapus bidang yang tidak ingin disinkronkan, klik image di baris bidang tersebut.

        3. Konfigurasikan bidang yang akan disinkronkan.

          Ikuti langkah-langkah di bawah ini yang sesuai dengan ekspresi bson_value() Anda.

          Ekspresi valid

          1. Masukkan Column Name.

            Catatan

            Ini adalah nama kolom di tabel tujuan instans ApsaraDB RDS for MySQL.

          2. Pilih Type data untuk kolom tersebut.

            Penting

            Pastikan tipe data tabel tujuan kompatibel dengan data MongoDB sumber. Untuk informasi tentang pemetaan tipe data, lihat Pemetaan tipe data.

          3. Opsional: Konfigurasikan Length dan Precision data kolom.

          4. Ulangi langkah-langkah di atas untuk memetakan semua bidang yang relevan.

          Ekspresi tidak valid

          Catatan

          Misalnya, bidang dengan struktur hirarkis (parent-child).

          1. Di kolom Operation, klik image di baris bidang tersebut.

          2. Klik + Add Column.

          3. Konfigurasikan Column Name, Type, Length, dan Precision.

          4. Di kotak teks di bawah Parameter Value, masukkan ekspresi bson_value(). Untuk informasi selengkapnya, lihat Contoh penugasan nilai.

          5. Ulangi langkah-langkah di atas untuk memetakan semua bidang yang relevan.

      4. Klik OK.

    2. Klik Next: Advanced Settings untuk mengonfigurasi parameter lanjutan.

      Parameter

      Deskripsi

      Dedicated Cluster for Task Scheduling

      Secara default, DTS menjadwalkan tugas pada kluster bersama, dan Anda tidak perlu memilih kluster. Untuk kinerja yang lebih stabil, Anda dapat membeli kluster khusus untuk menjalankan tugas sinkronisasi DTS. Untuk informasi selengkapnya, lihat Apa itu kluster khusus DTS?.

      Retry Time for Failed Connections

      Setelah tugas sinkronisasi dimulai, jika koneksi ke database sumber atau tujuan gagal, DTS melaporkan error dan segera mulai mencoba koneksi ulang. Durasi percobaan ulang default adalah 720 menit. Anda juga dapat menentukan durasi percobaan ulang kustom dari 10 hingga 1.440 menit. Kami merekomendasikan agar Anda mengatur durasi minimal 30 menit. Jika DTS berhasil terhubung kembali ke database dalam durasi yang ditentukan, tugas sinkronisasi akan dilanjutkan secara otomatis. Jika tidak, tugas gagal.

      Catatan
      • Jika Anda memiliki beberapa instans DTS (misalnya, Instans A dan Instans B) yang berbagi sumber atau tujuan yang sama, dan Anda mengatur waktu percobaan ulang jaringan menjadi 30 menit untuk Instans A dan 60 menit untuk Instans B, durasi yang lebih pendek yaitu 30 menit akan digunakan untuk keduanya.

      • Karena DTS mengenakan biaya untuk waktu proses tugas selama periode percobaan ulang koneksi, kami merekomendasikan agar Anda menyesuaikan durasi percobaan ulang berdasarkan kebutuhan bisnis Anda atau segera melepas instans DTS setelah instans database sumber dan tujuan dilepas.

      Retry Time for Other Issues

      Setelah tugas sinkronisasi dimulai, jika terjadi masalah non-konektivitas lainnya pada database sumber atau tujuan (seperti exception eksekusi DDL atau DML), DTS melaporkan error dan segera mulai melakukan operasi percobaan ulang berkelanjutan. Durasi percobaan ulang default adalah 10 menit. Anda juga dapat menyesuaikan durasi percobaan ulang dalam rentang 1 hingga 1.440 menit. Kami merekomendasikan agar Anda mengaturnya minimal 10 menit. Jika operasi terkait berhasil dalam durasi percobaan ulang yang ditetapkan, tugas sinkronisasi akan dilanjutkan secara otomatis. Jika tidak, tugas gagal.

      Penting

      Nilai untuk Retry Time for Other Issues harus lebih kecil daripada Retry Time for Failed Connections.

      Enable Throttling for Full Data Synchronization

      Selama tahap sinkronisasi penuh, DTS mengonsumsi sumber daya baca dan tulis dari database sumber dan tujuan, yang dapat meningkatkan beban database. Untuk mengurangi beban pada database sumber dan tujuan, Anda dapat mengatur batas laju untuk tugas sinkronisasi penuh dengan mengonfigurasi parameter Queries per second (QPS) to the source database, RPS of Full Data Migration, dan Data migration speed for full migration (MB/s).

      Catatan
      • Item konfigurasi ini hanya tersedia ketika Synchronization Types diatur ke Full Data Synchronization.

      • Anda juga dapat menyesuaikan laju sinkronisasi penuh setelah instans sinkronisasi berjalan.

      Only one data type for primary key _id in a table of the data to be synchronized

      Menentukan apakah kunci primer _id memiliki tipe data tunggal dan konsisten dalam setiap koleksi yang akan disinkronkan.

      Penting
      • Pilih opsi berdasarkan data aktual Anda. Pemilihan yang salah dapat menyebabkan kehilangan data.

      • Parameter ini hanya tersedia jika Synchronization Types mencakup Full Data Synchronization.

      • Yes: Tipe data bersifat unik. Selama fase sinkronisasi penuh, DTS tidak memindai tipe data kunci primer di data sumber. Untuk setiap koleksi, DTS hanya menyinkronkan data yang sesuai dengan satu tipe data kunci primer.

      • No: Tipe data tidak unik. Selama fase sinkronisasi penuh, DTS memindai tipe data kunci primer di data sumber dan menyinkronkan semua data.

      Enable Throttling for Incremental Data Synchronization

      Anda juga dapat mengatur batas laju untuk tugas sinkronisasi inkremental. Untuk mengurangi tekanan pada database tujuan, atur RPS of Incremental Data Synchronization dan Data synchronization speed for incremental synchronization (MB/s).

      Environment Tag

      Anda dapat memilih tag lingkungan untuk mengidentifikasi instans berdasarkan kebutuhan bisnis Anda. Parameter ini tidak diperlukan dalam contoh ini.

      Configure ETL

      Pilih apakah akan mengaktifkan fitur ekstrak, transformasi, muat (ETL). Untuk informasi selengkapnya, lihat Apa itu ETL?. Nilai yang valid:

      Monitoring and Alerting

      Tentukan apakah akan mengonfigurasi peringatan. Jika sinkronisasi gagal atau latensi melebihi ambang batas yang ditentukan, notifikasi akan dikirim ke kontak peringatan.

  6. Simpan tugas dan jalankan pemeriksaan awal.

    • Untuk melihat parameter API untuk mengonfigurasi instans ini, arahkan kursor ke tombol Next: Save Task Settings and Precheck dan klik Preview OpenAPI parameters di gelembung.

    • Jika Anda telah selesai melihat parameter API, klik Next: Save Task Settings and Precheck di bagian bawah halaman.

    Catatan
    • Sebelum pekerjaan sinkronisasi dimulai, DTS menjalankan pemeriksaan awal. Pekerjaan hanya dapat dimulai setelah semua item pemeriksaan awal lolos.

    • Jika pemeriksaan awal gagal, klik View Details untuk item yang gagal. Perbaiki masalah sesuai petunjuk, lalu jalankan pemeriksaan awal lagi.

    • Jika pemeriksaan awal mengembalikan peringatan:

      • Jika item pemeriksaan gagal dan tidak dapat diabaikan, klik View Details di sebelah item tersebut. Ikuti petunjuk untuk memperbaiki masalah, lalu jalankan pemeriksaan awal lagi.

      • Untuk item pemeriksaan yang dapat diabaikan, Anda dapat mengklik Confirm Alert Details, Ignore, OK, dan Precheck Again secara berurutan untuk melewati peringatan dan menjalankan pemeriksaan awal lagi. Jika Anda memilih untuk mengabaikan item peringatan, hal ini dapat menyebabkan masalah seperti ketidakkonsistenan data dan menimbulkan risiko bagi bisnis Anda.

  7. Beli instans sinkronisasi.

    1. Saat Success Rate mencapai 100%, klik Next: Purchase Instance.

    2. Di halaman Purchase, pilih metode penagihan dan spesifikasi link untuk instans sinkronisasi data. Tabel berikut menjelaskan parameter ini secara detail.

      Kategori

      Parameter

      Deskripsi

      New Instance Class

      Metode Penagihan

      • Langganan: Anda membayar saat membuat instans. Ini cocok untuk kebutuhan jangka panjang dan lebih hemat biaya daripada bayar sesuai penggunaan. Semakin lama durasi langganan, semakin tinggi diskonnya.

      • Bayar sesuai penggunaan: Anda dikenai biaya per jam. Ini cocok untuk kebutuhan jangka pendek. Anda dapat melepas instans segera setelah digunakan untuk menghemat biaya.

      Konfigurasi Kelompok Sumber Daya

      Kelompok sumber daya tempat instans tersebut berada. Default-nya adalah kelompok sumber daya default. Untuk informasi selengkapnya, lihat Apa itu Resource Management?.

      Spesifikasi Link

      DTS menyediakan spesifikasi sinkronisasi dengan tingkat kinerja berbeda. Spesifikasi link sinkronisasi memengaruhi laju sinkronisasi. Anda dapat memilih spesifikasi berdasarkan skenario bisnis Anda. Untuk informasi selengkapnya, lihat Spesifikasi link sinkronisasi data.

      Durasi Langganan

      Dalam mode langganan, pilih durasi dan jumlah untuk instans langganan. Anda dapat memilih langganan bulanan dari 1 hingga 9 bulan, atau langganan tahunan 1, 2, 3, atau 5 tahun.

      Catatan

      Opsi ini hanya tersedia ketika metode penagihan adalah Subscription.

    3. Setelah menyelesaikan konfigurasi, baca dan pilih Data Transmission Service (Pay-as-you-go) Service Terms.

    4. Klik Buy and Start. Di kotak dialog OK, klik OK.

      Anda dapat melihat progres tugas di halaman Data Synchronization.

Pemetaan Tipe Data

Tipe Data MongoDB

Tipe Data MySQL

ObjectId

VARCHAR

String

VARCHAR

Document

VARCHAR

DbPointer

VARCHAR

Array

VARCHAR

Date

DATETIME

TimeStamp

DATETIME

Double

DOUBLE

Integer 32-bit (BsonInt32)

INTEGER

Integer 64-bit (BsonInt64)

BIGINT

Decimal128

DECIMAL

Boolean

BOOLEAN

Null

VARCHAR

Contoh Konfigurasi Nilai

Struktur Data MongoDB Sumber

{
  "_id":"62cd344c85c1ea6a2a9f****",
  "person":{
    "name":"neo",
    "age":26,
    "sex":"male"
  }
}

Struktur Tabel MySQL Tujuan

Nama Kolom

Tipe

mongo_id

varchar

Catatan

Kolom kunci primer.

person_name

varchar

person_age

decimal

Konfigurasi Kolom Baru

Penting

Anda harus menentukan jalur hierarkis lengkap dalam ekspresi bson_value() untuk mencegah kehilangan data atau kegagalan tugas. Misalnya, jika Anda mengatur ekspresi menjadi bson_value("person"), DTS tidak dapat menyinkronkan data inkremental dari subfield objek person (seperti name, age, dan sex) ke tujuan.

Nama Kolom

Type

Penugasan

mongo_id

STRING

bson_value("_id")

person_name

STRING

bson_value("person","name")

person_age

DECIMAL

bson_value("person","age")