


Cara memanggil semula ApplicationContextInitializer sebelum bekas SpringBoot disegarkan
I. Penyediaan projek
Contoh projek yang dibuat dalam artikel ini dibangunkan menggunakan SpringBoot 2.2.1.RELEASE
+ maven 3.5.3
+ idea
Penciptaan projek SpringBoot khusus tidak akan diterangkan dalam perincian, fail pom teras, tiada kebergantungan tambahan
fail konfigurasiapplication.yml
, dan tiada konfigurasi khas
II Contoh titik sambungan sebelum muat semula bekas
1
Apabila kami mahu melaksanakan pemulaan konteks tersuai, ia adalah sangat mudah hanya melaksanakan antara muka di atas, seperti
public class ApplicationContextInitializer01 implements ApplicationContextInitializer { @Override public void initialize(ConfigurableApplicationContext configurableApplicationContext) { System.out.println("ApplicationContextInitializer01"); } }
2. Pendaftaran titik sambungan
Sejak di atas Tentukan titik lanjutan dan bagaimana untuk menjadikannya berkesan?
Secara rasmi menyediakan tiga cara, seperti mendaftar terus semasa permulaan: springApplication.addInitializers(new ApplicationContextInitializer01());
@SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication springApplication = new SpringApplication(Application.class); springApplication.addInitializers(new ApplicationContextInitializer01()); try (ConfigurableApplicationContext context = springApplication.run(args)) { } } }
Apabila titik sambungan kami disediakan dalam pakej balang, gunakan kaedah di atas Kaedah pendaftaran permulaan jelas tidak boleh dilaksanakan . Pada masa ini, kaedah yang lebih disyorkan ialah mendaftar melalui mekanisme SPI Spring
Daftar dalam fail META-INF/spring.factories
dalam direktori sumber
org.springframework.context.ApplicationContextInitializer=com.git.hui.extention.context.ApplicationContextInitializer02
Penjelasan
Mekanisme SPI di atas amat disyorkan untuk digunakan oleh semua orang Dalam artikel sebelum ini, pendaftaran
AutoConfiguration
biasanya dilakukan dengan cara ini
Selain itu. kepada dua kaedah pendaftaran di atas, terdapat juga kaedah fail konfigurasi Dalam fail konfigurasi application.properties
atau application.yml
, konfigurasikan konfigurasi berikut untuk memulakan
context: initializer: classes: com.git.hui.extention.context.ApplicationContextInitializer03
Untuk menguji tiga kaedah pendaftaran di atas.
, kami melaksanakan tiga titik sambungan tersuai, dan kemudian selepas bermula, lihat pada output sebenar
di atas Daripada output, anda hanya boleh membuat kesimpulan tentang keutamaan kaedah pendaftaran yang berbeza (untuk mengesahkan sudut pandangan berikut dengan lebih munasabah, adalah disyorkan agar anda mengubah suai tiga nama sambungan tersuai di atas untuk menghapuskan masalah pengisihan yang disebabkan oleh sambungan)
Pendaftaran fail konfigurasi> Pendaftaran SPI semasa permulaan
3 ialah hubungan berurutan, kita boleh melaksanakannya melalui anotasi
Contohnya, apabila tiga titik sambungan di atas semuanya didaftarkan melalui mod permulaan, contoh output@Order(5) public class ApplicationContextInitializer01 implements ApplicationContextInitializer { @Override public void initialize(ConfigurableApplicationContext configurableApplicationContext) { System.out.println("ApplicationContextInitializer01"); } } @Order(2) public class ApplicationContextInitializer02 implements ApplicationContextInitializer { @Override public void initialize(ConfigurableApplicationContext configurableApplicationContext) { System.out.println("ApplicationContextInitializer02"); } } @Order(10) public class ApplicationContextInitializer03 implements ApplicationContextInitializer { @Override public void initialize(ConfigurableApplicationContext configurableApplicationContext) { System.out.println("ApplicationContextInitializer03"); } } @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication springApplication = new SpringApplication(Application.class); springApplication.addInitializers(new ApplicationContextInitializer01(), new ApplicationContextInitializer02(), new ApplicationContextInitializer03()); try (ConfigurableApplicationContext context = springApplication.run(args)) { } } }
@Order
adalah seperti berikut
<.>
Kemudian perkara utama datang
Jika ketiga-tiga pelaksanaan tersuai di atas bukan kaedah pendaftaran yang sama, seperti 03 menggunakan kaedah fail konfigurasi untuk mendaftar, kemudian 01, 02 masih memulakan pendaftaran
- , maka pesanannya ialah 03 > 🎜> Maksudnya, susunan pengubahsuaian anotasi tidak boleh memecahkan susunan
- Fail Konfigurasi> kelas pelaksanaan tersuai , peraturannya adalah seperti berikut
- Fail Konfigurasi> 🎜> anotasi, Semakin kecil nilai, semakin tinggi keutamaan
@Order
4 Contoh senario penggunaan Akhir sekali, mari kita lihat apa kegunaan titik sambungan ini. adalah dan dalam senario yang kita gunakan. Adakah ini akan digunakan?
Senario aplikasi yang biasa dilihat ialah menggunakannya untuk menentukan fail konfigurasi yang perlu diaktifkan
public class ApplicationContextInitializer03 implements ApplicationContextInitializer { @Override public void initialize(ConfigurableApplicationContext configurableApplicationContext) { // 指定激活prod对应的配置文件 configurableApplicationContext.getEnvironment().setActiveProfiles("prod"); } }
- Tetapi secara amnya jarang untuk melihat sesiapa melakukan ini, kerana hanya gunakan parameter konfigurasi secara terus Jadi adakah terdapat senario yang memerlukan ini?
Sudah tentu ada jawapan Contohnya, dengan penggunaan kontena docker yang popular sekarang, apabila kita ingin menggunakan imej yang sama setiap kali, dan kemudian semasa operasi sebenar, kita boleh menentukan imej semasa mengikut. persekitaran yang berbeza. Fail konfigurasi yang didayakan akan berguna pada masa ini
Sebagai contoh, kami menggunakan parameter persekitaran bekas - untuk mendapatkan persekitaran berjalan semasa, aktifkan
; jika ia adalah ujian, aktifkan
@Order
Kemudian anda boleh melakukannya sekarang
public class EenvActiveApplicationContextInitializer implements ApplicationContextInitializer { @Override public void initialize(ConfigurableApplicationContext configurableApplicationContext) { String env = System.getenv("app.env"); if ("prod".equalsIgnoreCase(env)) { configurableApplicationContext.getEnvironment().setActiveProfiles("prod"); } else if ("test".equalsIgnoreCase(env)) { configurableApplicationContext.getEnvironment().setActiveProfiles("test"); } else { throw new RuntimeException("非法的环境参数:" + env); } } }
Atas ialah kandungan terperinci Cara memanggil semula ApplicationContextInitializer sebelum bekas SpringBoot disegarkan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

JVM melaksanakan ciri-ciri Wora Java melalui tafsiran bytecode, API bebas platform dan pemuatan kelas dinamik: 1. Bytecode ditafsirkan sebagai kod mesin untuk memastikan operasi silang platform; 2. Perbezaan sistem operasi abstrak API standard; 3. Kelas dimuatkan secara dinamik pada masa runtime untuk memastikan konsistensi.

Versi terbaru Java berkesan menyelesaikan masalah khusus platform melalui pengoptimuman JVM, penambahbaikan perpustakaan standard dan sokongan perpustakaan pihak ketiga. 1) Pengoptimuman JVM, seperti ZGC Java11 meningkatkan prestasi pengumpulan sampah. 2) Penambahbaikan perpustakaan standard, seperti sistem modul Java9 yang mengurangkan masalah berkaitan platform. 3) Perpustakaan pihak ketiga menyediakan versi yang dioptimumkan platform, seperti OpenCV.

