Gunakan GRPC untuk meningkatkan prestasi microservice Java; 2. Tentukan kontrak yang kuat melalui fail .proto; 3. Konfigurasikan kebergantungan GRPC dengan Maven dan menghasilkan kod; 4. Melaksanakan logik pelayan GRPC; 5. Perkhidmatan panggilan dari pelanggan; 6. TLS, pengendalian ralat, penemuan perkhidmatan dan pemerhatian mesti didayakan dalam persekitaran pengeluaran. Ikuti langkah-langkah untuk membina sistem komunikasi microservice yang cekap dan selamat.
Oleh itu, anda membina seni bina mikroservis Java dan mahu menggunakan GRPC? Pilihan yang baik. Ia pantas, cekap, dan hebat untuk komunikasi perkhidmatan-ke-perkhidmatan-terutamanya apabila anda mengambil berat tentang prestasi dan kejelasan kontrak. Inilah caranya untuk memulakan tanpa terkejut.

Mengapa GRPC masuk akal untuk Microservices Java
Sebelum menyelam ke persediaan, ia membantu mengetahui mengapa GRPC sesuai dengan persekitaran mikroservis:
- Prestasi Tinggi : Menggunakan HTTP/2 dan Serialization Perduaan (buffer protokol), jadi lebih cepat dan lebih ringan daripada JSON atas HTTP/1.1.
- Kontrak yang kuat : Antara muka perkhidmatan dan struktur mesej ditakrifkan dalam fail
.proto
, menjadikan API eksplisit dan bahasa-agnostik. - Generasi Kod Terbina : Anda menentukan perkhidmatan anda sekali, dan alat menjana kod klien dan pelayan untuk Java (dan bahasa lain).
- Sokongan untuk Streaming : GRPC menyokong streaming pelayan, streaming pelanggan, dan streaming bidedirectional-berguna untuk corak masa nyata atau yang didorong oleh peristiwa.
Sekiranya perkhidmatan anda bercakap dengan banyak (misalnya, perkhidmatan inventori panggilan perkhidmatan pesanan), GRPC dapat mengurangkan latensi dan meningkatkan throughput.

Langkah 1: Tentukan perkhidmatan anda dengan penampan protokol
Mula dengan menulis fail .proto
. Ini mentakrifkan model data dan antara muka perkhidmatan anda.
Contoh: inventory.proto

