Programmation concurrente en Java

Florian Beaufumé
Florian BeaufuméFreelance software architect and developer. Java and backend expert. Angular and Kotlin intermediate.
Programmation concurrente en Java
Florian Beaufumé
03/2017
Florian Beaufumé
• Architecte logiciel Java et web
• Freelance
• florian.beaufume@adeliosys.fr
• www.adeliosys.fr
• www.linkedin.com/in/fbeaufume
• fr.slideshare.net/fbeaufume
• Concepts
• Java SE
• Java EE et Spring
Sommaire
Concepts
• "Le nombre de transistor double tous les deux ans"
• "La fréquence double chaque 1,5 année"
Lois de Moore
• Concurrence :
• Des tâches qui peuvent se chevaucher
• Alternées ou pas
• Parallélisme :
• Exécution simultanées au niveau matériel
Concurrence vs parallélisme
• Gain maximal de latence suivant la part parallélisable du
traitement
Loi d'Amdahl
• Processus découpé en threads
• Natif vs green
• Ordonnancement préemptif vs coopératif
• Time slicing
• Fonctionnalités de distribution et coordination
• Bénéfices
• Utilisation des ressources
• Réactivité
• Couts
• Complexité de conception et débugging
• Ressources par thread et context switching
Modèle multi-threads
• Thread safe < Immutable < Stateless
• Section critique
• Opération atomique
• Contention
• Deadlock
• Starvation
Définitions
Java SE
• Concurrence intégrée au langage
• Basé sur des threads :
• Nom
• Priorité : 1 à 10
• Daemon ou pas
• Etat : NEW, RUNNABLE, BLOCKED, WAITING, etc.
• Pile d'appel
• Exemple :
• Mémoire partagée suivant le Java Memory Model
Java 1.0
Java 1.0 - Threads de base
• Synchronisation de threads pour accéder à des données
Java 1.0 - Synchronized
• Permet d'implémenter un scope request :
• Sécurité (identité, droits)
• Transaction
• Tenant
• Java 1.2 : InheritableThreadLocal
Java 1.0 - ThreadLocal
• Exemple java.util.Timer :
• Un thread par timer
• Pas de garantie d'exécution
Java 1.3 - Timers
Programmation concurrente en Java
• Ajout de java.util.concurrent, merci Doug Lea
• Java Memory Model
• Interactions entre les threads
et la mémoire
• "Happens before"
• Volatile :
• R et W en mémoire principale
plutôt que sur cache CPU
• Rend R et W 64 bits (long et
double) atomique
• Mais pas un incrément
• Permet de la synchronisation
simple
Java 5
• Volatile seul
• Synchronized en écriture + volatile
Java 5 - Volatile
• Singleton lazy loadé classique
• Via double checked locking
Java 5 - Double checked locking
• ReentrantLock
• ReentrantReadWriteLock
Java 5 - Locks
• Coordination de threads sur des étapes
Java 5 - CountDownLatch
main
workers
await()
countdown()
• Map<K, V>
• Hashtable : synchronisée, clés et valeurs non null
• HashMap : pas synchronisée, accepte clés et valeurs nulles
• ConcurrentMap<K, V>
• Etend Map<K, V>
• Méthodes atomiques comme putIfAbsent(key, value)
• ConcurrentHashMap, implémentation efficace
Java 5 - ConcurrentHashMap
• Exécution de tâches sur pool de threads
Java 5 - Executors (1/2)
Executor
Executor
Service
ThreadPool
Executor
Interfaces Classes
Scheduled
Executor
Service
Scheduled
ThreadPool
Executor
void execute(Runnable)
Supporte Future, ex :
Future<T> submit(Callable<T> task)
Supporte scheduling, ex :
ScheduledFuture scheduleAtFixedRate(
Runnable command,
long initialDelay,
long period,
TimeUnit unit)
Java 5 - Executors (2/2)
• Nombres atomiques
• Semaphore
• Et d'autres
Java 5 - Divers
Programmation concurrente en Java
• Equivalent mono-JVM de MapReduce
• Décompose une tache en sous-taches et recompose le
résultat final
• Fonctionne par work-stealing
• Etendre RecursiveAction (si pas de résultat) ou
RecursiveTask (si résultat)
Java 7 - Fork/join (1/2)
Java 7 - Fork/join (2/2)
• Adder
• Bonnes performances (reporte les ajouts si besoin)
• Accumulator
• Généralisation de l'Adder
Java 8 - Adders et accumulators
Java 8 - StampedLock (1/2)
synchronized
synchronized (W)
et volatile
ReentrantLock
ReentrantRWLock
StampedLock
Simplicité
Bonnes perfs en lecture
Ajout de fonctionnalités (timed
wait, try lock, etc.)
Bonnes perfs en lecture
Bonnes perfs, fonctionnalités
(upgrade de lock R en W, etc.)
Fonctionnalités
Java 8 - StampedLock (2/2)
• Execution dans le ForkJoinPool commun
• Parallélisme du ForkJoinPool commun :
• Par system property :
• -Djava.util.concurrent.ForkJoinPool.common.parallelism=7
• Sinon Runtime.getRuntime().availableProcessors() - 1
• Le thread courant aussi est utilisé
• Ou dans un ForkJoinPool custom
Java 8 - Parallel streams (1/2)
• Pas toujours plus performant, varie suivant :
• Type de collection : ArrayList plutôt que LinkedList
• Nature du traitement
• Taille de "N*Q" (nb d'élément * cout par élément)
• Nombre de cœurs, il faut > 1
• Mesurer les deux
• Par défaut utilisent tous le ForkJoinPool commun
• Attention aux lambdas stateful
Java 8 - Parallel streams (2/2)
• Classe qui implémente Future et CompletionStage
• Pour combiner/chainer des actions
• Syntaxe fonctionnelle
Java 8 - CompletableFuture
Java EE et Spring
• Modèle "thread-per-request" avec pools de thread
(HTTP/Servlet, EJB)
• Solutions Java SE fonctionnent mais…
• … utiliser les threads du framework
• Contextes de sécurité et de transaction
• Modèles de composants (Servlet, EJB, Spring, etc) :
• Cycle de vie et scope : request, session, etc.
• Modèle de concurrence, voir de locking
Principes généraux
• Servlet
• SingleThreadModel est déprécié
• Une instance pour toutes les requêtes, donc thread-safe
• Spring et CDI
• Concurrence manuelle via solutions de Java SE
• EJB session singleton
• @ConcurrencyManagement : container ou bean
• @AccessTimeout
• @Lock : read ou write
• Autres
Concurrence des composants
• EJB 3.1 (Java EE 6)
• Spring 3 ou Spring Data
• CDI
• Peut s'implémenter via intercepteur maison
• Evènements asynchrones de CDI 2 (Java EE 8)
Méthodes asynchrones
• Concurrency Utilities (Java EE 7)
• Spring
Executors
• EJB 3.1 Timer Service (Java EE 6)
• Concurrency Utilities (Java EE 7)
• Spring 3
Scheduling
Programmation concurrente en Java
• Concurrence d'accès aux données entre requêtes
utilisateurs
• "Transaction longue" quand plusieurs transactions de BD
• Solutions : locking optimiste ou pessimiste
Locking de persistance
R1 W1
R2 W2
t
Conflit
• Fonctionnement
• OptimisticLockException en cas de problème
• Pour faible taux de conflits
• Bénéfices
• Scalabilité
• Portabilité
• Inconvénients
• Gérer le conflit : reload, force, merge
Locking optimiste
R W
t
version=3 version=4
JPA
Hibernate"update … where version=3""select …"
• Fonctionnement
• Pour fort taux de conflits
• Bénéfices
• Simplicité
• Inconvénients
• Contention
• Pour transactions courtes
Locking pessimiste par la base
R W
t
"select … for update" "update …"
JPA 2
Hibernate
• Fonctionnement
• Table de lock (id, entityClass, entityId, userId, date)
• Pour fort taux de conflits
• Bénéfices
• Fonctions avancées (monitoring, historisation, etc)
• Inconvénients
• Mode édition dans l'UI
• Gérer l'expiration des locks
• Plus d'accès à la base
• Contention
Locking pessimiste applicatif
R W
t
JPA
Hibernate
Lock Unlock
florian.beaufume@adeliosys.fr
www.adeliosys.fr
www.linkedin.com/in/fbeaufume
fr.slideshare.net/fbeaufume
Merci
1 of 46

Recommended

Programmation réactive avec Spring 5 et Reactor by
Programmation réactive avec Spring 5 et ReactorProgrammation réactive avec Spring 5 et Reactor
Programmation réactive avec Spring 5 et ReactorFlorian Beaufumé
4.5K views31 slides
WebSocket avec Java EE 7 by
WebSocket avec Java EE 7WebSocket avec Java EE 7
WebSocket avec Java EE 7Florian Beaufumé
1.7K views44 slides
Nouveautés de java 8 by
Nouveautés de java 8Nouveautés de java 8
Nouveautés de java 8Florian Beaufumé
9.7K views34 slides
Rails 3 au Djangocong by
Rails 3 au DjangocongRails 3 au Djangocong
Rails 3 au DjangocongJérémy Lecour
763 views18 slides
Réu technodejs by
Réu technodejsRéu technodejs
Réu technodejsnaholyr
626 views12 slides
Paris Scala User Group #43 - Spray (Magnet Pattern) + RxScala / ElasticSearch by
Paris Scala User Group #43 - Spray (Magnet Pattern) + RxScala / ElasticSearchParis Scala User Group #43 - Spray (Magnet Pattern) + RxScala / ElasticSearch
Paris Scala User Group #43 - Spray (Magnet Pattern) + RxScala / ElasticSearchMourad DACHRAOUI
6.2K views60 slides

More Related Content

What's hot

FinistJUG - Apache TomEE by
FinistJUG - Apache TomEEFinistJUG - Apache TomEE
FinistJUG - Apache TomEEHoracio Gonzalez
1.9K views57 slides
Realtime Web avec Kafka, Spark et Mesos by
Realtime Web avec Kafka, Spark et MesosRealtime Web avec Kafka, Spark et Mesos
Realtime Web avec Kafka, Spark et Mesosebiznext
6.3K views28 slides
Postman - Dev/var 15 by
Postman - Dev/var 15Postman - Dev/var 15
Postman - Dev/var 15Jonathan SAEZ
1.5K views18 slides
Migration de Tomcat vers Vert.x by
Migration de Tomcat vers Vert.xMigration de Tomcat vers Vert.x
Migration de Tomcat vers Vert.xFlorianBoulay
6.2K views46 slides
A la queue leu leu by
A la queue leu leuA la queue leu leu
A la queue leu leunautilebleu
571 views14 slides
JAVA 8 by
JAVA 8JAVA 8
JAVA 8Mohamed Saïd Frikha
427 views28 slides

What's hot(20)

Realtime Web avec Kafka, Spark et Mesos by ebiznext
Realtime Web avec Kafka, Spark et MesosRealtime Web avec Kafka, Spark et Mesos
Realtime Web avec Kafka, Spark et Mesos
ebiznext6.3K views
Migration de Tomcat vers Vert.x by FlorianBoulay
Migration de Tomcat vers Vert.xMigration de Tomcat vers Vert.x
Migration de Tomcat vers Vert.x
FlorianBoulay6.2K views
A la queue leu leu by nautilebleu
A la queue leu leuA la queue leu leu
A la queue leu leu
nautilebleu571 views
nouveautés du moteur Bonita 7.9 by Bonitasoft
nouveautés du moteur Bonita 7.9nouveautés du moteur Bonita 7.9
nouveautés du moteur Bonita 7.9
Bonitasoft160 views
Run java vs ruby by pinguin666
Run java vs rubyRun java vs ruby
Run java vs ruby
pinguin6661.2K views
Les Promises en Javascript by Benoit Zohar
Les Promises en JavascriptLes Promises en Javascript
Les Promises en Javascript
Benoit Zohar2.3K views
AMQP: interopérabilité et découplage de systèmes hétérogènes avec RabbitMQ by Microsoft
AMQP: interopérabilité et découplage de systèmes hétérogènes avec RabbitMQAMQP: interopérabilité et découplage de systèmes hétérogènes avec RabbitMQ
AMQP: interopérabilité et découplage de systèmes hétérogènes avec RabbitMQ
Microsoft1.5K views
2014.12.11 - TECH CONF #3 - Présentation Node.js by TelecomValley
2014.12.11 - TECH CONF #3 - Présentation Node.js2014.12.11 - TECH CONF #3 - Présentation Node.js
2014.12.11 - TECH CONF #3 - Présentation Node.js
TelecomValley1.1K views
Laravel yet another framework by LAHAXE Arnaud
Laravel  yet another frameworkLaravel  yet another framework
Laravel yet another framework
LAHAXE Arnaud4.2K views
RSocket un protocole réseau pour les Reactive Streams by VMware Tanzu
RSocket un protocole réseau pour les Reactive StreamsRSocket un protocole réseau pour les Reactive Streams
RSocket un protocole réseau pour les Reactive Streams
VMware Tanzu375 views
NodeJs, une introduction by Toxicode
NodeJs, une introductionNodeJs, une introduction
NodeJs, une introduction
Toxicode5.5K views
Meetup du 21 septembre 2017 by AFUP_Limoges
Meetup du 21 septembre 2017Meetup du 21 septembre 2017
Meetup du 21 septembre 2017
AFUP_Limoges88 views
Présentation de nodejs by 13p
Présentation de nodejsPrésentation de nodejs
Présentation de nodejs
13p1.3K views

Similar to Programmation concurrente en Java

Caching reboot: javax.cache & Ehcache 3 by
Caching reboot: javax.cache & Ehcache 3Caching reboot: javax.cache & Ehcache 3
Caching reboot: javax.cache & Ehcache 3Louis Jacomet
829 views30 slides
Javaday Paris 2022 - Java en 2022 : profiter de Java 17 by
Javaday Paris 2022 - Java en 2022 : profiter de Java 17Javaday Paris 2022 - Java en 2022 : profiter de Java 17
Javaday Paris 2022 - Java en 2022 : profiter de Java 17Jean-Michel Doudoux
70 views50 slides
Présentation de Apache Zookeeper by
Présentation de Apache ZookeeperPrésentation de Apache Zookeeper
Présentation de Apache ZookeeperMichaël Morello
6.3K views14 slides
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdf by
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdfdevoxx 2022 - 10 ans de Devoxx FR et de Java.pdf
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdfJean-Michel Doudoux
139 views49 slides
Introduction à Play Framework 2 by
Introduction à Play Framework 2Introduction à Play Framework 2
Introduction à Play Framework 2Samy Dindane
3.9K views36 slides
EventMachine by
EventMachineEventMachine
EventMachineLeTesteur
735 views14 slides

Similar to Programmation concurrente en Java(20)

Caching reboot: javax.cache & Ehcache 3 by Louis Jacomet
Caching reboot: javax.cache & Ehcache 3Caching reboot: javax.cache & Ehcache 3
Caching reboot: javax.cache & Ehcache 3
Louis Jacomet829 views
Javaday Paris 2022 - Java en 2022 : profiter de Java 17 by Jean-Michel Doudoux
Javaday Paris 2022 - Java en 2022 : profiter de Java 17Javaday Paris 2022 - Java en 2022 : profiter de Java 17
Javaday Paris 2022 - Java en 2022 : profiter de Java 17
Présentation de Apache Zookeeper by Michaël Morello
Présentation de Apache ZookeeperPrésentation de Apache Zookeeper
Présentation de Apache Zookeeper
Michaël Morello6.3K views
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdf by Jean-Michel Doudoux
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdfdevoxx 2022 - 10 ans de Devoxx FR et de Java.pdf
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdf
Introduction à Play Framework 2 by Samy Dindane
Introduction à Play Framework 2Introduction à Play Framework 2
Introduction à Play Framework 2
Samy Dindane3.9K views
EventMachine by LeTesteur
EventMachineEventMachine
EventMachine
LeTesteur735 views
Ejb 3 by daliing
Ejb 3Ejb 3
Ejb 3
daliing2.3K views
Du JavaScript dans mon projet by jollivetc
Du JavaScript dans mon projetDu JavaScript dans mon projet
Du JavaScript dans mon projet
jollivetc1.4K views
Elasticsearch 5.0 les nouveautés by Mathieu Elie
Elasticsearch 5.0 les nouveautésElasticsearch 5.0 les nouveautés
Elasticsearch 5.0 les nouveautés
Mathieu Elie1.1K views
Direct memory @ devoxxfr by Olivier Lamy
Direct memory @ devoxxfrDirect memory @ devoxxfr
Direct memory @ devoxxfr
Olivier Lamy2.4K views
Direct memory 3_devoxx_fr_2012-2.04.18 by Benoit Perroud
Direct memory 3_devoxx_fr_2012-2.04.18Direct memory 3_devoxx_fr_2012-2.04.18
Direct memory 3_devoxx_fr_2012-2.04.18
Benoit Perroud2.5K views
JDBC / JPA / Hibernate: Sans maîtrise la puissance n’est rien! by bleporini
JDBC / JPA / Hibernate: Sans maîtrise la puissance n’est rien!JDBC / JPA / Hibernate: Sans maîtrise la puissance n’est rien!
JDBC / JPA / Hibernate: Sans maîtrise la puissance n’est rien!
bleporini1.4K views
Meetup django-2012-06-14 by nautilebleu
Meetup django-2012-06-14Meetup django-2012-06-14
Meetup django-2012-06-14
nautilebleu772 views
Introduction Erlang - altnet fr Juin 2013 by Yann Schwartz
Introduction Erlang - altnet fr Juin 2013Introduction Erlang - altnet fr Juin 2013
Introduction Erlang - altnet fr Juin 2013
Yann Schwartz1.1K views

Programmation concurrente en Java

  • 1. Programmation concurrente en Java Florian Beaufumé 03/2017
  • 2. Florian Beaufumé • Architecte logiciel Java et web • Freelance • florian.beaufume@adeliosys.fr • www.adeliosys.fr • www.linkedin.com/in/fbeaufume • fr.slideshare.net/fbeaufume
  • 3. • Concepts • Java SE • Java EE et Spring Sommaire
  • 5. • "Le nombre de transistor double tous les deux ans" • "La fréquence double chaque 1,5 année" Lois de Moore
  • 6. • Concurrence : • Des tâches qui peuvent se chevaucher • Alternées ou pas • Parallélisme : • Exécution simultanées au niveau matériel Concurrence vs parallélisme
  • 7. • Gain maximal de latence suivant la part parallélisable du traitement Loi d'Amdahl
  • 8. • Processus découpé en threads • Natif vs green • Ordonnancement préemptif vs coopératif • Time slicing • Fonctionnalités de distribution et coordination • Bénéfices • Utilisation des ressources • Réactivité • Couts • Complexité de conception et débugging • Ressources par thread et context switching Modèle multi-threads
  • 9. • Thread safe < Immutable < Stateless • Section critique • Opération atomique • Contention • Deadlock • Starvation Définitions
  • 11. • Concurrence intégrée au langage • Basé sur des threads : • Nom • Priorité : 1 à 10 • Daemon ou pas • Etat : NEW, RUNNABLE, BLOCKED, WAITING, etc. • Pile d'appel • Exemple : • Mémoire partagée suivant le Java Memory Model Java 1.0
  • 12. Java 1.0 - Threads de base
  • 13. • Synchronisation de threads pour accéder à des données Java 1.0 - Synchronized
  • 14. • Permet d'implémenter un scope request : • Sécurité (identité, droits) • Transaction • Tenant • Java 1.2 : InheritableThreadLocal Java 1.0 - ThreadLocal
  • 15. • Exemple java.util.Timer : • Un thread par timer • Pas de garantie d'exécution Java 1.3 - Timers
  • 17. • Ajout de java.util.concurrent, merci Doug Lea • Java Memory Model • Interactions entre les threads et la mémoire • "Happens before" • Volatile : • R et W en mémoire principale plutôt que sur cache CPU • Rend R et W 64 bits (long et double) atomique • Mais pas un incrément • Permet de la synchronisation simple Java 5
  • 18. • Volatile seul • Synchronized en écriture + volatile Java 5 - Volatile
  • 19. • Singleton lazy loadé classique • Via double checked locking Java 5 - Double checked locking
  • 21. • Coordination de threads sur des étapes Java 5 - CountDownLatch main workers await() countdown()
  • 22. • Map<K, V> • Hashtable : synchronisée, clés et valeurs non null • HashMap : pas synchronisée, accepte clés et valeurs nulles • ConcurrentMap<K, V> • Etend Map<K, V> • Méthodes atomiques comme putIfAbsent(key, value) • ConcurrentHashMap, implémentation efficace Java 5 - ConcurrentHashMap
  • 23. • Exécution de tâches sur pool de threads Java 5 - Executors (1/2) Executor Executor Service ThreadPool Executor Interfaces Classes Scheduled Executor Service Scheduled ThreadPool Executor void execute(Runnable) Supporte Future, ex : Future<T> submit(Callable<T> task) Supporte scheduling, ex : ScheduledFuture scheduleAtFixedRate( Runnable command, long initialDelay, long period, TimeUnit unit)
  • 24. Java 5 - Executors (2/2)
  • 25. • Nombres atomiques • Semaphore • Et d'autres Java 5 - Divers
  • 27. • Equivalent mono-JVM de MapReduce • Décompose une tache en sous-taches et recompose le résultat final • Fonctionne par work-stealing • Etendre RecursiveAction (si pas de résultat) ou RecursiveTask (si résultat) Java 7 - Fork/join (1/2)
  • 28. Java 7 - Fork/join (2/2)
  • 29. • Adder • Bonnes performances (reporte les ajouts si besoin) • Accumulator • Généralisation de l'Adder Java 8 - Adders et accumulators
  • 30. Java 8 - StampedLock (1/2) synchronized synchronized (W) et volatile ReentrantLock ReentrantRWLock StampedLock Simplicité Bonnes perfs en lecture Ajout de fonctionnalités (timed wait, try lock, etc.) Bonnes perfs en lecture Bonnes perfs, fonctionnalités (upgrade de lock R en W, etc.) Fonctionnalités
  • 31. Java 8 - StampedLock (2/2)
  • 32. • Execution dans le ForkJoinPool commun • Parallélisme du ForkJoinPool commun : • Par system property : • -Djava.util.concurrent.ForkJoinPool.common.parallelism=7 • Sinon Runtime.getRuntime().availableProcessors() - 1 • Le thread courant aussi est utilisé • Ou dans un ForkJoinPool custom Java 8 - Parallel streams (1/2)
  • 33. • Pas toujours plus performant, varie suivant : • Type de collection : ArrayList plutôt que LinkedList • Nature du traitement • Taille de "N*Q" (nb d'élément * cout par élément) • Nombre de cœurs, il faut > 1 • Mesurer les deux • Par défaut utilisent tous le ForkJoinPool commun • Attention aux lambdas stateful Java 8 - Parallel streams (2/2)
  • 34. • Classe qui implémente Future et CompletionStage • Pour combiner/chainer des actions • Syntaxe fonctionnelle Java 8 - CompletableFuture
  • 35. Java EE et Spring
  • 36. • Modèle "thread-per-request" avec pools de thread (HTTP/Servlet, EJB) • Solutions Java SE fonctionnent mais… • … utiliser les threads du framework • Contextes de sécurité et de transaction • Modèles de composants (Servlet, EJB, Spring, etc) : • Cycle de vie et scope : request, session, etc. • Modèle de concurrence, voir de locking Principes généraux
  • 37. • Servlet • SingleThreadModel est déprécié • Une instance pour toutes les requêtes, donc thread-safe • Spring et CDI • Concurrence manuelle via solutions de Java SE • EJB session singleton • @ConcurrencyManagement : container ou bean • @AccessTimeout • @Lock : read ou write • Autres Concurrence des composants
  • 38. • EJB 3.1 (Java EE 6) • Spring 3 ou Spring Data • CDI • Peut s'implémenter via intercepteur maison • Evènements asynchrones de CDI 2 (Java EE 8) Méthodes asynchrones
  • 39. • Concurrency Utilities (Java EE 7) • Spring Executors
  • 40. • EJB 3.1 Timer Service (Java EE 6) • Concurrency Utilities (Java EE 7) • Spring 3 Scheduling
  • 42. • Concurrence d'accès aux données entre requêtes utilisateurs • "Transaction longue" quand plusieurs transactions de BD • Solutions : locking optimiste ou pessimiste Locking de persistance R1 W1 R2 W2 t Conflit
  • 43. • Fonctionnement • OptimisticLockException en cas de problème • Pour faible taux de conflits • Bénéfices • Scalabilité • Portabilité • Inconvénients • Gérer le conflit : reload, force, merge Locking optimiste R W t version=3 version=4 JPA Hibernate"update … where version=3""select …"
  • 44. • Fonctionnement • Pour fort taux de conflits • Bénéfices • Simplicité • Inconvénients • Contention • Pour transactions courtes Locking pessimiste par la base R W t "select … for update" "update …" JPA 2 Hibernate
  • 45. • Fonctionnement • Table de lock (id, entityClass, entityId, userId, date) • Pour fort taux de conflits • Bénéfices • Fonctions avancées (monitoring, historisation, etc) • Inconvénients • Mode édition dans l'UI • Gérer l'expiration des locks • Plus d'accès à la base • Contention Locking pessimiste applicatif R W t JPA Hibernate Lock Unlock