springCloud项目搭建
新建父maven项目
groupId:pers.xzp.springCloud
artifactId:springCloud
父项目中仅仅需要一个pom文件,用于管理模块的依赖统一、继承等
编辑pom文件
首先项目包结构为:pom
添加依赖声明:依赖声明,不会引入依赖,只有当模块引入依赖坐标的时候才会引入响应依赖
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<!--springcloud版本-->
<spring-cloud.version>Finchley.SR2</spring-cloud.version>
<springboot.version>2.0.6.RELEASE</springboot.version>
</properties>
<!-- dependencyManagement:帮助我们去管理坐标的版本:仅仅声明,不引入依赖-->
<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>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${springboot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<!--springboot支持-->
<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>
</dependency>
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<!--Devtools-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<!-- optional=true,依赖不会传递,该项目依赖devtools;之后依赖boot项目的项目如果想要使用devtools,需要重新引入 -->
<!--<optional>true</optional>-->
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork> <!-- 如果没有该生效标志,热部署的devtools不生效 -->
</configuration>
</plugin>
</plugins>
</build>
创建Eureka注册中心模块
Eureka服务端作为服务注册中心
模块名:eureka-registryCenter,端口:7001
引入Eureka服务端依赖
<dependencies>
<!--Eureka服务端支持-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
编辑核心配置文件
server:
#端口
port: 7001
eureka:
instance:
#服务注册中心实列的主机名
hostname: localhost
server:
#关闭自我保护机制,防止失效的服务也被访问
# enable-self-preservation: false
#该配置可以修改检查失效的服务器,每隔5s去扫描检查失效的服务 默认60s
eviction-interval-timer-in-ms: 5000
client:
#是否向服务注册中心注册自己 自己注册了自己就是有毛病
register-with-eureka: false
#是否监测服务 翻译:获取注册
fetch-registry: false
#服务注册中心的配置内容,指定服务注册中心的位置
service-url:
#单机配置 就是访问注册中心的路径
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
创建项目引导类
作为Eureka服务端的引导类,需要被@EnableEurekaServer标注
//@EnableEurekaServer:标注的类表示Eureka服务端,作为注册中心
@EnableEurekaServer
@SpringBootApplication
public class RegistryCenter_7001 {
public static void main(String[] args) {
SpringApplication.run(RegistryCenter_7001.class);
}
}
创建Eureka客户端:服务提供者
模块名字:provider-payment8001 端口号:8001
引入Eureka客户端依赖
<!--eureka客户端支持 我们去写支付功能 服务-->
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
编辑核心配置文件
server:
port: 8001
# Eureka客户端取别名
spring:
application:
name: payment
eureka:
client:
service-url:
# 注册Eureka客户端到服务注册中心 需要与注册中心配置对应
defaultZone: http://localhost:7001/eureka
编码
实体类
@Data
public class User implements Serializable {
private int id;
private String name;
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birthday;
public User(int id, String name, Date birthday) {
this.id = id;
this.name = name;
this.birthday = birthday;
}
public User() {
}
}
Controller控制器
//@Slf4j:使用log4j日志需要,默认生成log实例
@Slf4j
@Controller
public class UserController {
private static SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
@GetMapping("/getalluser")
@ResponseBody
public String getAllUser(){
User user = null;
try {
user = new User(1,"张三",sdf.parse("2020-10-10"));
} catch (ParseException e) {
log.debug("日期类型转换失败");
}
return user.toString();
}
}
测试
有服务端和客户端,类似WebSocket编程,需要我们先启动服务端;
因此,我们需要先启动Eureka注册中心eureka-registryCenter
,然后在启动Eureka客户端provider-payment8001
浏览器输入:http://localhost:7001,会进入了Eureka服务注册中心
输入:http://localhost:8001/getalluser,会访问到服务提供者的数据
输入:http://localhost:7001/getalluser
小结
注册中心可以类比tomcat管理javaweb应用
Eureka有服务端和客户端概念,可以参考WebSocket编程
springCloud项目搭建的更多相关文章
- spring-cloud项目搭建
springCloud项目搭建手册 springcloud应用场景及微服务框架发展趋势 Spring Cloud为开发人员提供了工具,以快速构建分布式系统中的某些常见模式(例如,配置管理,服务发现,断 ...
- 微服务SpringCloud项目架构搭建入门
Spring的微服务框架SpringCloud受到众多公司欢迎,给大家带来一篇框架搭建入门.本次采用的版本是Spring Cloud版本为Finchley.RELEASE. 一.SpringCloud ...
- SpringCloud(7)---网关概念、Zuul项目搭建
SpringCloud(7)---网关概念.Zuul项目搭建 一.网关概念 1.什么是路由网关 网关是系统的唯一对外的入口,介于客户端和服务器端之间的中间层,处理非业务功能 提供路由请求.鉴权.监控. ...
- 基于idea的springcloud的helloworld项目搭建过程整理
Springcloud的搭建主要包括三个部分:服务注册中心.服务提供者.服务消费者.每一个部分都是一个springboot项目,它们通过配置文件(application.properties或appl ...
- 一起来学Spring Cloud | 第一章 :如何搭建一个多模块的springcloud项目
在spring cloud系列章节中,本来已经写了几个章节了,但是自己看起来有些东西写得比较杂,所以重构了一下springcloud的章节内容,新写了本章节,先教大家在工作中如何搭建一个多模块的spr ...
- 「开源」SpringCloud+vue搭建的商城项目
最近在研究SpringCloud,看到一个基于SpringCloud+vue搭建的模拟商城项目.用来辅助学习SpringCloud企业级开发还是很有帮助的.强烈推荐!! 源码地址在最后. spring ...
- 基于springcloud框架搭建项目-Eureka篇(一)
springcloud项目近年来算是很流行的了,不少公司项目目前都用到了,毕竟优点很多,刚好公司项目用到了,根据自己的理解,简单搭建一下,以便以后学习 这里简单的介绍一下它: SpringCloud, ...
- 从零搭建一个SpringCloud项目之Feign搭建
从零搭建一个SpringCloud项目之Feign搭建 工程简述 目的:实现trade服务通过feign调用user服务的功能.因为trade服务会用到user里的一些类和接口,所以抽出了其他服务需要 ...
- 搭建简单的SpringCloud项目三:问题及解决
GitHub:https://github.com/ownzyuan/test-cloud 前篇:搭建简单的SpringCloud项目一:注册中心和公共层 搭建简单的SpringCloud项目二:服务 ...
随机推荐
- rake
ruby-rake https://rubygems.org/gems/rake 官方文档 https://ruby.github.io/rake/ http://docs.seattlerb.org ...
- render 强大的渲染函数
可以动态的创建节点 可以改变表格中要去换一种形式去展示的列 (未完暂定)
- Fitness - 05.23
倒计时222天 运动40分钟,共计8组,4.2公里.拉伸10分钟. 每组跑步3分钟(6.5KM/h),走路2分钟(5.5KM/h). 终于赶在姨妈前完成第3周的跑步训练了,可喜可贺~~ 下周预计要休息 ...
- spring集成shiro,事务失效问题 not eligible for auto-proxying
BeanPostProcessor bean实例化顺序有关,@Configuration会最先实例化,也就是在spring启动完成之前. 导致Configuration中使用的注入,没能在spring ...
- DHCP和NAT
DHCP(dynamic host configuration protocol)用于内网动态分配IP,是一种基于UDP的应用层协议. NAT(net address translation)用于内网 ...
- SpringCloud 服务负载均衡和调用 Ribbon、OpenFeign
1.Ribbon Spring Cloud Ribbon是基于Netflix Ribbon实现的-套客户端―负载均衡的工具. 简单的说,Ribbon是Netlix发布的开源项目,主要功能是提供客户端的 ...
- Google Kick Start 2020 Round C
ac代码 A. Countdown for循环跑一跑,没啥好说的. B. Stable Wall 如果\(s_{i,j} \ne s_{i+1,j}\),那么说明\(s_{i+1,j}\)必须在\(s ...
- shell 逻辑判断
|| && 查了 Stack Overflow ||,表示或,从前往后执行,执行第一个真 &&,前者是真才会接着执行 ; 表示接着往下执行,不管前者如何 #!/bin/ ...
- python日志模块配置
import logging logging.basicConfig(filename= 'out.log',filemode= 'w+', level= logging.DEBUG, format= ...
- Scrapy框架的架构原理解析
爬虫框架--Scrapy 如果你对爬虫的基础知识有了一定了解的话,那么是时候该了解一下爬虫框架了.那么为什么要使用爬虫框架? 学习框架的根本是学习一种编程思想,而不应该仅仅局限于是如何使用它.从了解到 ...