


Agregat Microservices Swagger UI daripada API Gateway Menggunakan Spring API Gateway dan Micronaut
Jan 16, 2025 pm 06:22 PMPanduan ini menunjukkan penyepaduan Swagger 3 (OpenAPI) dengan Spring Cloud Gateway untuk dokumentasi API perkhidmatan mikro yang diperkemas. Kami akan memanfaatkan Java 21, Spring Boot 3.2 dan Micronaut untuk mencipta penyelesaian yang mantap dan mesra pengguna.
Mengapa Pilih Swagger/OpenAPI?
Swagger, kini Spesifikasi OpenAPI (OAS), ialah piawaian dokumentasi API terkemuka. Khasiatnya termasuklah:
- Standard Industri: Diguna pakai secara meluas dan disokong oleh ekosistem alatan yang kaya.
- Dokumentasi Interaktif: Menjana dokumentasi mesra pengguna yang membolehkan pembangun meneroka dan menguji API secara langsung.
- Produktiviti Pembangun yang Dipertingkat: Ciri seperti penjanaan kod untuk SDK dan stub pelayan mempercepatkan pembangunan API.
- Kolaborasi Dipertingkat: Memberikan pemahaman bersama tentang fungsi API untuk pembangun, penguji dan pihak berkepentingan.
- Pengujian dan Nyahpepijat Ringkas: UI Swagger termasuk antara muka ujian untuk mengesahkan respons API.
- Sokongan Merentas Bahasa: Bersepadu dengan lancar merentas susunan teknologi yang pelbagai.
- Penyepaduan Mudah: Penyepaduan mudah dengan rangka kerja popular seperti Spring Boot dan Micronaut.
- Mesra Automasi: Menyokong automasi untuk pengurusan kitaran hayat API.
- Sumber Terbuka dengan Pilihan Perusahaan: Tersedia sebagai alat sumber terbuka percuma dengan pilihan perusahaan.
Spring Cloud Gateway: The Foundation
Spring Cloud Gateway, dibina pada Spring Framework 5, Spring Boot 2 dan Project Reactor, bertindak sebagai titik masuk pusat untuk penghalaan dan penapisan permintaan kepada perkhidmatan mikro anda.
Bagaimana Spring Cloud Gateway Berfungsi:
Rajah di bawah menggambarkan operasi Spring Cloud Gateway:
Permintaan pelanggan dinilai berdasarkan laluan yang ditetapkan. Permintaan padanan diproses oleh Pengendali Web Gateway, melaksanakan penapisan pra dan pasca sebelum dan selepas meminta proksi.
Membina Aplikasi:
Prasyarat:
- Jawa 21
- Gradle (atau Maven)
- Spring Boot 3.2 atau lebih baru
- Pemahaman Spring Cloud Gateway dan Swagger
- Micronaut
Pelaksanaan Langkah demi Langkah:
Langkah 1: Buat Aplikasi Micronaut (Pekerjaan, Perk, Perkhidmatan Tag)
Gunakan Pelancar Micronaut ([pautan ke pelancar]) untuk mencipta tiga aplikasi Micronaut: job-service
, perk-service
dan tag-service
. Pilih Java atau Kotlin, versi Micronaut stabil terkini, Swagger UI dan OpenAPI sebagai ciri. Gunakan Gradle atau Maven sebagai alat binaan. Setiap perkhidmatan akan mempunyai UI Swagger yang boleh diakses (mis., http://localhost:8081/swagger-ui/index.html
untuk job-service
). Anda juga boleh menggunakan CLI:
mn create-app --build=gradle_kotlin --jdk=21 --lang=java --test=junit --features=openapi,swagger-ui dev.job.job
(Ulang untuk perk-service
dan tag-service
, laraskan nama pakej dengan sewajarnya).
Langkah 2: Buat Gerbang API Spring Boot
Gunakan Spring Initializr ([pautan ke Spring Initializr]) untuk menjana projek Spring Boot. Sertakan kebergantungan berikut: Spring Cloud Gateway, Spring Boot Actuator dan Spring Web.
Langkah 3: Sepadukan Swagger ke dalam Gerbang API
Tambahkan kebergantungan Springdoc yang diperlukan pada pom.xml
(Maven) atau build.gradle
(Gradle) anda:
dependencies { implementation("org.springframework.cloud:spring-cloud-starter-gateway") implementation("org.springdoc:springdoc-openapi-starter-webmvc-api:2.8.3") implementation("org.springdoc:springdoc-openapi-starter-webflux-ui:2.8.3") }
Konfigurasikan application.yml
untuk mendayakan UI Swagger dan nyatakan URL untuk setiap fail Swagger YAML perkhidmatan mikro:
springdoc: api-docs: enabled: true swagger-ui: enabled: true path: /swagger-ui.html config-url: /v3/api-docs/swagger-config urls: - name: Job Service url: http://localhost:8081/swagger/job-service-0.0.yml - name: Perk Service url: http://localhost:8082/swagger/perk-0.0.yml - name: Tag Service url: http://localhost:8083/swagger/tag-0.0.yml
Tetapkan port Gateway API kepada 8080 dalam application.yml
:
server: port: 8080 spring: application: name: web-api-gateway
Langkah 4: Jalankan Aplikasi
Mulakan setiap satu daripada empat aplikasi (tiga perkhidmatan Micronaut dan Spring Boot Gateway). UI Swagger Gateway boleh diakses di http://localhost:8080/webjars/swagger-ui/index.html
.
Kesimpulan:
Pendekatan gabungan ini menyediakan seni bina perkhidmatan mikro yang berkuasa dan didokumentasikan dengan baik. Spring Cloud Gateway dengan cekap mengarahkan permintaan, manakala Swagger menawarkan pengalaman dokumentasi API terpusat dan interaktif. Persediaan ini meningkatkan produktiviti dan kerjasama pembangun dengan ketara. Ingat untuk menggantikan URL pemegang tempat dengan URL sebenar fail Swagger YAML perkhidmatan mikro anda.
Atas ialah kandungan terperinci Agregat Microservices Swagger UI daripada API Gateway Menggunakan Spring API Gateway dan Micronaut. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

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

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

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

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Perbezaan antara hashmap dan hashtable terutamanya dicerminkan dalam keselamatan benang, sokongan nilai null dan prestasi. 1. Dari segi keselamatan benang, hashtable adalah benang selamat, dan kaedahnya kebanyakannya kaedah segerak, sementara hashmap tidak melakukan pemprosesan penyegerakan, yang bukan benang-selamat; 2. Dari segi sokongan nilai null, hashmap membolehkan satu kunci null dan nilai null berbilang, manakala hashtable tidak membenarkan kekunci atau nilai null, jika tidak, nullPointerException akan dibuang; 3. Dari segi prestasi, hashmap lebih cekap kerana tidak ada mekanisme penyegerakan, dan Hashtable mempunyai prestasi penguncian yang rendah untuk setiap operasi. Adalah disyorkan untuk menggunakan ConcurrentHashMap sebaliknya.

