Jadual Kandungan
1. Prakata
2. Suara yang berbeza
1. Urutan operasi
2. Sikap semasa berurusan dengan cache
3. Analisis konkurensi benang
Mencari data
1. Persekitaran bukan serentak
2. Persekitaran serentak
Kemas kini data
1 >
Penyelesaian
Keadaan khas
Rumah Java javaTutorial Apakah pangkalan data dan skema ketekalan data cache untuk pengaturcaraan serentak Java?

Apakah pangkalan data dan skema ketekalan data cache untuk pengaturcaraan serentak Java?

Apr 24, 2023 am 08:28 AM
java pangkalan data

1. Prakata

Dalam sistem serentak teragih, pangkalan data dan ketekalan data cache ialah kesukaran teknikal yang mencabar. Dengan mengandaikan terdapat penyelesaian transaksi teragih gred industri yang lengkap, maka konsistensi pangkalan data dan data cache akan dapat diselesaikan dengan mudah Malah, transaksi yang diedarkan pada masa ini tidak matang.

2. Suara yang berbeza

Dalam pangkalan data dan penyelesaian ketekalan data cache, terdapat pelbagai suara.

  • Pangkalan data operasi dahulu dan kemudian cache atau cache dahulu dan kemudian pangkalan data

  • Sekiranya cache dikemas kini atau dipadamkan

1. Urutan operasi

Dalam sistem serentak, dalam senario dwi-tulis pangkalan data dan cache, untuk mengejar keselarasan yang lebih besar, operasi pada pangkalan data dan cache jelas tidak akan dilakukan secara serentak. Operasi terdahulu berjaya dan operasi kedua dilakukan dalam cara tak segerak.

Sebagai penyelesaian storan data gred industri yang matang, pangkalan data hubungan mempunyai mekanisme pemprosesan transaksi yang lengkap Setelah data diletakkan pada cakera, tanpa mengira kegagalan perkakasan, ia boleh dikatakan secara bertanggungjawab bahawa data itu tidak akan berlaku hilang.

Cache yang dipanggil tidak lebih daripada data yang disimpan dalam memori Setelah perkhidmatan dimulakan semula, semua data cache akan hilang. Oleh kerana ia dipanggil caching, bersiaplah untuk kehilangan data cache pada setiap masa. Walaupun Redis mempunyai mekanisme kegigihan, bolehkah ia menjamin 100% kegigihan? Redis menyimpan data ke cakera secara tidak segerak Cache adalah cache, dan pangkalan data adalah dua perkara yang berbeza. Menggunakan cache sebagai pangkalan data adalah sangat berbahaya.

Dari perspektif keselamatan data, pangkalan data dikendalikan dahulu, dan kemudian cache dikendalikan secara tak segerak untuk bertindak balas kepada permintaan pengguna.

2. Sikap semasa berurusan dengan cache

Sama ada cache dikemas kini atau dipadamkan, sepadan dengan gaya malas dan gaya penuh Dari perspektif amalan keselamatan benang, pemadaman operasi cache adalah agak sukar. Jika prestasi pertanyaan berpuas hati di bawah premis pemadaman cache, maka pemadaman cache lebih diutamakan.

Walaupun mengemas kini cache boleh meningkatkan kecekapan pertanyaan, data kotor serentak yang disebabkan oleh urutan lebih menyusahkan untuk diproses Mukadimah memperkenalkan perisian tengah mesej lain seperti MQ, jadi ia tidak disyorkan melainkan perlu.

3. Analisis konkurensi benang

Kunci untuk memahami masalah yang disebabkan oleh konkurensi benang adalah terlebih dahulu memahami gangguan sistem Apabila sistem pengendalian menjadualkan tugas, gangguan berlaku pada bila-bila masa oleh ketidakkonsistenan data benang. Mengambil CPU 4 dan 8 utas sebagai contoh, sehingga 8 utas boleh diproses pada masa yang sama Walau bagaimanapun, sistem pengendalian menguruskan lebih daripada 8 utas, jadi utas berjalan dalam cara yang kelihatan selari.

Mencari data

1. Persekitaran bukan serentak

Dalam persekitaran bukan serentak, tiada salahnya menanyakan data dengan cara berikut: tanya cache dahulu. Jika data cache tidak wujud, Tanya pangkalan data, kemas kini cache dan kembalikan hasilnya.

public BuOrder getOrder(Long orderId) {
    String key = ORDER_KEY_PREFIX + orderId;
    BuOrder buOrder = RedisUtils.getObject(key, BuOrder.class);
    if (buOrder != null) {
        return buOrder;
    }
    BuOrder order = getById(orderId);
    RedisUtils.setObject(key, order, 5, TimeUnit.MINUTES);
    return order;
}
Salin selepas log masuk

