Rumah > Java > javaTutorial > teks badan

Cara menggunakan perkhidmatan mikro dan teknologi kontena dalam tindanan teknologi Java

WBOY
Lepaskan: 2023-09-06 14:32:00
asal
619 orang telah melayarinya

Cara menggunakan perkhidmatan mikro dan teknologi kontena dalam tindanan teknologi Java

Cara menggunakan perkhidmatan mikro dan teknologi kontena dalam tindanan teknologi Java

Dengan peningkatan pengkomputeran awan dan data besar, aplikasi tunggal tradisional tidak lagi dapat memenuhi keperluan pembangunan pesat. Kemunculan perkhidmatan mikro dan teknologi kontena menyediakan cara yang lebih fleksibel dan berskala untuk pembangunan dan penggunaan perisian. Artikel ini akan memperkenalkan cara menggunakan perkhidmatan mikro dan teknologi kontena dalam tindanan teknologi Java dan memberikan contoh kod yang sepadan.

1. Gambaran Keseluruhan Seni Bina Perkhidmatan Mikro
Seni bina perkhidmatan mikro ialah gaya seni bina yang membahagikan aplikasi kompleks kepada perkhidmatan kecil dan autonomi. Setiap perkhidmatan boleh dibangunkan, digunakan dan ditingkatkan secara bebas, berkomunikasi antara satu sama lain melalui protokol komunikasi yang ringan. Berbanding dengan aplikasi monolitik tradisional, seni bina perkhidmatan mikro adalah lebih anjal dan berskala, dan boleh mencapai pembangunan yang sangat selari.

2. Pengenalan kepada Java Microservice Framework
Dalam tindanan teknologi Java, terdapat banyak rangka kerja mikro untuk dipilih, seperti Spring Cloud, Micronaut, Quarkus, dll. Artikel ini mengambil Spring Cloud sebagai contoh untuk memperkenalkan cara menggunakan rangka kerja ini untuk membina aplikasi perkhidmatan mikro.

  1. Buat projek Spring Boot
    Pertama, kita perlu mencipta projek Spring Boot sebagai asas perkhidmatan mikro. Anda boleh menggunakan Spring Initializr untuk membuat projek dengan cepat dan memilih kebergantungan yang diperlukan, seperti Spring Web, Spring Data JPA, dsb. Kemudian, gunakan arahan berikut untuk menjalankan projek:
mvn spring-boot:run
Salin selepas log masuk
  1. Tambah kebergantungan Spring Cloud
    Tambah kebergantungan berkaitan Spring Cloud dalam fail pom.xml, seperti Spring Cloud Netflix Eureka, Spring Cloud Config, dsb. Kebergantungan ini akan membantu kami melaksanakan pendaftaran dan penemuan perkhidmatan, pengurusan konfigurasi dan fungsi lain.
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-config</artifactId>
</dependency>
Salin selepas log masuk
  1. Dayakan pendaftaran dan penemuan perkhidmatan
    Tambahkan anotasi @EnableEurekaServer ke kelas utama aplikasi untuk mendayakan Eureka Server: @EnableEurekaServer注解,启用Eureka Server:
@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApplication.class, args);
    }
}
Salin selepas log masuk
  1. 创建微服务
    创建一个简单的微服务,以提供一个RESTful接口:
@RestController
public class HelloController {
    @GetMapping("/hello")
    public String hello() {
        return "Hello, World!";
    }
}
Salin selepas log masuk
  1. 启用服务注册和发现
    在应用的主类上添加@EnableEurekaClient注解,启用Eureka Client。
@SpringBootApplication
@EnableEurekaClient
public class HelloServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(HelloServiceApplication.class, args);
    }
}
Salin selepas log masuk
  1. 配置服务发现
    在应用的配置文件中,添加以下配置:
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/
Salin selepas log masuk
  1. 测试微服务
    启动Eureka Server和Hello Service,然后使用浏览器访问http://localhost:8761,可以看到Hello Service已经注册到Eureka Server上。然后,访问http://localhost:8080/hello,将返回"Hello, World!"。