Java menggunakan kelas pembalut kerana jenis data asas tidak dapat mengambil bahagian secara langsung dalam operasi berorientasikan objek, dan bentuk objek sering diperlukan dalam keperluan sebenar; 1. Kelas koleksi hanya boleh menyimpan objek, seperti senarai menggunakan tinju automatik untuk menyimpan nilai berangka; 2. Generik tidak menyokong jenis asas, dan kelas pembungkusan mesti digunakan sebagai parameter jenis; 3. Kelas pembungkusan boleh mewakili nilai null untuk membezakan data yang tidak tersendiri atau hilang; 4. Kelas pembungkusan menyediakan kaedah praktikal seperti penukaran rentetan untuk memudahkan parsing dan pemprosesan data, jadi dalam senario di mana ciri -ciri ini diperlukan, kelas pembungkusan sangat diperlukan.

Staticmethodsininterfaceswereintroducedinjava8toallowutilityfunctionswithintheintheinterfaceitself.beforjava8, SuchfunctionsRequiredseparateHelpereHelperes, LeadingTodisorgaganizedCode.Now, staticmethodethreeKeybeeMeKeBeReSes, staticmethodeDethreeKeybeeMeKeBeReSes, staticmethodethreeKeybeeMeKeKeBeReSes, staticmethodeDethreeKeybeeMeKeKeBeReKeNey

