Rumah >Java >javaTutorial >Menggunakan Nacos untuk penemuan perkhidmatan dalam pembangunan API Java

Menggunakan Nacos untuk penemuan perkhidmatan dalam pembangunan API Java

PHPz
PHPzasal
2023-06-18 08:27:031948semak imbas

Dengan peningkatan aplikasi asli awan, seni bina perkhidmatan mikro semakin digemari oleh pembangun. Penemuan perkhidmatan ialah bahagian penting dalam seni bina perkhidmatan mikro, yang membolehkan perkhidmatan mendaftarkan diri mereka dan berkomunikasi dengan perkhidmatan lain. Dalam pembangunan Java, Nacos ialah pusat penemuan dan konfigurasi perkhidmatan sumber terbuka yang popular Ia menyediakan antara muka API dan UI yang mudah digunakan, membolehkan pembangun mengurus dan menyelaras perkhidmatan dengan lebih baik. Artikel ini akan memperkenalkan cara menggunakan Nacos untuk penemuan perkhidmatan dalam pembangunan API Java.

  1. Pasang Nacos

Mula-mula, anda perlu memuat turun dan memasang Nacos. Nacos menyediakan dua kaedah pemasangan: menyusun daripada kod sumber dan memasang melalui pakej binari. Di sini, kami memilih untuk memasang melalui pakej binari.

Alamat muat turun: https://github.com/alibaba/nacos/releases

Selepas muat turun selesai, nyahmampat dan mulakan perkhidmatan Nacos. Cipta ruang nama dan perkhidmatan dalam konsol Nacos untuk memudahkan pengurusan perkhidmatan yang bersatu.

  1. Perkenalkan kebergantungan

Dalam projek Gradle atau Maven, tambahkan kebergantungan klien Nacos:

Gradle:

implementation 'com.alibaba.nacos:nacos-client:2.0.1'

Maven :

<dependency>
  <groupId>com.alibaba.nacos</groupId>
  <artifactId>nacos-client</artifactId>
  <version>2.0.1</version>
</dependency>
  1. Pengguna perkhidmatan menulis

Apabila menulis pengguna perkhidmatan, anda perlu menggunakan objek DiscoveryClient yang disediakan oleh Nacos untuk mendapatkan semua contoh perkhidmatan yang tersedia dan menyediakannya untuk masa hadapan permintaan Pilih contoh.

import com.alibaba.cloud.nacos.NacosDiscoveryProperties;
import com.alibaba.cloud.nacos.discovery.NacosDiscoveryClient;
import com.alibaba.nacos.api.exception.NacosException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import java.util.List;

@Component
public class ServiceConsumer {
    @Autowired
    private NacosDiscoveryProperties discoveryProperties;

    public String getServiceUrl(String serviceName) throws NacosException {
        NacosDiscoveryClient nacosDiscoveryClient = new NacosDiscoveryClient(discoveryProperties);
        List<Instance> instances = nacosDiscoveryClient.getInstances(serviceName);
        if (CollectionUtils.isEmpty(instances)) {
            throw new RuntimeException("No available instance for service");
        }
        Instance instance = LoadBalancer.chooseInstance(instances);
        return instance.getUri().toString();
    }
}

Dalam kod di atas, kami mendapat senarai tika perkhidmatan melalui DiscoveryClient dan pilih tika perkhidmatan menggunakan LoadBalancer. Anda boleh menyesuaikan LoadBalancer untuk memenuhi keperluan anda.

  1. Menulis penyedia perkhidmatan

Apabila menulis pembekal perkhidmatan, anda perlu mendaftarkan perkhidmatan dengan Nacos dan melaksanakan logik perniagaan khusus perkhidmatan tersebut.

import com.alibaba.cloud.nacos.registry.NacosRegistration;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@EnableDiscoveryClient
@RestController
public class ServiceProvider {
    @Autowired
    private NacosRegistration registration;

    @Value("${server.port}")
    private int port;

    public static void main(String[] args) {
        SpringApplication.run(ServiceProvider.class, args);
    }

    @GetMapping("/")
    public String index() {
        return "Hello, world!";
    }

    @GetMapping("/register")
    public String register() {
        registration.register();
        return "服务注册成功";
    }
}

Dalam kod di atas, kami menggunakan NacosRegistration untuk mendaftarkan perkhidmatan dengan Nacos dan menyediakan perkhidmatan dalam pengawal.

  1. Jalankan perkhidmatan

Kini, kita boleh memulakan penyedia perkhidmatan dan pengguna perkhidmatan, dan mengakses perkhidmatan yang disediakan oleh penyedia perkhidmatan melalui pengguna perkhidmatan.

Lawati http://localhost:8080/register untuk mendaftarkan perkhidmatan ke Nacos.

Lawati http://localhost:8080/ dan anda boleh melihat kandungan yang dikembalikan oleh pembekal perkhidmatan.

  1. Ringkasan

Artikel ini memperkenalkan cara menggunakan Nacos untuk penemuan perkhidmatan dalam pembangunan API Java. Menggunakan Nacos, perkhidmatan boleh didaftarkan dan ditemui dengan mudah, dan tiada pengekodan tambahan diperlukan untuk mencapai ketersediaan perkhidmatan yang tinggi. Saya harap artikel ini dapat membantu pembangun Java.

Atas ialah kandungan terperinci Menggunakan Nacos untuk penemuan perkhidmatan dalam pembangunan API Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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