Proses pengesahan bytecode JVM termasuk empat langkah utama: 1) Periksa sama ada format fail kelas mematuhi spesifikasi, 2) mengesahkan kesahihan dan ketepatan arahan bytecode, 3) melakukan analisis aliran data untuk memastikan keselamatan jenis, dan 4) mengimbangi ketelitian dan prestasi pengesahan. Melalui langkah -langkah ini, JVM memastikan bahawa hanya selamat, bytecode yang betul dilaksanakan, dengan itu melindungi integriti dan keselamatan program.

Java'splatformindependenceAllowsApplicationStoranyoperatingsystemwithajvm.1) singlecodebase: writeandcompileonceforallplatforms.2) Easyupdates: UpdateTecodeForsimulteUseUlyDeployment.3)

Kemerdekaan platform Java terus dipertingkatkan melalui teknologi seperti JVM, kompilasi JIT, penyeragaman, generik, ekspresi Lambda dan Projectpanama. Sejak tahun 1990-an, Java telah berkembang dari JVM asas kepada JVM moden berprestasi tinggi, memastikan konsistensi dan kecekapan kod di platform yang berbeza.

Bagaimanakah Java mengurangkan masalah khusus platform? Java melaksanakan platform bebas melalui JVM dan perpustakaan standard. 1) Gunakan bytecode dan JVM untuk abstrak perbezaan sistem operasi; 2) Perpustakaan standard menyediakan API silang platform, seperti laluan fail pemprosesan kelas Paths, dan pengekodan aksara pemprosesan kelas charset; 3) Gunakan fail konfigurasi dan ujian pelbagai platform dalam projek sebenar untuk pengoptimuman dan debugging.

Java'splatformindependenceEnhancesMicroservicesarchitectureByOfferingDeploymentflexability, konsistensi, skalabilitas, andPortability.1) DeploymentflexabilityAllowsMicroserviceStorunonAnanyplatformWithAjvm.2) ConsistencyAcsServicSservicesSimpliesDevelanDanDevelan

GraalVM meningkatkan kemerdekaan platform Java dalam tiga cara: 1. 2. Persekitaran Runtime Bebas, menyusun program Java ke dalam fail boleh laku tempatan melalui GraalvmnativeImage; 3. Pengoptimuman Prestasi, Graal Compiler menjana kod mesin yang cekap untuk meningkatkan prestasi dan konsistensi program Java.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Dreamweaver CS6
Alat pembangunan web visual

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa
