Rumah Java javaTutorial Melaksanakan tadbir urus perkhidmatan mikro berdasarkan bekas Spring Cloud

Melaksanakan tadbir urus perkhidmatan mikro berdasarkan bekas Spring Cloud

Jun 22, 2023 pm 08:43 PM
perkhidmatan mikro spring cloud Kontena

Dengan pembangunan Internet dan pengkomputeran awan, semakin banyak syarikat mula menggunakan seni bina perkhidmatan mikro untuk membina dan menggunakan sistem perisian. Dalam seni bina perkhidmatan mikro, sistem dibahagikan kepada beberapa unit perkhidmatan autonomi yang kecil, masing-masing dengan aplikasi sendiri, storan data dan logik perniagaan. Kelebihan gaya seni bina ini ialah ia meningkatkan daya tahan, kebolehskalaan dan kebolehselenggaraan aplikasi. Walau bagaimanapun, seni bina perkhidmatan mikro turut membawa beberapa cabaran, seperti penemuan perkhidmatan, pengimbangan beban, toleransi kesalahan, visualisasi, dll., yang memerlukan alat tadbir urus perkhidmatan mikro yang berkuasa untuk diselesaikan. Spring Cloud ialah rangka kerja perkhidmatan mikro berdasarkan Spring Boot Ia menyediakan satu siri teknologi tadbir urus perkhidmatan mikro untuk membolehkan pembangun membina dan mengurus aplikasi perkhidmatan mikro dengan lebih mudah.

Bekas Spring Cloud ialah salah satu komponen teras Spring Cloud Ia menyediakan pelbagai fungsi tadbir urus perkhidmatan mikro, seperti pendaftaran dan penemuan perkhidmatan, pengurusan konfigurasi, pemutus litar, dll. Dalam artikel ini, kami akan memperkenalkan cara melaksanakan tadbir urus perkhidmatan mikro menggunakan bekas Spring Cloud.

1. Pendaftaran dan penemuan perkhidmatan

Dalam seni bina perkhidmatan mikro, panggilan antara perkhidmatan memerlukan mengetahui alamat rangkaian perkhidmatan dan alamat perkhidmatan sering berubah. Ini memerlukan pendaftaran perkhidmatan dan mekanisme penemuan untuk mengurus alamat perkhidmatan. Bekas Spring Cloud menyediakan Eureka untuk menyelesaikan masalah ini.

Eureka ialah komponen pendaftaran dan penemuan perkhidmatan sumber terbuka Netflix Ia melaksanakan fungsi asas pendaftaran dan penemuan perkhidmatan berdasarkan API RESTful, dan juga menyediakan fungsi lanjutan seperti pemeriksaan kesihatan perkhidmatan, pengimbangan beban dan failover. Menggunakan Eureka dalam Spring Cloud adalah sangat mudah Anda hanya perlu memperkenalkan kebergantungan yang berkaitan ke dalam projek Spring Boot dan mengkonfigurasi application.yml atau application.properties. Berikut ialah contoh konfigurasi application.yml yang mudah:

spring:
  application:
    name: service-provider
  cloud:
    config:
      uri: http://config-server:8888 # 配置中心地址
    consul:
      host: consul-server # 基于Consul模式时Consul服务器地址
  profiles:
    active: dev
eureka:
  client:
    serviceUrl:
      defaultZone: http://eureka-server:8761/eureka/ # Eureka注册中心地址
  instance:
    preferIpAddress: true
  server:
    enable-self-preservation: false # 测试场景,不关闭则Eureka客户端会每隔30s向Eureka Server发送一次心跳包作为健康检查,因为测试场景是手动杀掉实例,所以不执行自我保护
Salin selepas log masuk

Dalam fail konfigurasi di atas, kami mengkonfigurasi nama perkhidmatan sebagai penyedia perkhidmatan, menggunakan pusat pendaftaran Eureka dan menggunakan pusat konfigurasi Spring Cloud Config dan Konsul perkhidmatan. Didapati item konfigurasi ini boleh diubah suai mengikut keperluan. Sangat mudah untuk menggunakan pusat pendaftaran Eureka Anda hanya perlu menambah anotasi @EnableEurekaClient ke kelas permulaan untuk mendaftarkan perkhidmatan ke dalam Pelayan Eureka.