三、容器化技术概述
容器化技术是一种将应用及其依赖项打包成可移植的镜像的技术,以实现应用的隔离和部署的一致性。Docker是目前最流行的容器化技术之一,本文将以Docker为例介绍如何将微服务应用容器化。

  1. 创建Docker镜像
    首先,我们需要创建一个Dockerfile文件,用于描述镜像的构建过程。一个简单的Dockerfile如下所示:
FROM openjdk:8
COPY target/myapp.jar /app/myapp.jar
CMD ["java", "-jar", "/app/myapp.jar"]
Salin selepas log masuk

其中,openjdk:8是基础镜像,COPY命令用于将应用jar包复制到镜像中,CMD命令指定容器启动时执行的命令。然后,通过以下命令来构建镜像:

docker build -t myapp .
Salin selepas log masuk
  1. 运行容器
    使用以下命令来运行容器:
docker run -p 8080:8080 myapp
Salin selepas log masuk

其中,-p

rrreee
      Cipta microservices
    1. Cipta Perkhidmatan mikro ringkas untuk menyediakan antara muka yang RESTful:
    2. rrreee
        Dayakan pendaftaran dan penemuan perkhidmatan

        Tambah anotasi @EnableEurekaClient pada kelas utama aplikasi untuk mendayakan Eureka Pelanggan.

        🎜rrreee
          🎜Konfigurasikan penemuan perkhidmatan🎜Dalam fail konfigurasi aplikasi, tambahkan konfigurasi berikut: 🎜🎜rrreee
            🎜Uji perkhidmatan mikro🎜Mulakan Pelayan Eureka dan Perkhidmatan Hello, Kemudian gunakan pelayar untuk mengakses http://localhost:8761 Anda boleh melihat bahawa Perkhidmatan Hello telah didaftarkan pada Pelayan Eureka. Kemudian, mengakses http://localhost:8080/hello akan mengembalikan "Hello, World!". 🎜🎜🎜3. Gambaran Keseluruhan Teknologi Kontena🎜Teknologi kontena ialah teknologi yang membungkus aplikasi dan kebergantungannya ke dalam imej mudah alih untuk mencapai ketekalan pengasingan dan penggunaan aplikasi. Docker ialah salah satu teknologi kontena yang paling popular pada masa ini. Artikel ini akan menggunakan Docker sebagai contoh untuk memperkenalkan cara mengonteni aplikasi perkhidmatan mikro. 🎜🎜🎜Buat imej Docker🎜Pertama, kita perlu mencipta fail Dockerfile untuk menerangkan proses pembinaan imej. Fail Docker yang mudah adalah seperti berikut: 🎜🎜rrreee🎜 Antaranya, openjdk:8 ialah imej asas, arahan COPY digunakan untuk menyalin pakej balang aplikasi ke imej , CMD menentukan arahan yang akan dilaksanakan apabila bekas bermula. Kemudian, gunakan arahan berikut untuk membina imej: 🎜rrreee🎜🎜Jalankan bekas🎜Gunakan arahan berikut untuk menjalankan bekas: 🎜🎜rrreee🎜Antaranya, parameter -p menentukan pemetaan bagi pelabuhan dalaman kontena ke pelabuhan hos. 🎜🎜🎜Gunakan ke platform awan🎜Muat naik imej kontena ke platform awan, seperti Docker Hub, Perkhidmatan Imej Kontena Awan Alibaba, dsb. Kemudian, anda boleh membuat kluster Kubernetes pada platform awan dan menggunakan imej bekas ke kluster. 🎜🎜🎜Di atas ialah pengenalan asas dan kod sampel untuk menggunakan perkhidmatan mikro dan teknologi kontena dalam tindanan teknologi Java. Perkhidmatan mikro dan teknologi kontena adalah trend penting dalam pembangunan dan penggunaan perisian semasa. Saya harap artikel ini dapat membantu pembaca. 🎜

    Atas ialah kandungan terperinci Cara menggunakan perkhidmatan mikro dan teknologi kontena dalam tindanan teknologi Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Label berkaitan:
    sumber:php.cn
    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
    Tutorial Popular
    Lagi>
    Muat turun terkini
    Lagi>
    kesan web
    Kod sumber laman web
    Bahan laman web
    Templat hujung hadapan