sintaks = "proto3"; pakej com.example.inventory; Perkhidmatan InventoryService { RPC GetStock (StockRequest) pulangan (StockResponse); } Mesej StockRequest { string product_id = 1; } Mesej StockResponse { int32 tersedia_count = 1; }
Ini mentakrifkan perkhidmatan mudah yang memeriksa stok untuk produk. Simpan fail .proto
anda di lokasi atau pakej bersama jika pelbagai perkhidmatan bergantung kepada mereka.
Langkah 2: Sediakan GRPC dalam projek Java anda
Gunakan Maven atau Gradle. Berikut adalah persediaan maven minimum ( pom.xml
):
<dependencies> <geterlihat> <groupId> io.grpc </groupId> <stifactid> GRPC-Netty-Shaded </artifactid> <versi> 1.58.0 </versi> </ketergantungan> <geterlihat> <groupId> io.grpc </groupId> <sttifactid> GRPC-protobuf </artifactid> <versi> 1.58.0 </versi> </ketergantungan> <geterlihat> <groupId> io.grpc </groupId> <ctiFactId> GRPC-STUB </artifactid> <versi> 1.58.0 </versi> </ketergantungan> </dependencies> <build> <semtions> <mpasten> <groupId> kr.motd.maven </groupId> <stifactid> os-maven-plugin </artifactid> <versi> 1.7.1 </versi> </lanjutan> </sambungan> <sugin> <sugin> <groupId> org.xolstice.maven.plugins </groupId> <stifactid> protobuf-maven-plugin </artifactid> <versi> 0.6.1 </versi> <figuration> <Protosourceroot> $ {project.basedir}/src/main/proto </protosourceroot> <utputDirectory> $ {project.build.directory}/sumber yang dihasilkan </outputDirectory> <learoutputdirectory> false </clearoutputdirectory> </konfigurasi> <Secution> <Execution> <isf gol> <iffial> compile </goal> <iffial> Compile-Custom </goal> </matlamat> </pelaksanaan> </pelaksanaan> </plugin> </plugin> </binaan>
Selepas menambah ini, jalankan:
MVN Compile
Plugin menjana kelas Java dari fail .proto
anda - termasuk kelas asas perkhidmatan, stub, dan jenis mesej.
Langkah 3: Melaksanakan pelayan
Buat kelas yang memanjangkan InventoryServiceGrpc.InventoryServiceImplBase
yang dihasilkan:
import io.grpc.server; import io.grpc.serverbuilder; import java.io.ioException; Inventory Kelas Awam { pelayan pelayan peribadi; public void start () melemparkan ioException { pelayan = serverbuilder.forport (8080) .AddService (InventoryServiceImpl baru ()) .build () .start (); System.out.println ("Pelayan bermula pada port 8080"); Runtime.getRuntime (). AddShutDownHook (thread baru (() -> { System.out.println ("Menutup Server GRPC"); InventoryServer.This.Stop (); })); blockuntilshutdown (); } void swasta blockuntilshutdown () melemparkan gangguan yang diganggu { jika (pelayan! = null) { server.AwaitterMination (); } } berhenti void peribadi () { jika (pelayan! = null) { server.shutdown (); } } public static void main (string [] args) melemparkan ioException, tergangguException { InventoryServer baru (). Mula (); } Inventori Kelas StatikServiceImpl memanjangkan InventoryServiceGrpc.InventoryServiceImplBase { @Override public void getstock (StockRequest Request, StreamObserver <StockResponse> ResponseObserver) { // simulasi logik int stok = "p123" .equals (request.getProductId ())? 42: 0; Respons Tempahan Saham = StockResponse.NewBuilder () .setavailableCount (stok) .build (); responseObserver.onnext (respons); ResponseObserver.onCompleted (); } } }
Itu sahaja - anda mempunyai pelayan GRPC yang bekerja.
Langkah 4: Hubungi perkhidmatan dari microservice yang lain (pelanggan)
Sekarang, dalam perkhidmatan panggilan anda (contohnya, perkhidmatan pesanan), buat pelanggan GRPC:
InventoryClient Kelas Awam { Inventory Final PrivateServiceGrpc.InventoryServiceBlockingStub BlockingStub; InventoryClient Public (Host String, Int Port) { Saluran ManagedChannel = ManagedChannelBuilder.ForAddress (Host, Port) .UsepLaintext () // Jangan gunakan dalam pengeluaran tanpa TLS .build (); BlockingStub = InventoryServiceGrpc.NewBlockingStub (Channel); } public int getStock (String ProductID) { Permintaan stockRequest = stockRequest.newBuilder (). SetProductId (ProductID) .build (); Response StockResponse = BlockingStub.getStock (permintaan); respons balik.GetAvailableCount (); } }
Gunakannya seperti:
InventoryClient Client = InventoryClient baru ("localhost", 8080); int stock = client.getStock ("p123"); System.out.println ("Stok:" Saham);
Petua untuk kegunaan dunia sebenar
- Gunakan TLS dalam pengeluaran : Sentiasa aktifkan penyulitan antara perkhidmatan. GRPC menyokong SSL/TLS keluar dari kotak.
- Mengendalikan kesilapan dengan kod status GRPC : Gunakan
Status
danStatusException
untuk penyebaran ralat bersih. - Mengintegrasikan dengan Penemuan Perkhidmatan : Pasangan GRPC dengan alat seperti Konsul, Eureka, atau Kubernet DNS.
- Tambah pemerhatian : Gunakan pemintas untuk pembalakan, metrik (misalnya, mikrometer), dan pengesanan yang diedarkan (misalnya, OpenTelemetry).
- Elakkan gandingan yang ketat : Walaupun
.proto
Fail menentukan kontrak, versi mereka dengan teliti dan elakkan kerap memecahkan perubahan.
Balut
GRPC dalam persediaan microservices Java memberikan anda kelajuan, jenis keselamatan, dan antara muka yang bersih. Mulakan Kecil: Tentukan satu perkhidmatan, dapatkannya, dan panggilnya dari yang lain. Sebaik sahaja anda selesa, tambahkan streaming, pengesahan, dan pemantauan.
Ia tidak selalunya pilihan yang tepat (contohnya, jika anda memerlukan pelanggan pelayar), tetapi untuk komunikasi backend-to-backend, sukar untuk ditewaskan.
Pada asasnya, tentukan .proto
, menjana kod, melaksanakan pelayan, hubungi dari klien - dan anda bergulir.
Atas ialah kandungan terperinci Bermula dengan GRPC dalam Senibina Microservices Java. 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

Maven adalah alat standard untuk pengurusan dan pembinaan projek Java. Jawapannya terletak pada hakikat bahawa ia menggunakan pom.xml untuk menyeragamkan struktur projek, pengurusan pergantungan, automasi kitaran hayat pembinaan dan sambungan pemalam; 1. Gunakan pom.xml untuk menentukan kumpulan, artifactid, versi dan kebergantungan; 2. Perintah teras utama seperti mvnclean, penyusun, ujian, pakej, memasang dan menggunakan; 3. Gunakan DependencyManagement dan Pengecualian untuk Menguruskan Versi Ketergantungan dan Konflik; 4. Mengatur aplikasi besar melalui struktur projek multi-modul dan diuruskan secara seragam oleh POM induk; 5.

SetupaMaven/gradleprojectwithjax-rsdependencyiSejersey; 2.createarescresourceUsingAnnotationssuchas@pathand@get; 3.configuretheapplicationviaapplicationsubclassorweb.xml;

Memahami komponen teras blockchain, termasuk blok, hash, struktur rantai, mekanisme konsensus dan kebolehubahan; 2. Buat kelas blok yang mengandungi data, cap waktu, hash dan nonce sebelumnya, dan melaksanakan pengiraan hash SHA-256 dan bukti perlombongan kerja; 3. Membina kelas blockchain untuk menguruskan senarai blok, memulakan blok Kejadian, menambah blok baru dan sahkan integriti rantai; 4. Tulis blockchain ujian utama, tambah blok data transaksi pada giliran dan status rantai output; 5. Fungsi peningkatan pilihan termasuk sokongan transaksi, rangkaian P2P, tandatangan digital, Restapi dan ketekunan data; 6. Anda boleh menggunakan perpustakaan blok Java seperti Hyperledgerfabric, Web3J atau Corda untuk pembukaan peringkat pengeluaran

@Property Decorator digunakan untuk menukar kaedah ke dalam sifat untuk melaksanakan bacaan, penetapan dan kawalan penghapusan sifat. 1. Penggunaan Asas: Tentukan atribut baca sahaja melalui @property, seperti kawasan yang dikira berdasarkan radius dan diakses secara langsung; 2. Penggunaan Lanjutan: gunakan @name.setter dan @name.deleter untuk melaksanakan pengesahan tugasan atribut dan operasi penghapusan; 3. Aplikasi Praktikal: Melaksanakan pengesahan data dalam setter, seperti BankAccount untuk memastikan bahawa baki tidak negatif; 4. Penamaan Spesifikasi: Pembolehubah dalaman adalah prefixed, nama kaedah harta selaras dengan atribut, dan kawalan akses bersatu digunakan untuk meningkatkan keselamatan kod dan penyelenggaraan.

Pertama, gunakan JavaScript untuk mendapatkan pilihan sistem pengguna dan tetapan tema yang disimpan di dalam negara, dan memulakan tema halaman; 1. Struktur HTML mengandungi butang untuk mencetuskan Topik Switching; 2. CSS menggunakan: Root untuk menentukan pembolehubah tema yang cerah, kelas mod-mode mentakrifkan pembolehubah tema gelap, dan menggunakan pembolehubah ini melalui VAR (); 3. JavaScript mengesan lebih suka skema-skema dan membaca LocalStorage untuk menentukan tema awal; 4. Tukar kelas mod gelap pada elemen HTML apabila mengklik butang, dan menjimatkan keadaan semasa ke LocalStorage; 5. Semua perubahan warna disertakan dengan animasi peralihan 0.3 saat untuk meningkatkan pengguna

Untuk menjana nilai hash menggunakan Java, ia boleh dilaksanakan melalui kelas MessageDigest. 1. Dapatkan contoh algoritma yang ditentukan, seperti MD5 atau SHA-256; 2. Panggil kaedah .Update () untuk lulus dalam data untuk disulitkan; 3. Panggil kaedah .digest () untuk mendapatkan pelbagai hash byte; 4. Tukar array byte ke dalam rentetan heksadesimal untuk membaca; Untuk input seperti fail besar, baca dalam ketulan dan panggilan .Update () beberapa kali; Adalah disyorkan untuk menggunakan SHA-256 dan bukannya MD5 atau SHA-1 untuk memastikan keselamatan.

Ya, menu drop-down CSS biasa boleh dilaksanakan melalui HTML dan CSS tulen tanpa JavaScript. 1. Gunakan UL dan Li bersarang untuk membina struktur menu; 2. Gunakan: Hover pseudo-Class untuk mengawal paparan dan menyembunyikan kandungan tarik-turun; 3. Tetapkan Kedudukan: Relatif untuk Ibu Bapa Li, dan submenu diletakkan menggunakan kedudukan: mutlak; 4. Submenu mungkir untuk memaparkan: Tiada, yang menjadi paparan: blok apabila melayang; 5. Multi-level pull-down boleh dicapai melalui bersarang, digabungkan dengan peralihan, dan menambah animasi pudar, dan disesuaikan dengan terminal mudah alih dengan pertanyaan media. Penyelesaian keseluruhannya mudah dan tidak memerlukan sokongan JavaScript, yang sesuai untuk besar

Gunakan DateTime.StrpTime () untuk menukar rentetan tarikh ke dalam objek DateTime. 1. Penggunaan Asas: Parse "2023-10-05" sebagai objek DateTime melalui "%y-%m-%d"; 2. Menyokong pelbagai format seperti "%m/%d/%y" untuk menghuraikan tarikh Amerika, "%d/%m/%y" untuk menghuraikan tarikh British, "%b%d,%y%i:%m%p" untuk menghuraikan masa dengan am/pm; 3. Gunakan dateUtil.parser.parse () untuk secara automatik menyimpulkan format yang tidak diketahui; 4. Gunakan .D