Jika terdapat kecacatan serius dalam persekitaran berkonkurensi tinggi: apabila cache gagal, sejumlah besar permintaan pertanyaan masuk, semuanya mencecah DB dalam sekelip mata Sumber sambungan pangkalan data keletihan, dan pelanggan bertindak balas dengan Ralat 500, atau lebih serius, pangkalan data mungkin berada di bawah tekanan terlalu banyak dan perkhidmatan mungkin ditutup.

2. Persekitaran serentak

Oleh itu, dalam persekitaran serentak, kod di atas perlu diubah suai dan kunci yang diedarkan digunakan. Apabila sebilangan besar permintaan masuk, benang yang memperoleh kunci mempunyai peluang untuk mengakses pangkalan data untuk menanyakan data, dan benang yang tinggal disekat. Apabila data disoal dan cache dikemas kini, kunci kemudiannya dilepaskan. Benang menunggu menyemak semula cache dan mendapati bahawa data boleh diperolehi dan bertindak balas terus kepada data cache.

Kunci teragih disebut di sini, jadi patutkah kita menggunakan kunci meja atau kunci baris? Gunakan kunci baris yang diedarkan untuk meningkatkan konkurensi; gunakan mekanisme semakan kedua untuk memastikan bahawa urutan yang menunggu untuk mendapatkan kunci dapat mengembalikan hasil dengan cepat

@Override
public BuOrder getOrder(Long orderId) {
    /* 如果缓存不存在,则添加分布式锁更新缓存 */
    String key = ORDER_KEY_PREFIX + orderId;
    BuOrder order = RedisUtils.getObject(key, BuOrder.class);
    if (order != null) {
        return order;
    }
    String orderLock = ORDER_LOCK + orderId;
    RLock lock = redissonClient.getLock(orderLock);
    if (lock.tryLock()) {
        order = RedisUtils.getObject(key, BuOrder.class);
        if (order != null) {
            LockOptional.ofNullable(lock).ifLocked(RLock::unlock);
            return order;
        }
        BuOrder buOrder = getById(orderId);
        RedisUtils.setObject(key, buOrder, 5, TimeUnit.MINUTES);
        LockOptional.ofNullable(lock).ifLocked(RLock::unlock);
    }
    return RedisUtils.getObject(key, BuOrder.class);
}
Salin selepas log masuk

Kemas kini data

1 >
Dalam persekitaran bukan serentak, kod berikut mungkin menyebabkan ketidakkonsistenan data (data ditimpa). Walaupun menggunakan penguncian optimistik peringkat pangkalan data boleh menyelesaikan masalah data yang ditimpa, trafik kemas kini yang tidak sah akan tetap mengalir ke pangkalan data.

public Boolean editOrder(BuOrder order) {
    /* 更新数据库 */
    updateById(order);
    /* 删除缓存 */
    RedisUtils.deleteObject(OrderServiceImpl.ORDER_KEY_PREFIX + order.getOrderId());
    return true;
}
Salin selepas log masuk
2. Persekitaran serentak
Dalam analisis di atas, penggunaan penguncian optimistik pangkalan data boleh menyelesaikan masalah data yang ditimpa dalam kemas kini serentak diubah suai, nombor versi berubah , permintaan serentak berikutnya kepada pangkalan data adalah trafik tidak sah. Strategi utama untuk mengurangkan tekanan pangkalan data adalah untuk memintas trafik tidak sah sebelum pangkalan data.

Menggunakan kunci teragih boleh memastikan trafik serentak mengakses pangkalan data dengan cara yang teratur Memandangkan penguncian optimistik telah digunakan pada peringkat pangkalan data, urutan kedua dan seterusnya yang memperoleh kunci mengendalikan pangkalan data sebagai trafik tidak sah.

Urutan menggunakan strategi keluar tamat masa apabila memperoleh kunci Ulir yang menunggu kunci akan tamat masa dan keluar dengan cepat, membalas permintaan pengguna dengan cepat dan mencuba semula operasi data kemas kini.

