Spring Cloud学习笔记.实现第一个微服务系统(服务中心)

本文详细介绍了如何在Idea中搭建Spring Cloud Eureka作为服务中心,并配置多节点集群,以及配置文件和部署流程。通过实例展示如何创建虚拟地址和不同环境的配置,最后演示了部署及查看服务注册的效果。
摘要由CSDN通过智能技术生成

基于Eureka实现“服务中心”

  • 在Idea中安装Spring Assistant
  • 新建Spring Cloud项目

File->New->Project,选择Spring Assistant,选择Default选项->Next->输入Project Name–>选择“Spring Cloud Discovery”->Eureka Server->Next->Finish
在这里插入图片描述
在这里插入图片描述

注意依赖

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.5.5</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>
	<groupId>com.example</groupId>
	<artifactId>demo</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<name>Eureka Server Demo</name>
	<description>Demo project for Spring Boot</description>
	<properties>
		<java.version>1.8</java.version>
		<spring-cloud.version>2020.0.4</spring-cloud.version>
	</properties>

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

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

		<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.apache.maven.plugins</groupId>
				<artifactId>maven-resources-plugin</artifactId>
				<version>3.1.0</version>
			</plugin>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>

</project>

添加配置:application.properties

spring.application.name=Eureka Server Demo
#spring.profiles.active=node1
server.port=8080

#是否将自己注册到Eureka Server,默认为true。
eureka.client.register-with-eureka=true

#是否从Eureka Server获取注册信息,默认为true。
eureka.client.fetch-registry=true

#设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可使用 , 分隔。
eureka.client.serviceUrl.defaultZone=http://localhost:${server.port}/eureka/

实现“服务中心”集群

配置虚拟地址:C:\Windows\System32\drivers\etc
127.0.0.1 node1
127.0.0.1 node2
127.0.0.1 node3

多环境资源配置

  • application-node1.properties
spring.application.name=Eureka Server Demo
server.port=8081
#节点名称
eureka.instance.hostname=node1

#是否将自己注册到Eureka Server,默认为true。
eureka.client.register-with-eureka=true

#是否从Eureka Server获取注册信息,默认为true。
eureka.client.fetch-registry=true

#设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可使用 , 分隔。
eureka.client.serviceUrl.defaultZone=http://node2:8082/eureka/,http://node3:8083/eureka/

  • application-node2.properties
spring.application.name=Eureka Server Demo
server.port=8082
#节点名称
eureka.instance.hostname=node2

#是否将自己注册到Eureka Server,默认为true。
eureka.client.register-with-eureka=true

#是否从Eureka Server获取注册信息,默认为true。
eureka.client.fetch-registry=true

#设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可使用 , 分隔。
eureka.client.serviceUrl.defaultZone=http://node1:8081/eureka/,http://node3:8083/eureka/

  • application-node3.properties
spring.application.name=Eureka Server Demo
server.port=8083
#节点名称
eureka.instance.hostname=node3

#是否将自己注册到Eureka Server,默认为true。
eureka.client.register-with-eureka=true

#是否从Eureka Server获取注册信息,默认为true。
eureka.client.fetch-registry=true

#设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可使用 , 分隔。
eureka.client.serviceUrl.defaultZone=http://node1:8081/eureka/,http://node2:8082/eureka/

打包部署

maven: lifeCycle->clean->package
在这里插入图片描述
部署
cmd
java -jar demo-0.0.1-SNAPSHOT.jar --spring.profiles.active=node1

cmd
java -jar demo-0.0.1-SNAPSHOT.jar --spring.profiles.active=node2

cmd
java -jar demo-0.0.1-SNAPSHOT.jar --spring.profiles.active=node3

运行成功后的效果:
在这里插入图片描述
##TODO
部署那里的指令如何一键执行(部署)?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值