Here we will see how we can configure different datasource for application and batch. By default, Spring batch stores the job details and execution details in database. If separate data source is not configured for spring batch then it will use the available data source in your application if configured and create batch related tables there. Which may be the unwanted burden on application database and we would like to configure separate database for spring batch.
To overcome this situation we will configure the different datasource for spring batch using in-memory database, since we don't want to store batch job details permanently.
Other thing is the configuration of spring cloud task in case of multiple datasource and it must point to the same data source which is pointed by spring batch.
In below sections, we will se how to configure application, batch and cloud task related data sources.
Spring batch job with spring cloud data flow server
How to setup spring cloud data flow server
To overcome this situation we will configure the different datasource for spring batch using in-memory database, since we don't want to store batch job details permanently.
Other thing is the configuration of spring cloud task in case of multiple datasource and it must point to the same data source which is pointed by spring batch.
In below sections, we will se how to configure application, batch and cloud task related data sources.
Application Data Source
Define the data source in application properties or yml configuration to configure the database.spring.datasource.url=jdbc:h2:tcp://localhost:19092/mem:app-data spring.datasource.jdbcUrl=jdbc:h2:tcp://localhost:19092/mem:app-data spring.datasource.driverClassName=org.h2.Driver spring.datasource.username=sa spring.datasource.password= spring.jpa.database-platform=org.hibernate.dialect.H2DialectDefine the spring beans for data source, entity manager factory and transaction manager. We also need to configure JPA repository where we tell the location of our repository classes and domain objects for business data manipulation.
@Configuration @EnableJpaRepositories( entityManagerFactoryRef = "appEntityManagerFactory", transactionManagerRef = "appTransactionManager", basePackages = "com.ttj.app.repository" ) @EnableTransactionManagement public class AppDataSourceConfig { @Bean @ConfigurationProperties(prefix = "spring.datasource") public DataSource appDataSource(){ return DataSourceBuilder.create().build(); } @Bean(name = "appEntityManagerFactory") public LocalContainerEntityManagerFactoryBean appEntityManagerFactory(EntityManagerFactoryBuilder builder, @Qualifier("appDataSource") DataSource appDataSource){ return builder .dataSource(appDataSource) .packages("com.ttj.app.domain") .persistenceUnit("app") .build(); } @Bean(name = "appTransactionManager") public PlatformTransactionManager appTransactionManager(@Qualifier("appEntityManagerFactory") EntityManagerFactory appEntityManagerFactory) { return new JpaTransactionManager(appEntityManagerFactory); } }
Spring Batch Data Source
Configure below data source properties in application properties or yml configuration. Please note if you are going to use this job as cloud task to register with spring cloud data flow server then make sure it is pointing to same database which is used by data flow server.spring.batch.datasource.url=jdbc:h2:tcp://localhost:19092/mem:dataflow spring.batch.datasource.jdbcUrl=jdbc:h2:tcp://localhost:19092/mem:dataflow spring.batch.datasource.driverClassName=org.h2.Driver spring.batch.datasource.username=sa spring.batch.datasource.password=Define the spring beans for batch datasource and transaction manager. Please note that here we are making the datasource and transaction manager as primary beans as spring cloud task looks for some other bean name by default for data source and transaction manager and making it primary makes cloud task to use these beans.
@Configuration public class BatchDataSourceConfig { @Bean(name="batchDataSource") @Primary @ConfigurationProperties(prefix = "spring.batch.datasource") public DataSource batchDataSource(){ return DataSourceBuilder.create().build(); } @Primary @Bean(name = "batchEntityManagerFactory") public LocalContainerEntityManagerFactoryBean batchEntityManagerFactory(EntityManagerFactoryBuilder builder, @Qualifier("batchDataSource") DataSource batchDataSource){ return builder .dataSource(batchDataSource) .packages("com.ttj.batch.domain") .persistenceUnit("batch") .build(); } @Primary @Bean(name = "batchTransactionManager") public PlatformTransactionManager appTransactionManager(@Qualifier("batchEntityManagerFactory") EntityManagerFactory batchEntityManagerFactory) { return new JpaTransactionManager(batchEntityManagerFactory); } @Bean public BatchConfigurer configurer(@Qualifier("batchDataSource") DataSource batchDataSource) { return new DefaultBatchConfigurer(batchDataSource); } }
Spring Cloud Task Data Source
We need to use the same data source which is configured with spring batch and need to define the bean for TaskConfigurer as given below. Also by default it looks for transaction manager with the bean name as "transactionManager" and to use the batch transaction manager we need to annotate batch transaction manager with @Primary which we saw in previous section of spring batch data source configuration.@Configuration public class CloudTaskConfig { @Bean public TaskConfigurer taskConfigurer(@Qualifier("batchDataSource") DataSource batchDataSource){ return new DefaultTaskConfigurer(batchDataSource); } }Other posts you may like to explore:
Spring batch job with spring cloud data flow server
How to setup spring cloud data flow server
This is really nice post, I found and love this content. I will prefer this, thanks for sharing. Business Intelligence Data Analytics.
ReplyDeleteThanks for your kind words.
DeleteI followed you, but its not creating Spring Batch metadata tables automatically
ReplyDeletedid you find any solution to this?
Deleteexactly what i was looking for, thank you
ReplyDeleteI'm facing Caused by: org.hsqldb.HsqlException: user lacks privilege or object not found: BATCH_JOB_INSTANCE problem. What am I missing here.
ReplyDeleteThere could be several reasons like user for batch doesn't have permission in configured database or it is connecting to incorrect database in case multiple database configured in your application.
Delete
ReplyDeleteIt was such a good post. Visit Hack App Data Pro Apk Download. Thanks for sharing.
Thank you so much for imparting this excellent information to us. Anyone can benefit from this information. Therefore, kindly impart this kind of wisdom to everyone. Thanks. Information about.best pdf signature api
ReplyDeleteThe blog consistently posts new content, and it is a fascinating blog. Thank you for revealing.hire programmers in india
ReplyDeleteThis is a great article you've shared because it offers some great information that will be very helpful to me. I'm grateful that you said that. Work well done; continue.hire coldfusion developers
ReplyDeleteHey i read your blog and find it very helpful for me because i was looking for these type of content online.
ReplyDeleteReasons Why To Hire A Bodyguard in London, UK:| Spetsnaz Security International Fidel Matola
https://www.spetsnazsecurityinternational.co.uk/reasons-to-hire-a-london-bodyguard.html
https://www.spetsnazsecurityinternational.co.uk/reasons-to-hire-a-london-bodyguard.html
Bursa
ReplyDeleteMersin
izmir
Rize
Antep
X6DQD2
yalova
ReplyDeleteyozgat
elazığ
van
sakarya
1FP
tekirdağ evden eve nakliyat
ReplyDeleteşırnak evden eve nakliyat
bitlis evden eve nakliyat
aksaray evden eve nakliyat
karaman evden eve nakliyat
LMB78
AD9B1
ReplyDeleteDenizli Lojistik
Denizli Parça Eşya Taşıma
Bolu Lojistik
Kırıkkale Evden Eve Nakliyat
Kastamonu Parça Eşya Taşıma
4EA42
ReplyDeleteParibu Güvenilir mi
Bingöl Evden Eve Nakliyat
Kars Evden Eve Nakliyat
Diyarbakır Evden Eve Nakliyat
Çankırı Evden Eve Nakliyat
9A3F9
ReplyDeleteKarabük Şehir İçi Nakliyat
Ardahan Parça Eşya Taşıma
Maraş Parça Eşya Taşıma
Kayseri Evden Eve Nakliyat
Zonguldak Şehirler Arası Nakliyat
Elazığ Şehir İçi Nakliyat
AAX Güvenilir mi
Adıyaman Şehirler Arası Nakliyat
Kripto Para Nedir
88467
ReplyDeleteBursa Lojistik
Kucoin Güvenilir mi
Hakkari Şehirler Arası Nakliyat
Amasya Lojistik
Uşak Şehirler Arası Nakliyat
Düzce Lojistik
Artvin Şehirler Arası Nakliyat
Kilis Parça Eşya Taşıma
Etlik Parke Ustası
D6342
ReplyDeleteSilivri Fayans Ustası
Adıyaman Parça Eşya Taşıma
Kırıkkale Lojistik
Ünye Oto Lastik
Kırklareli Lojistik
Nevşehir Parça Eşya Taşıma
Yenimahalle Boya Ustası
Edirne Şehirler Arası Nakliyat
Etimesgut Parke Ustası
117CC
ReplyDeleteindirim kodu %20
Elevate your programming skills with the leading "Java Course in Gurgaon" offered by APTRON. As a premier training institute, APTRON Gurgaon provides comprehensive and hands-on Java programming courses that cater to both beginners and experienced developers.
ReplyDeleteFECEE
ReplyDeletediyarbakır mobil sesli sohbet
edirne görüntülü sohbet odaları
canlı sohbet odası
mardin canlı sohbet sitesi
kars görüntülü sohbet odaları
sesli sohbet
görüntülü sohbet siteleri ücretsiz
muş ücretsiz sohbet sitesi
bursa en iyi görüntülü sohbet uygulaması
B8432
ReplyDeleteantep sohbet siteleri
hakkari yabancı sohbet
rastgele görüntülü sohbet ücretsiz
Antep Görüntülü Sohbet Yabancı
izmir tamamen ücretsiz sohbet siteleri
siirt mobil sohbet sitesi
Kırıkkale Sesli Sohbet Mobil
istanbul bedava sohbet uygulamaları
Kayseri Rastgele Görüntülü Sohbet Uygulaması
CB9C9
ReplyDeleteKwai Takipçi Satın Al
Bitcoin Madenciliği Siteleri
Binance Hesap Açma
Bitcoin Nasıl Alınır
Soundcloud Beğeni Hilesi
Bitcoin Kazanma
Bitcoin Kazanma
Discord Sunucu Üyesi Satın Al
Loop Network Coin Hangi Borsada
9CDB9
ReplyDeletekömür sabunu
zerdeçal sabunu
kripto ne demek
bitget
binance referans kimliği
ısırgan sabunu
toptan sabun
mobil 4g proxy
kömür sabunu
3EE24
ReplyDeleteprobit
btcturk
referans kodu binance
sohbet canlı
bitcoin haram mı
gate io
bybit
aax
canlı sohbet
479E6
ReplyDeletekredi kartı ile kripto para alma
referans kimligi nedir
telegram kripto grupları
binance 100 dolar
okex
güvenilir kripto para siteleri
toptan mum
kraken
kripto para nereden alınır
92D30
ReplyDeletekaldıraç nasıl yapılır
toptan sabun
bitcoin hangi bankalarda var
referans kodu binance
bybit
kripto telegram grupları
binance 100 dolar
telegram kripto kanalları
bitrue
402C9
ReplyDeletekripto para haram mı
kucoin
bitget
bitmex
referans kimligi nedir
cointiger
bkex
huobi
telegram kripto kanalları
85618
ReplyDeletehuobi
güvenilir kripto para siteleri
bitmex
referans kodu
mobil proxy 4g
okex
bitexen
binance
canlı sohbet ücretsiz
FF9CD
ReplyDeletebitexen
binance
kripto para haram mı
referans kimliği
kizlarla canli sohbet
binance referans kimliği
coinex
paribu
okex
5E05E
ReplyDeleteyoutube seo
ach coin yorum
harita kaydı
axs coin yorum
fil coin yorum
oxt coin yorum
aave coin yorum
op coin yorum
youtube izlenme
833B7
ReplyDeletecss
web tasarım
site kurma
solar güneş paneli
hosting
fort coin yorum
instagram beğeni
alpine coin yorum
site satışı
1678A
ReplyDelete----
----
----
----
----
matadorbet
----
----
----
690A1
ReplyDeleteistanbul iç mimar
Youtube İzlenme
fiziksel sunucu
jeneratör fiyatları
seo nedir
Youtube Para Kazanma
ehliyet sınav soruları
güneş paneli
vds satın al
74A8A
ReplyDeletefreelance iş ilanları
Footer Link
Knight Online Sunucu
Yapay Zeka Çizim
Facebook Grup Satın Al
Kurumsal Hosting
yabancı dizi önerileri
Instagram Takipçi Satın Al
Tiktok Hesap
8107C
ReplyDeleteYoutube SEO
Sosyal Medya Yönetimi
bitcoin son dakika
Bing SEO
seo hizmeti
İnternetten Para Kazanma
smm panel
Residential Proxy Satın Al
Facebook Reklam Verme
B5D93
ReplyDeleteEticaret Paketleri
Instagram Para Kazanma
home office iş ilanları
google 5 yıldız
Dedicated Server
abone satin al
izlenme satin al
bitcoin
blogspot seo
48A32
ReplyDeleteBTC Forum
Eth Coin Yorum
BTC Son Dakika Haberleri
Forth Coin Yorum
Bitcoin Yorum
Prom Coin Yorum
Slp Coin Yorum
Ftm Coin Yorum
Matic Coin Yorum
E7E77
ReplyDeleteEtc Coin Yorum
Shib Coin Yorum
Bitcoin Son Dakika Haberleri
Lsk Coin Yorum
Qnt Coin Yorum
BTC Forum
Sushi Coin Yorum
Bitcoin Yorum
Dia Coin Yorum
BF64F
ReplyDeleteücretli show
https://www.canli.show/
8BDBC685BC
ReplyDeletesanal seks
sex hattı
cam şov
seks hattı
görüntülü show
sanal sex
cam show
görüntülü sex
sohbet hattı
DE0814908B
ReplyDeleteseks hattı
görüntülü sex
cam şov
cam show
görüntülü şov
sohbet hatti
sex hattı
sohbet hatti
sanal sex
0C397B677F
ReplyDeletegörüntülü seks
görüntülü sex
sanal seks
sohbet hatti
seks hattı
sanal sex
sohbet hatti
cam şov
sex hattı
3CC4362559
ReplyDeletesanal sex
sohbet hatti
sex hattı
cam show
görüntülü şov
görüntülü sex
sanal seks
sohbet hatti
cam şov
081F707CDA
ReplyDeleteucretli show
41898408A3
ReplyDeletegeciktirici
viga
vigrande
bufalo çikolata
sertleştirici
cobra vega
degra
bufalo içecek
viagra
9DA2401B03
ReplyDeletebufalo çikolata
delay
vigrande
kamagra
maxman
viagra
novagra
lay era
yapay kızlık zarı
8A7D9E5702
ReplyDeletekaldırıcı
sertleştirici
ereksiyon hapı
kamagra
sildegra
viga
novagra
performans arttırıcı
delay
472444E80A
ReplyDeletecobra vega
cam şov
themra macun
cialis
lifta
kaldırıcı
whatsapp görüntülü şov
sinegra
delay