public Boolean editOrder(BuOrder order) {
    String orderLock = ORDER_LOCK + order.getOrderId();
    RLock lock = redissonClient.getLock(orderLock);
    try {
        /* 超时未获取到锁,快速失败,用户端重试 */
        if (lock.tryLock(1, TimeUnit.SECONDS)) {
            /* 更新数据库 */
            updateById(order);
            /* 删除缓存 */
            RedisUtils.deleteObject(OrderServiceImpl.ORDER_KEY_PREFIX + order.getOrderId());
            /* 释放锁 */
            LockOptional.ofNullable(lock).ifLocked(RLock::unlock);
            return true;
        }
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    return false;
}
Salin selepas log masuk
Bergantung kepada alam sekitar

Kod di atas menggunakan kelas alat yang merangkum kunci.

<dependency>
  <groupId>xin.altitude.cms</groupId>
  <artifactId>ucode-cms-common</artifactId>
  <version>1.4.3.2</version>
</dependency>
Salin selepas log masuk

Lakukan operasi seterusnya berdasarkan status kunci. LockOptional

4. Pangkalan data dahulu, kemudian cache

Konsistensi data

1 Penerangan masalah
Seterusnya, kita akan membincangkan sama ada terdapat keselarasan dalam pengemaskinian pangkalan data. pertama dan kemudian memadamkan soalan cache.

(1) Cache baru sahaja tamat tempoh

(2) Minta A untuk menanyakan pangkalan data dan dapatkan nilai lama
(3) Minta B untuk menulis nilai baharu ke dalam pangkalan data
( 4) Minta B untuk memadam Cache
(5) Minta A untuk menulis nilai lama yang ditemui pada cache

Kunci kepada masalah konkurensi di atas ialah langkah 5 berlaku selepas langkah 3 dan 4. Ia boleh dilihat daripada faktor gangguan sistem pengendalian yang tidak pasti bahawa situasi ini mungkin berlaku.

2. Penyelesaian

Dari sudut pandangan praktikal, menulis data ke Redis mengambil masa yang jauh lebih singkat daripada menulis data ke pangkalan data Walaupun kebarangkalian kejadian adalah rendah, ia akan tetap berlaku. .

  • (1) Tingkatkan masa tamat tempoh cache

Tingkatkan masa tamat tempoh cache untuk membenarkan data kotor wujud dalam julat masa tertentu sehingga kemas kini serentak seterusnya berlaku, Data kotor mungkin berlaku. Data kotor wujud secara berkala.

  • (2) Kemas kini dan pertanyaan berkongsi kunci baris

Kemas kini dan pertanyaan berkongsi kunci teragih baris, dan masalah di atas tidak wujud lagi wujud. Apabila permintaan baca memperoleh kunci, permintaan tulis berada dalam keadaan disekat (tamat masa akan gagal dan kembali dengan cepat), memastikan langkah 5 dilakukan sebelum langkah 3.

  • (3) Tangguhkan pemadaman cache

Gunakan RabbitMQ untuk menangguhkan pemadaman cache untuk mengalih keluar kesan langkah 5. Menggunakan kaedah tak segerak hampir tiada kesan ke atas prestasi.

Keadaan khas

Pangkalan data mempunyai mekanisme transaksi untuk memastikan kejayaan operasi satu arahan Redis, tetapi kemudian digabungkan ia tidak mempunyai ciri-ciri atomik berjaya, dan kemudian aplikasi Ia menutup secara tidak normal, menyebabkan cache Redis tidak dipadamkan. Masalah ini berlaku apabila sambungan rangkaian perkhidmatan Redis tamat masa.

Jika masa tamat tempoh cache ditetapkan, data kotor akan sentiasa wujud sebelum cache tamat tempoh. Jika masa tamat tempoh tidak ditetapkan, data kotor akan wujud sehingga kali berikutnya data diubah suai. (Data pangkalan data telah berubah dan cache belum dikemas kini)

Penyelesaian

Sebelum mengendalikan pangkalan data, tulis mesej pemadaman cache tertunda kepada RabbitMQ, kemudian laksanakan operasi pangkalan data dan laksanakan cache operasi pemadaman. Tidak kira sama ada cache peringkat kod berjaya dipadamkan, MQ memadamkan cache sebagai operasi terjamin.

Atas ialah kandungan terperinci Apakah pangkalan data dan skema ketekalan data cache untuk pengaturcaraan serentak Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Soalan Temuduga Java Spring Soalan Temuduga Java Spring Aug 30, 2024 pm 04:29 PM

Dalam artikel ini, kami telah menyimpan Soalan Temuduga Spring Java yang paling banyak ditanya dengan jawapan terperinci mereka. Supaya anda boleh memecahkan temuduga.

Cuti atau kembali dari Java 8 Stream Foreach? Cuti atau kembali dari Java 8 Stream Foreach? Feb 07, 2025 pm 12:09 PM

Java 8 memperkenalkan API Stream, menyediakan cara yang kuat dan ekspresif untuk memproses koleksi data. Walau bagaimanapun, soalan biasa apabila menggunakan aliran adalah: bagaimana untuk memecahkan atau kembali dari operasi foreach? Gelung tradisional membolehkan gangguan awal atau pulangan, tetapi kaedah Foreach Stream tidak menyokong secara langsung kaedah ini. Artikel ini akan menerangkan sebab -sebab dan meneroka kaedah alternatif untuk melaksanakan penamatan pramatang dalam sistem pemprosesan aliran. Bacaan Lanjut: Penambahbaikan API Java Stream Memahami aliran aliran Kaedah Foreach adalah operasi terminal yang melakukan satu operasi pada setiap elemen dalam aliran. Niat reka bentuknya adalah

Program Java untuk mencari kelantangan kapsul Program Java untuk mencari kelantangan kapsul Feb 07, 2025 am 11:37 AM

Kapsul adalah angka geometri tiga dimensi, terdiri daripada silinder dan hemisfera di kedua-dua hujungnya. Jumlah kapsul boleh dikira dengan menambahkan isipadu silinder dan jumlah hemisfera di kedua -dua hujungnya. Tutorial ini akan membincangkan cara mengira jumlah kapsul yang diberikan dalam Java menggunakan kaedah yang berbeza. Formula volum kapsul Formula untuk jumlah kapsul adalah seperti berikut: Kelantangan kapsul = isipadu isipadu silinder Dua jumlah hemisfera dalam, R: Radius hemisfera. H: Ketinggian silinder (tidak termasuk hemisfera). Contoh 1 masukkan Jejari = 5 unit Ketinggian = 10 unit Output Jilid = 1570.8 Unit padu menjelaskan Kirakan kelantangan menggunakan formula: Kelantangan = π × r2 × h (4

Bagaimana untuk menjalankan aplikasi boot musim bunga pertama anda di Spring Tool Suite? Bagaimana untuk menjalankan aplikasi boot musim bunga pertama anda di Spring Tool Suite? Feb 07, 2025 pm 12:11 PM

Spring Boot memudahkan penciptaan aplikasi Java yang mantap, berskala, dan siap pengeluaran, merevolusi pembangunan Java. Pendekatan "Konvensyen Lebih Konfigurasi", yang wujud pada ekosistem musim bunga, meminimumkan persediaan manual, Allo

Cipta Masa Depan: Pengaturcaraan Java untuk Pemula Mutlak Cipta Masa Depan: Pengaturcaraan Java untuk Pemula Mutlak Oct 13, 2024 pm 01:32 PM

Java ialah bahasa pengaturcaraan popular yang boleh dipelajari oleh pembangun pemula dan berpengalaman. Tutorial ini bermula dengan konsep asas dan diteruskan melalui topik lanjutan. Selepas memasang Kit Pembangunan Java, anda boleh berlatih pengaturcaraan dengan mencipta program "Hello, World!" Selepas anda memahami kod, gunakan gesaan arahan untuk menyusun dan menjalankan program, dan "Hello, World!" Pembelajaran Java memulakan perjalanan pengaturcaraan anda, dan apabila penguasaan anda semakin mendalam, anda boleh mencipta aplikasi yang lebih kompleks.

Mysql: Konsep mudah untuk pembelajaran mudah Mysql: Konsep mudah untuk pembelajaran mudah Apr 10, 2025 am 09:29 AM

MySQL adalah sistem pengurusan pangkalan data sumber terbuka. 1) Buat Pangkalan Data dan Jadual: Gunakan perintah Createdatabase dan Createtable. 2) Operasi Asas: Masukkan, Kemas kini, Padam dan Pilih. 3) Operasi lanjutan: Sertai, subquery dan pemprosesan transaksi. 4) Kemahiran Debugging: Semak sintaks, jenis data dan keizinan. 5) Cadangan Pengoptimuman: Gunakan indeks, elakkan pilih* dan gunakan transaksi.

