Practical উদাহরণ: Locking এবং Concurrency Management

JPA তে Optimistic এবং Pessimistic Locking - জেপিএ  (JPA) - Java Technologies

332

JPA (Java Persistence API) তে locking এবং concurrency management ডেটাবেসের সাথে একাধিক থ্রেডের মাধ্যমে নিরাপদে কাজ করার জন্য ব্যবহৃত হয়। এটি বিশেষ করে multi-user অ্যাপ্লিকেশনগুলোতে গুরুত্বপূর্ণ, যেখানে একাধিক ব্যবহারকারী একই ডেটা আপডেট করার চেষ্টা করতে পারে এবং data consistency বজায় রাখা প্রয়োজন।

JPA তে locking এবং concurrency control দুটি মূল কৌশল রয়েছে:

  1. Optimistic Locking
  2. Pessimistic Locking

এই দুটি কৌশল ব্যবহার করে ডেটাবেসে সঠিকভাবে concurrency handling করা যায়।

1. Optimistic Locking


Optimistic Locking তখন ব্যবহার করা হয় যখন আপনি মনে করেন যে খুব কম সময়ের জন্য একই রেকর্ড একাধিক ব্যবহারকারী অ্যাক্সেস করবে। এখানে, আপনি ডেটা লক না করে একটি ভ্যালিডেশন ব্যবহার করেন, এবং পরে ডেটা আপডেট করার সময় যদি কোন কনফ্লিক্ট থাকে, তাহলে ডেটাবেস একটি ত্রুটি প্রদান করে।

Optimistic Locking সাধারণত versioning এর মাধ্যমে করা হয়, যেখানে একটি version ফিল্ড থাকে এবং সেই ফিল্ডের মান প্রতিটি আপডেটের সময় বৃদ্ধি পায়।

Optimistic Locking Example:

Step 1: Entity Class with Versioning

import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Version;

@Entity
public class Product {
    @Id
    private Long id;
    
    private String name;
    private double price;
    
    @Version
    private int version;  // Version field for optimistic locking
    
    // Getters and Setters
}

এখানে, @Version অ্যানোটেশন দিয়ে version ফিল্ডকে চিহ্নিত করা হয়েছে, যা প্রতি আপডেটের সময় বাড়ানো হবে। যদি দুইটি ইউজার একই সময় ডেটা আপডেট করার চেষ্টা করে, তখন version চেক করা হবে এবং কনফ্লিক্ট হলে একটি OptimisticLockException ছোঁড়া হবে।

Step 2: Usage of Optimistic Locking

EntityManager em = entityManagerFactory.createEntityManager();
em.getTransaction().begin();

// Retrieve product from database
Product product = em.find(Product.class, 1L);

// Update product details
product.setPrice(200.0);

try {
    em.getTransaction().commit(); // Try to commit changes
} catch (OptimisticLockException ole) {
    // Handle conflict, notify user
    em.getTransaction().rollback();
}

এখানে, OptimisticLockException হলে, অর্থাৎ একই version সহ একাধিক পরিবর্তন ঘটলে, টেনশন এবং কনফ্লিক্ট হ্যান্ডলিং করা হবে।


2. Pessimistic Locking


Pessimistic Locking তখন ব্যবহৃত হয় যখন আপনি চান যে কোনো রেকর্ড একবারে একটি থ্রেড/ব্যবহারকারী দ্বারা এক্সেস করা হোক এবং অন্য কোন থ্রেড বা ব্যবহারকারী সেই রেকর্ডে কোনো পরিবর্তন করতে না পারে। এটি তখন ব্যবহার করা হয় যখন আপনি নিশ্চিত হতে চান যে, একাধিক ব্যবহারকারী একই সময়ে একই রেকর্ডে কাজ করবে না।

JPA তে Pessimistic Locking PESSIMISTIC_READ এবং PESSIMISTIC_WRITE হিসাবে দুইটি ধরনের লক প্রদান করে।

  • PESSIMISTIC_READ: রেকর্ডটি অন্য কেউ লিখতে না পারে, তবে অন্য কেউ রেকর্ডটি পড়তে পারবে।
  • PESSIMISTIC_WRITE: রেকর্ডটি অন্য কেউ পড়তে বা লিখতে পারবে না, এটি সম্পূর্ণভাবে লক করা হয়।

