springcloud ( 1 Eureka的使用 )

8 篇文章 0 订阅
8 篇文章 0 订阅

本篇主要介绍Eureka 实现服务的发现与注册,所有内容全部来自于互联网,仅供参考

1  创建parent工程

   新建maven工程,配置pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.could.shj</groupId>
    <artifactId>parent-clould</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>pom</packaging>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.3.RELEASE</version>
        <relativePath/>
    </parent>

    <modules>
        <module>eureka-server</module>
        <module>eureka-client</module>
    </modules>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

请注意  

<modules>
    <module>eureka-server</module>
    <module>eureka-client</module>
</modules>

分别代表着两个模块

2  创建服务注册中心 eureka-server

右键项目,在新建中选择模块,

选择 spring initialir

然后输入相关信息

 

然后选择下图内容

创建完成之后配置其pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>com.clould.shj</groupId>
	<artifactId>eureka-server</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>eureka-server</name>
	<description>Demo project for Spring Boot</description>

	<parent>
		<groupId>com.could.shj</groupId>
		<artifactId>parent-clould</artifactId>
		<version>1.0-SNAPSHOT</version>
	</parent>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
		<java.version>1.8</java.version>
		<spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
		</dependency>


	</dependencies>




</project>

配置启动文件的注解

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {

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

配置application.properties

server.port=8761
eureka.instance.hostname=127.0.0.1
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false
eureka.client.service-url.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/
spring.application.name=eureka-server

然后可以启动项目

然后在浏览器中输入  http://127.0.0.1:8761/

3 创建服务提供者  eureka-client

当client向server注册时,它会提供一些元数据,例如主机和端口,URL,主页等

Eureka server 从每个client实例接收心跳消息。 如果心跳超时,则通常将该实例从注册server中删除。

创建步骤参考server 的创建,创建完成之后,修改pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>com.could.shj</groupId>
	<artifactId>eureka-client</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>eureka-client</name>
	<description>Demo project for Spring Boot</description>

	<parent>
		<groupId>com.could.shj</groupId>
		<artifactId>parent-clould</artifactId>
		<version>1.0-SNAPSHOT</version>
	</parent>



	<dependencies>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
		</dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
	</dependencies>



	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>


</project>

 然后在启动类中增加注解

@SpringBootApplication
@EnableEurekaClient
@RestController
public class EurekaClientApplication {

	public static void main(String[] args) {

		SpringApplication.run(EurekaClientApplication.class, args);
	}

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

	@RequestMapping("/hello")
	public String home(@RequestParam(value = "name", defaultValue = "shj") String name) {
		return "hello " + name + " ,i am from port:" + port;
	}

}

配置application.properties

server.port=8762
spring.application.name=eureka-client
eureka.client.service-url.defaultZone=http://127.0.0.1:8761/eureka/

然后启动项目

刷新http://127.0.0.1:8761/

此时在浏览器中输入: http://127.0.0.1:8762/hello

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Cloud的Eureka是一个服务发现框架,它用于构建可伸缩和具有弹性的微服务应用程序。通过Eureka,服务实例可以注册到Eureka服务器,并且可以查询已注册的服务。服务消费者可以使用Eureka客户端查找并联系指定的服务生产者。Eureka具有高可用性和自我治愈能力,可以帮助您构建高度可用的微服务体系结构。 ### 回答2: Spring Cloud Eureka是一个服务注册和发现模块,它实现了Netflix公司开发的基于REST的服务注册与发现中间件Eureka。在微服务架构中,组成微服务的各个服务需要相互调用,而服务调用的目标地址可能会经常变化。使用Eureka进行服务注册与发现,可以在一个管理控制台上跟踪所有的微服务实例,并且根据实际情况动态调整服务实例。 在Spring Cloud项目中,使用Eureka可以非常方便地实现服务注册与发现。首先,我们需要在pom.xml文件中添加eureka-client和eureka-server的依赖。对于服务提供者,我们可以添加@EnableDiscoveryClient注解以将其注册到Eureka服务器。对于服务调用者,我们可以使用@EnableDiscoveryClient注解注释服务,并使用@LoadBalanced注解启用负载平衡。 在使用Spring Cloud Eureka的过程中,我们需要至少一个Eureka服务器来管理注册的各个微服务实例。可以通过在pom.xml文件中添加eureka-server依赖来实现Eureka服务器的构建。我们可以通过在配置文件中设置eureka.client.serviceUrl.defaultZone属性来指定要连接的Eureka服务器的地址。 在启动Spring Boot应用程序之后,可以在Eureka服务器的控制台中看到该服务的实例。如果该服务实例发生任何变化(例如,该服务实例被删除或添加),Eureka服务器将根据实际情况自动更新相应的服务实例信息。 总之,使用Spring Cloud Eureka可以方便地实现服务的注册与发现,并且可以轻松管理跟踪不断变化的微服务实例。这使得微服务架构的实现更加简单和可靠。 ### 回答3: SpringCloud是一种开源框架,它是一组分布式系统的工具,它的主要目标是使开发者能够轻松地构建和管理复杂的分布式系统。而Eureka作为Spring Cloud的一个组件,是服务注册中心,它能够让我们更容易地实现服务的发现与注册。因为在分布式系统中,由于分布式的性质,服务的IP地址可能会随时发生变化,而Eureka能够实时地监测服务的变化,当有服务发生变化时,它能够立即通知到其他服务。 在使用SpringCloud中的Eureka时,需要进行如下的几个步骤: 1、新建一个SpringBoot的Maven工程; 2、在pom.xml文件中添加相应依赖,并更新Maven; 3、新建一个启动类,并在类上添加@EnableEurekaServer注解; 4、在application.yml文件中添加配置,指定服务的名称和端口号; 5、启动应用程序,在浏览器中访问http://localhost:8761,即可打开Eureka的控制台。 在Eureka的控制台中,可以看到已注册的服务列表、服务的健康状况和统计数据等信息,而且当服务发生变化时,也会显示在控制台中。此外,由于Eureka是一个服务注册中心,我们还可以在其他应用程序中使用Eureka Client来注册和发现服务,这样就可以实现服务之间的互相通信。 总的来说,Eureka使用可以让开发者更加方便地构建和管理复杂的分布式系统,因为它能够实时地监测服务的变化,做到服务的自动发现和注册。考虑到这种优势,Eureka已经成为了Spring Cloud中非常重要的组件之一,它的应用场景也非常广泛,比如微服务架构、物联网等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值