springboot2 springcloud Greenwich.SR3 构建微服务--1.eureka注册中心搭建

本文主要是介绍springboot2 springcloud Greenwich.SR3 构建微服务--1.eureka注册中心搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本一系列springcloud的文章主主要讲应用, 也会涉及到一些原理的讲解.

写了几句自己这段时间看书,总结的微服务的东西送给你们 :

道为源,源分多支为术,如龙生九子,九子各不同,然皆为龙也.

凡物发必依其理,当知其源,勿学其术而不究其道,执其道而轻其术,可矣.

 

道为源头,从源发可以发展出很多的形态就是术,就想龙生九子,九子各不同,但是他们的源头都是龙.

需要掌握事物发展的根源, 知道背后的运行的原理,而不是却看一个一个的实现,把握住后面的原理,看或者看现今非常流行的东西都可以了.

 

本系列的微服务文章是基于目前最新的大版本  (2019年9月20日)  ,具体为:

oracle jdk1.8

IntelliJ IDEA 2017.3.5 x64

最新的 springboot 2.1.8 GA

最新的 springcloud Greenwich.SR3  GA

采用此目前最新版本的所有的坑,我都会填一遍!!!!

注意事项, 把idea的所有配置文件的编码都改成utf-8 , 这个电脑上忘记改了, 结果,我又把一些中文注释又写了一遍!!!

所以以后尽量写英文的注释把, 这样切换编码就不担心乱码了,记住了

 

至于我们公司为什么采用微服务, 一部分原因是因为有的人需要绩效, 还有就是平台的改造, 做一个公司的大的基础技术平台,以后新的项目都依赖于此平台.

以前上海一家做p2p的公司, 当时还是一个整体的应用, 我没去之前他们每次更新都做的全局更新, 有时候修复了一个线上的bug, 还得全量更新, 完全是没必要去动那些没有问题的模块啊 . 这就是单体应用的一个痛点了, 还有应用的伸缩性, 隔离性, 微服务的出现解决了很多的问题. 所以用起来的.

 

其实目前市面上开源的注册中心很多,像zookeeper,macos ,都可以作为注册中心.而且nacos已经出了1.0的GA版本.可以试试哦.

不扯别的了.今天就是试试eureka好了. eureka 作为一个典型的客户端的注册中心 , 客户端拉取从注册中心拉取服务的信息.

 

1.eureka服务注册中心

a.新建springboot项目就是eureka-server, 添加eureka-server 的依赖 ,最后的pom文件为:

<?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.1.8.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.example</groupId><artifactId>eureka-servser</artifactId><version>0.0.1-SNAPSHOT</version><name>eureka-servser</name><description>Demo project for Spring Boot</description><properties><java.version>1.8</java.version><spring-cloud.version>Greenwich.SR3</spring-cloud.version></properties><dependencies><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.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build>
</project>

 

b.在启动类上添加注册中心服务端的注解,

添加注解:@EnableEurekaServer, 启用eureka server注册中心

 

c.修改配置文件,对了,我用的是application.properties 配置文件, 没有使用yml配置文件, 因为那个看不习惯.

以后的spring.application.name  尽量不要带- 这次的坑我自己填了, 其实也还好, 不算什么坑.看团队的变成习惯吧

#应用端口号,8761是默认的端口号, 改不改你高兴就好
server.port=8761#应用的名字
spring.application.name=eureka-server#eureka的注册地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka#eureka服务是否向自己注册,默认true.这里我们不想自己注册
eureka.client.register-with-eureka=false

 

d.启动springboot项目, 访问http://localhost:8761 , 就能看到eureka的界面了. 这里不截图了

 

2.新建一个客户端springboot项目 eureka-client,  向刚才启动的注册中心注册进去

新建完成后的pom文件是:

<?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.1.8.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.example</groupId><artifactId>eureka-client</artifactId><version>0.0.1-SNAPSHOT</version><name>eureka-client</name><description>Demo project for Spring Boot</description><properties><java.version>1.8</java.version><spring-cloud.version>Greenwich.SR3</spring-cloud.version></properties><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><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>

在启动类上添加注解,标明是客户端

@EnableEurekaClient

 

 

修改配置文件,标明向哪个url进行注册.

修改配置文件:#应用名字,在eureka中注册的名字
spring.application.name=eureka-client#端口号
server.port=8861#注册的url
eureka.client.eureka-server-u-r-l-context=http://localhost:8761/eureka

 

然后就可以启动eureka-client 项目了, 再次去刷新http://localhost:8761 就可以看到一个应用注册来了.

如果你启动的时候可能出现自动停止.

在pom中添加一个web的依赖, 上面的总pom已经加入了

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

 

恭喜 你就完成了微服务入门的第一步.

 

其实框架的使用都没什么难度, 难的是概念的理解, 以及原理的学习.框架多用几遍就会了, 没啥大不了.

还是不会就去查看springcloud 的官方文档, 详细的多.

所以多看看微服务的书, 比看什么框架要好很多.什么书, 看你自己了. 那种介绍框架怎么使用的书就不大看了.

 

整个代码地址是:

https://github.com/changhe626/micro-service

Java Framework,欢迎各位前来交流java相关
QQ群:965125360

 

 

 

这篇关于springboot2 springcloud Greenwich.SR3 构建微服务--1.eureka注册中心搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/986269

相关文章

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10