Pessimistic Locking Example:

Step 1: Entity Class

import javax.persistence.Entity;
import javax.persistence.Id;

@Entity
public class Account {
    @Id
    private Long id;
    private double balance;
    
    // Getters and Setters
}

Step 2: Using Pessimistic Locking

EntityManager em = entityManagerFactory.createEntityManager();
em.getTransaction().begin();

// Pessimistic locking on Account record
Account account = em.createQuery("SELECT a FROM Account a WHERE a.id = :id", Account.class)
                    .setParameter("id", 1L)
                    .setLockMode(LockModeType.PESSIMISTIC_WRITE) // Lock for update
                    .getSingleResult();

// Modify the balance
account.setBalance(account.getBalance() + 100.0);
em.getTransaction().commit();

এখানে, PESSIMISTIC_WRITE লকিং ব্যবহার করা হয়েছে, যা নিশ্চিত করে যে একবারে শুধুমাত্র একটি থ্রেড/ব্যবহারকারী এই রেকর্ডে কাজ করতে পারবে এবং অন্যদের রেকর্ডটি এক্সেস করার অনুমতি হবে না।


Pessimistic vs Optimistic Locking

বৈশিষ্ট্যOptimistic LockingPessimistic Locking
লকিং কৌশললকিং ছাড়াই কনফ্লিক্ট চেক করা হয়।রেকর্ড সম্পূর্ণ লক করা হয়।
পারফরম্যান্সউচ্চ পারফরম্যান্স, কারণ লকিং প্রক্রিয়া কম।কম পারফরম্যান্স, কারণ রেকর্ড লক করা হয়।
কনফ্লিক্ট হ্যান্ডলিংকনফ্লিক্ট হলে OptimisticLockException ছোঁড়া হয়।কনফ্লিক্ট হলে অপেক্ষা করতে হয়।
ব্যবহারকম সম্ভাব্য কনফ্লিক্টের ক্ষেত্রে।উচ্চ কনফ্লিক্টের ক্ষেত্রে ব্যবহৃত হয়।

Concurrency Management in JPA


Concurrency Management হল এমন একটি প্রক্রিয়া যেখানে একাধিক থ্রেড বা ব্যবহারকারী একসাথে ডেটাবেসের রেকর্ডগুলো এক্সেস বা পরিবর্তন করার সময় ডেটার সঠিকতা নিশ্চিত করা হয়। JPA তে locking মেকানিজম দিয়ে concurrency control করা হয়, যা দুটি ধাপে কাজ করে:

  1. Optimistic Locking: যেখানে versioning বা timestamp ব্যবহার করে কনফ্লিক্ট চেক করা হয়।
  2. Pessimistic Locking: যেখানে রেকর্ডকে একসাথে একাধিক থ্রেড/ব্যবহারকারী দ্বারা পরিবর্তন করার জন্য লক করা হয়।

Concurrency Handling Example

// Using Optimistic Locking
EntityManager em = entityManagerFactory.createEntityManager();
em.getTransaction().begin();

Product product = em.find(Product.class, 1L);  // Fetching product
product.setPrice(100.0);  // Updating product price

try {
    em.getTransaction().commit();  // Committing the transaction
} catch (OptimisticLockException ole) {
    em.getTransaction().rollback();
    // Handle the exception by notifying the user or retry logic
}

Conclusion


JPA তে Locking এবং Concurrency Management ডেটাবেসের রেকর্ডের প্রতি একাধিক থ্রেডের অ্যাক্সেস নিয়ন্ত্রণ করার জন্য অত্যন্ত গুরুত্বপূর্ণ। Optimistic Locking ছোট অ্যাপ্লিকেশনে বা যেখানে কম কনফ্লিক্ট হয় এমন সিচুয়েশনে ভালো কাজ করে, এবং Pessimistic Locking যখন উচ্চ কনফ্লিক্ট থাকতে পারে তখন সবচেয়ে কার্যকরী। JPA-তে এই কৌশলগুলি কার্যকরভাবে ব্যবহার করা হলে, ডেটাবেসের নিরাপত্তা এবং পারফরম্যান্স উভয়ই উন্নত করা সম্ভব।

Content added By
Promotion

Are you sure to start over?

Loading...