文档章节

Spring Cloud 学习笔记

xiaoye08050141
 xiaoye08050141
发布于 2017/05/24 17:12
字数 876
阅读 335
收藏 7

工程搭建

1、http://start.spring.io/ 

   

下载工程

2、import 工程

修改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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>org.xiaoye.clearworld</groupId>
	<artifactId>clearworld-eureka</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>pom</packaging>

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

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.5.3.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</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>Dalston.RELEASE</spring-cloud.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-eureka-server</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>

3、服务注册中心:新建maven模块【clearworld-eureka-register】

修改pom文件

<?xml version="1.0"?>
<project
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
	xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
	<modelVersion>4.0.0</modelVersion>
	
	<parent>
		<groupId>org.xiaoye.clearworld</groupId>
		<artifactId>clearworld-eureka</artifactId>
		<version>0.0.1-SNAPSHOT</version>
	</parent>
	
	<artifactId>clearworld-eureka-register</artifactId>
	<name>clearworld-eureka-register</name>
	<url>http://maven.apache.org</url>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
	</properties>

	<dependencies></dependencies>
</project>

增加配置application.properties

## 端口号
server.port = 8000
## session 超时时间
server.sessionTimeout = 30

eureka.instance.hostname = localhost
eureka.client.registerWithEureka = false
eureka.client.fetchRegistry = false
eureka.client.serviceUrl.defaultZone = http://${eureka.instance.hostname}:${server.port}/eureka/

创建启动类

@EnableEurekaServer
@SpringBootApplication
public class AppStarter {
    
    public static void main(String[] args) {
        SpringApplication.run(AppStarter.class, args);
    }
}

4、服务提供方:新建maven模块【clearworld-eureka-server】

修改pom文件

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

	<parent>
		<groupId>org.xiaoye.clearworld</groupId>
		<artifactId>clearworld-eureka</artifactId>
		<version>0.0.1-SNAPSHOT</version>
	</parent>

	<artifactId>clearworld-eureka-server</artifactId>
	<name>clearworld-eureka-server</name>
	<url>http://maven.apache.org</url>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
	</properties>
	
	<dependencies></dependencies>
</project>

增加配置application.properties

## 系统名称
application.system-name = eureka-server
## 端口号
server.port = 8001
## session 超时时间
server.sessionTimeout = 30

spring.application.name = ${application.system-name}
eureka.client.serviceUrl.defaultZone=http://localhost:8000/eureka/

增加启动类:

@EnableEurekaClient
@SpringBootApplication
public class AppStarter {
    
    public static void main(String[] args) {
        SpringApplication.run(AppStarter.class, args);
    }
}

增加Controller

@RestController
public class TestController {

    @RequestMapping("hello")
    public String hello(@RequestParam String name) {
        return "你好," + name;
    }
}

5、服务消费方:新建maven模块【clearworld-eureka-client】

修改pom文件

<?xml version="1.0"?>
<project
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
	xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
	<modelVersion>4.0.0</modelVersion>
	
	<parent>
		<groupId>org.xiaoye.clearworld</groupId>
		<artifactId>clearworld-eureka</artifactId>
		<version>0.0.1-SNAPSHOT</version>
	</parent>
	
	<artifactId>clearworld-eureka-ribbon</artifactId>
	<name>clearworld-eureka-ribbon</name>
	<url>http://maven.apache.org</url>
	
	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
	</properties>
	
	<dependencies>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-ribbon</artifactId>
		</dependency>
	</dependencies>
</project>

增加配置application.properties

## 系统名称
application.system-name = eureka-client
## 端口号
server.port = 8004
## session 超时时间
server.sessionTimeout = 30

spring.application.name = ${application.system-name}
eureka.client.serviceUrl.defaultZone=http://localhost:8000/eureka/

增加启动类

@EnableDiscoveryClient
@SpringBootApplication
public class AppStarter {
    
    public static void main(String[] args) {
        SpringApplication.run(AppStarter.class, args);
    }
    
    @Bean
    @LoadBalanced
    RestTemplate restTemplate() {
        return new RestTemplate();
    }
}

增加Controller

// Controller 控制器
@RestController
public class TestController {

    @Autowired
    private TestService service;
    
    @RequestMapping("execute")
    public String execute() {
        String message = service.execute();
        return message;
    }
}

// 服务接口类
public interface TestService {

    public String execute();

}

// 服务接口实现类
@Service
public class TestServiceImpl implements TestService {
    
    @Autowired
    RestTemplate template;

    @Override
    public String execute() {
        return template.getForObject("http://EUREKA-SERVER/hello?name='叶生'", String.class);
    }
}