2. Pengurusan konfigurasi

Dalam seni bina perkhidmatan mikro, pengurusan konfigurasi perkhidmatan juga merupakan isu yang sangat penting. Spring Cloud menyediakan komponen Config Server untuk melaksanakan pengurusan konfigurasi perkhidmatan mikro boleh menyimpan maklumat konfigurasi secara setempat (alat pengurusan kod seperti Git, Svn) atau repositori jauh (seperti GitHub), dan pelanggan boleh menggunakan API Restful untuk Mendapatkan konfigurasi. maklumat dan muat semula cache secara automatik.

Menggunakan Pelayan Config dalam Spring Cloud adalah sangat mudah Anda hanya perlu memperkenalkan kebergantungan yang berkaitan ke dalam projek Spring Boot dan mengkonfigurasi application.yml atau application.properties. Berikut ialah contoh konfigurasi application.yml yang mudah:

spring:
  application:
    name: config-server
  cloud:
    config:
      server:
        git:
          uri: https://github.com/Alice52/spring-cloud-config-example.git # 配置文件所在的远程仓库
          search-paths: {config} # 配置文件所在的搜索路径
server:
  port: 8888 # 配置Server的端口
Salin selepas log masuk

Dalam fail konfigurasi di atas, kami mengkonfigurasi nama Pelayan Konfig sebagai pelayan konfigurasi, port yang dimulakan sebagai 8888 dan menggunakan Git untuk mengurus konfigurasi fail. , alamat fail konfigurasi ialah https://github.com/Alice52/spring-cloud-config-example.git. Untuk pelanggan, anda hanya perlu menambah anotasi @EnableAutoConfiguration dan @EnableConfigServer ke kelas permulaan untuk membolehkan pelanggan mendapatkan maklumat konfigurasi daripada Pelayan Config.

3. Panggilan perkhidmatan

Dalam seni bina perkhidmatan mikro, perkhidmatan memanggil satu sama lain melalui API RESTful berasaskan rangkaian Walau bagaimanapun, untuk panggilan perkhidmatan, kadangkala pengimbangan beban diperlukan dan pada masa yang sama Perlindungan pemutus litar diperlukan untuk mengelakkan kemerosotan perkhidmatan atau gangguan.

Spring Cloud menyediakan komponen Ribbon untuk menyediakan fungsi pengimbangan beban, dan juga menyediakan komponen Hystrix untuk menyediakan fungsi pemutus litar. Menggunakan Ribbon dan Hystrix dalam Spring Cloud juga sangat mudah Anda hanya perlu memperkenalkan kebergantungan yang berkaitan ke dalam projek Spring Boot dan mengkonfigurasi application.yml atau application.properties. Berikut ialah contoh konfigurasi application.yml yang mudah:

spring:
  application:
    name: service-consumer
server:
  port: 8080
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
  instance:
    preferIpAddress: true
    instanceId: ${spring.cloud.client.ipAddress}:${spring.application.name}:${server.port}
  server:
    enable-self-preservation: false # 测试场景,不关闭则Eureka客户端会每隔30s向Eureka Server发送一次心跳包作为健康检查,因为测试场景是手动杀掉实例,所以不执行自我保护
Salin selepas log masuk

Dalam fail konfigurasi di atas, kami mengkonfigurasi nama perkhidmatan sebagai pengguna perkhidmatan, menggunakan pusat pendaftaran Eureka dan menghidupkan mekanisme perlindungan diri bagi perkhidmatan untuk Mencegah Pelayan Eureka daripada mengesan kegagalan perkhidmatan dan mengalih keluarnya. Apabila pelanggan memanggil perkhidmatan, ia menggunakan Ribbon untuk pengimbangan beban, dan juga mengkonfigurasi Hystrix sebagai pemutus litar untuk memastikan ketersediaan dan kestabilan perkhidmatan yang tinggi.

4. Ringkasan