Penyusun JIT mengoptimumkan kod melalui empat kaedah: kaedah dalam talian, pengesanan tempat panas dan penyusunan, spekulasi jenis dan devirtualisasi, dan penghapusan operasi yang berlebihan. 1. Kaedah sebaris mengurangkan panggilan overhead dan memasukkan kaedah kecil yang sering dipanggil terus ke dalam panggilan; 2. Pengesanan tempat panas dan pelaksanaan kod frekuensi tinggi dan mengoptimumkannya untuk menjimatkan sumber; 3. Jenis spekulasi mengumpul maklumat jenis runtime untuk mencapai panggilan devirtualisasi, meningkatkan kecekapan; 4. Operasi berlebihan menghapuskan pengiraan dan pemeriksaan yang tidak berguna berdasarkan penghapusan data operasi, meningkatkan prestasi.

Blok permulaan contoh digunakan dalam Java untuk menjalankan logik inisialisasi apabila membuat objek, yang dilaksanakan sebelum pembina. Ia sesuai untuk senario di mana beberapa pembina berkongsi kod inisialisasi, permulaan medan kompleks, atau senario permulaan kelas tanpa nama. Tidak seperti blok inisialisasi statik, ia dilaksanakan setiap kali ia ditegaskan, manakala blok permulaan statik hanya dijalankan sekali apabila kelas dimuatkan.

Injava, thefinalkeywordpreventsavariable'svaluefrombeingchangedafterassignment, butitsbehaviordiffersforprimitivesandobjectreferences.forprimitiveVariables, finalmakesthevalueconstant, asinfinalintmax_speed = 100;

Mod kilang digunakan untuk merangkum logik penciptaan objek, menjadikan kod lebih fleksibel, mudah dikekalkan, dan ditambah longgar. Jawapan teras adalah: dengan mengurus logik penciptaan objek secara berpusat, menyembunyikan butiran pelaksanaan, dan menyokong penciptaan pelbagai objek yang berkaitan. Keterangan khusus adalah seperti berikut: Mod Kilang menyerahkan penciptaan objek ke kelas kilang khas atau kaedah untuk diproses, mengelakkan penggunaan Newclass () secara langsung; Ia sesuai untuk senario di mana pelbagai jenis objek yang berkaitan dicipta, logik penciptaan boleh berubah, dan butiran pelaksanaan perlu disembunyikan; Sebagai contoh, dalam pemproses pembayaran, jalur, paypal dan contoh lain dicipta melalui kilang -kilang; Pelaksanaannya termasuk objek yang dikembalikan oleh kelas kilang berdasarkan parameter input, dan semua objek menyedari antara muka yang sama; Varian biasa termasuk kilang -kilang mudah, kaedah kilang dan kilang abstrak, yang sesuai untuk kerumitan yang berbeza.

Terdapat dua jenis penukaran: tersirat dan eksplisit. 1. Penukaran tersirat berlaku secara automatik, seperti menukar int untuk berganda; 2. Penukaran eksplisit memerlukan operasi manual, seperti menggunakan (int) mydouble. Kes di mana penukaran jenis diperlukan termasuk memproses input pengguna, operasi matematik, atau lulus pelbagai jenis nilai antara fungsi. Isu-isu yang perlu diperhatikan adalah: Mengubah nombor terapung ke dalam bilangan bulat akan memotong bahagian pecahan, mengubah jenis besar menjadi jenis kecil boleh menyebabkan kehilangan data, dan beberapa bahasa tidak membenarkan penukaran langsung jenis tertentu. Pemahaman yang betul tentang peraturan penukaran bahasa membantu mengelakkan kesilapan.