6、测试

启动说明:

    a、启动服务注册中心,端口号:8000

    b、启动服务提供方,端口号:8001

    c、启动服务提供方,端口号:8002

    d、启动服务消费方,端口号:8004

访问:http://localhost:8000/  打开服务中心

访问:http://localhost:8004/execute

返回:你好,'叶生'

 

结束。

 

异常解析:

1、服务提供方只启动一次(这里只启动端口:8001的服务)

访问:http://localhost:8004/execute

服务消费方后台异常:java.lang.IllegalStateException: No instances available for EUREKA-SERVER

解决:

1、解决方案一:再启动一个服务提供方

2、解决方案二:

    a、取消服务消费方启动类中的“@LoadBalanced”注解(此为负载均衡注解,个人认为需要多个服务,具体待了解)

    b、修改请求服务提供方的地址为:

return template.getForObject("http://localhost:8001/hello?name='叶生'", String.class);

 

© 著作权归作者所有

共有 人打赏支持
上一篇: Java Linux 环境
下一篇: MQ 相关介绍
xiaoye08050141
粉丝 0
博文 29
码字总数 17546
作品 0
深圳
后端工程师
私信 提问
专访陈文辉:新技术很重要,但是首先要练好基本功

让我们把时间调回到2003年6月。那一年,承载着“传统J2EE寒冬之后的崭新起点”美好愿景的Spring项目开始立项,并以1.0版本进行推进。 时光荏苒,从Spring Framework 1.0发展到现在的Spring ...

异步社区
08/22
0
0
springmvc+mybatis学习笔记(汇总)

springmvc+mybatis学习笔记(汇总) 标签 : springmvc mybaits [TOC] 笔记分为两大部分:mybatis和springmvc mybatis springmvc 笔记内容主要是mybatis和springmvc的一些基本概念和使用方法,...

brianway
2016/03/30
1K
2
8月30日云栖精选夜读 | 谈谈“野生”Java程序员学习的道路!

一、引言 其实本来真的没打算写这篇文章,主要是LZ得记忆力不是很好,不像一些记忆力强的人,面试完以后,几乎能把自己和面试官的对话都给记下来。LZ自己当初面试完以后,除了记住一些聊过的...

yq传送门
08/30
0
0
springmvc学习笔记(6)-springmvc整合mybatis(IDEA中通过maven构建

springmvc学习笔记(6)-springmvc整合mybatis(IDEA中通过maven构建) 标签: springmvc mybatis [TOC] 本文主要展示如何在intellij IDEA中通过maven构建springmvc+mybatis框架的开发环境。 需求...

brianway
2016/03/10
432
0
Spring Boot 介绍说明---来源于网络,日常学习笔记

Spring Boot是Spring旗下众多的子项目之一,其理念是约定优于配置,它通过实现了自动配置(大多数用户平时习惯设置的配置作为默认配置)的功能来为用户快速构建出标准化的应用。Spring Boot...

舒文joven
08/28
0
0

没有更多内容

加载失败,请刷新页面

加载更多

CAS和AQS

CAS(Compare And Swap) 什么是CAS CAS(Compare And Swap),即比较并交换。是解决多线程并行情况下使用锁造成性能损耗的一种机制。 CAS是一种系统原语,原语属于操作系统用语范畴,是由若干条...

狼王黄师傅
30分钟前
2
0
Python利用pandas处理Excel数据的应用

Python利用pandas处理Excel数据的应用 最近迷上了高效处理数据的pandas,其实这个是用来做数据分析的,如果你是做大数据分析和测试的,那么这个是非常的有用的!!但是其实我们平时在做自动化...

上官夏洛特
44分钟前
2
0
100:代码管理平台svn

1:代码管理平台:代码版本管理工具,工作中用于代码更新,代码发布统计,代码版本控制;(频繁更新代码的版本记录),方便查阅历史变更,协同开发及合并; 版本管理工具发展: cvs(编码兼容不太好)...

芬野de博客
44分钟前
1
0
Linux学习-1101(rsync下、log、screen)

10.32/10.33 rsync通过服务同步 10.34 linux系统日志 10.35 screen工具 一、 rsync通过服务同步 rsync 通过服务的方式同步,首先需要开启一个服务。它是C/S架构,开启rsync服务,默认端口是8...

wxy丶
51分钟前
1
0
使用jpmml-sparkml-executable生成PMML模型文件

加载依赖的jar包通过./spark-shell --jars ./jpmml-sparkml-executable-1.2.13.jar 启动spark import org.apache.spark.ml.classification.LogisticRegressionimport org.apache.spark.m......

KYO4321
54分钟前
1
1

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部