Artikel ini memperkenalkan cara menggunakan bekas Spring Cloud untuk melaksanakan tadbir urus perkhidmatan mikro, termasuk pendaftaran dan penemuan perkhidmatan, pengurusan konfigurasi dan penggunaan perkhidmatan. Melalui komponen seperti Eureka, Config Server, Ribbon dan Hystrix yang disediakan oleh Spring Cloud, pembangun boleh membina dan mengurus aplikasi perkhidmatan mikro dengan lebih mudah. Sudah tentu, terdapat banyak aspek lain yang terlibat dalam seni bina perkhidmatan mikro, seperti gerbang perkhidmatan, pengesanan teragih, dan pengurusan kunci rahsia Kami akan memperkenalkan kandungan ini dalam artikel berikutnya.

Atas ialah kandungan terperinci Melaksanakan tadbir urus perkhidmatan mikro berdasarkan bekas Spring Cloud. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1658
14
Tutorial PHP
1257
29
Tutorial C#
1231
24
Rangka Kerja PHP dan Perkhidmatan Mikro: Penerapan dan Pengkontenaan Asli Awan Rangka Kerja PHP dan Perkhidmatan Mikro: Penerapan dan Pengkontenaan Asli Awan Jun 04, 2024 pm 12:48 PM

Faedah menggabungkan rangka kerja PHP dengan perkhidmatan mikro: Kebolehskalaan: Memanjangkan aplikasi dengan mudah, menambah ciri baharu atau mengendalikan lebih banyak beban. Fleksibiliti: Perkhidmatan mikro digunakan dan diselenggara secara bebas, menjadikannya lebih mudah untuk membuat perubahan dan kemas kini. Ketersediaan tinggi: Kegagalan satu perkhidmatan mikro tidak menjejaskan bahagian lain, memastikan ketersediaan yang lebih tinggi. Kes praktikal: Menggunakan perkhidmatan mikro menggunakan Laravel dan Kubernetes Langkah: Buat projek Laravel. Tentukan pengawal perkhidmatan mikro. Buat fail Docker. Buat manifes Kubernetes. Sebarkan perkhidmatan mikro. Uji perkhidmatan mikro.

Bagaimanakah rangka kerja Java menyokong penskalaan mendatar perkhidmatan mikro? Bagaimanakah rangka kerja Java menyokong penskalaan mendatar perkhidmatan mikro? Jun 04, 2024 pm 04:34 PM

Rangka kerja Java menyokong pengembangan mendatar perkhidmatan mikro Kaedah khusus termasuk: Spring Cloud menyediakan Ribbon dan Feign untuk pengimbangan beban sisi pelayan dan klien. NetflixOSS menyediakan Eureka dan Zuul untuk melaksanakan penemuan perkhidmatan, pengimbangan beban dan failover. Kubernetes memudahkan penskalaan mendatar dengan penskalaan automatik, pemeriksaan kesihatan dan mulakan semula automatik.

Jaminan ketekalan data seni bina microservice rangka kerja Java Jaminan ketekalan data seni bina microservice rangka kerja Java Jun 02, 2024 am 10:00 AM

Jaminan ketekalan data dalam seni bina perkhidmatan mikro menghadapi cabaran transaksi yang diedarkan, ketekalan akhirnya dan kemas kini yang hilang. Strategi termasuk: 1. Pengurusan transaksi yang diedarkan, menyelaraskan urus niaga silang perkhidmatan; 2. Kekonsistenan akhirnya, membenarkan kemas kini bebas dan penyegerakan melalui baris gilir mesej 3. Kawalan versi data, menggunakan penguncian optimistik untuk menyemak kemas kini serentak;

Apakah peranan yang dimainkan Spring Boot dalam seni bina perkhidmatan mikro? Apakah peranan yang dimainkan Spring Boot dalam seni bina perkhidmatan mikro? Jun 04, 2024 pm 02:34 PM

SpringBoot memainkan peranan penting dalam memudahkan pembangunan dan penggunaan dalam seni bina perkhidmatan mikro: menyediakan konfigurasi automatik berasaskan anotasi dan mengendalikan tugas konfigurasi biasa, seperti sambungan pangkalan data. Menyokong pengesahan kontrak API melalui ujian kontrak, mengurangkan perubahan yang merosakkan antara perkhidmatan. Mempunyai ciri sedia pengeluaran seperti pengumpulan metrik, pemantauan dan pemeriksaan kesihatan untuk memudahkan pengurusan perkhidmatan mikro dalam persekitaran pengeluaran.