Java Made Simple: Panduan Pemula untuk Kuasa Pengaturcaraan Java Made Simple: Panduan Pemula untuk Kuasa Pengaturcaraan Oct 11, 2024 pm 06:30 PM

Java Made Simple: Panduan Permulaan untuk Kuasa Pengaturcaraan Pengenalan Java ialah bahasa pengaturcaraan berkuasa yang digunakan dalam segala-galanya daripada aplikasi mudah alih hingga sistem peringkat perusahaan. Untuk pemula, sintaks Java adalah ringkas dan mudah difahami, menjadikannya pilihan ideal untuk pembelajaran pengaturcaraan. Sintaks Asas Java menggunakan paradigma pengaturcaraan berorientasikan objek berasaskan kelas. Kelas ialah templat yang menyusun data dan tingkah laku yang berkaitan bersama-sama. Berikut ialah contoh kelas Java yang mudah: publicclassPerson{privateStringname;privateintage;

Program Java untuk memasukkan elemen di bahagian bawah timbunan Program Java untuk memasukkan elemen di bahagian bawah timbunan Feb 07, 2025 am 11:59 AM

Stack adalah struktur data yang mengikuti prinsip LIFO (terakhir, pertama keluar). Dalam erti kata lain, elemen terakhir yang kita tambahkan pada timbunan adalah yang pertama dikeluarkan. Apabila kita menambah (atau menolak) unsur ke timbunan, mereka diletakkan di atas; iaitu di atas semua

See all articles