Cipta sistem teragih menggunakan rangka kerja perkhidmatan mikro Golang Cipta sistem teragih menggunakan rangka kerja perkhidmatan mikro Golang Jun 05, 2024 pm 06:36 PM

Cipta sistem teragih menggunakan rangka kerja mikro perkhidmatan Golang: Pasang Golang, pilih rangka kerja mikroperkhidmatan (seperti Gin), cipta perkhidmatan mikro Gin, tambah titik akhir untuk menggunakan perkhidmatan mikro, bina dan jalankan aplikasi, buat pesanan dan inventori perkhidmatan mikro, gunakan titik akhir untuk memproses pesanan dan inventori Gunakan sistem pemesejan seperti Kafka untuk menyambung perkhidmatan mikro Gunakan perpustakaan sarama untuk menghasilkan dan menggunakan maklumat pesanan

Rangka kerja PHP dan perkhidmatan mikro: ketekalan data dan pengurusan transaksi Rangka kerja PHP dan perkhidmatan mikro: ketekalan data dan pengurusan transaksi Jun 02, 2024 pm 04:59 PM

Dalam seni bina perkhidmatan mikro PHP, ketekalan data dan pengurusan transaksi adalah penting. Rangka kerja PHP menyediakan mekanisme untuk melaksanakan keperluan ini: gunakan kelas transaksi, seperti DB::transaction dalam Laravel, untuk menentukan sempadan transaksi. Gunakan rangka kerja ORM, seperti Doktrin, untuk menyediakan operasi atom seperti kaedah lock() untuk mengelakkan ralat konkurensi. Untuk urus niaga teragih, pertimbangkan untuk menggunakan pengurus transaksi teragih seperti Saga atau 2PC. Sebagai contoh, urus niaga digunakan dalam senario kedai dalam talian untuk memastikan konsistensi data apabila menambah pada troli beli-belah. Melalui mekanisme ini, rangka kerja PHP mengurus urus niaga dan konsistensi data dengan berkesan, meningkatkan keteguhan aplikasi.

Kelebihan dan Kelemahan Aplikasi Java Kontainer Kelebihan dan Kelemahan Aplikasi Java Kontainer Jun 04, 2024 pm 05:45 PM

Kelebihan aplikasi Java dalam kontena: Pengasingan sumber, pencegahan gangguan dan kelemahan keselamatan. Sangat mudah alih dan mudah dipindahkan ke platform yang berbeza. Kebolehskalaan, mudah untuk mengembangkan dan menyesuaikan kapasiti secara automatik. Tingkatkan kecekapan pembangunan dan gunakan alatan dan persekitaran yang konsisten. Mengurangkan kos dan menggunakan sumber sistem dengan cekap. Kelemahan: Overhed prestasi, boleh menjejaskan masa permulaan dan mulakan semula. Isu keselamatan, bekas berkongsi kernel, mungkin terdapat kelemahan keselamatan. Menguruskan kerumitan, sistem besar memerlukan penggunaan alat dan platform khusus. Had sumber yang menjejaskan prestasi atau kestabilan. Kegagalan rangkaian boleh menyebabkan masalah aplikasi teragih.

Pemantauan seni bina perkhidmatan mikro dan membimbangkan dalam rangka kerja Java Pemantauan seni bina perkhidmatan mikro dan membimbangkan dalam rangka kerja Java Jun 02, 2024 pm 12:39 PM

Pemantauan dan amaran seni bina mikroperkhidmatan dalam rangka kerja Java Dalam seni bina perkhidmatan mikro, pemantauan dan amaran adalah penting untuk memastikan kesihatan sistem dan operasi yang boleh dipercayai. Artikel ini akan memperkenalkan cara menggunakan rangka kerja Java untuk melaksanakan pemantauan dan membimbangkan seni bina perkhidmatan mikro. Kes praktikal: Gunakan SpringBoot+Prometheus+Alertmanager1. Integrasikan Prometheus@ConfigurationpublicclassPrometheusConfig{@BeanpublicSpringBootMetricsCollectorsspringBootMetric.

See all articles