首页 > 其他分享 >SpringCloud 学习笔记

SpringCloud 学习笔记

时间:2022-10-21 13:12:50浏览次数:38  
标签:http SpringCloud boot 笔记 eureka 学习 spring org server

一、搭建微服务环境

  1. 创建父模块(SpringCloud_demo)

    1.1 导入坐标 

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-logging</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.4</version>
        <scope>provided</scope>
    </dependency>
</dependencies>


<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>Greenwich.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

<repositories>
    <repository>
        <id>spring-snapshots</id>
        <name>Spring Snapshots</name>
        <url>http://repo.spring.io/libs-snapshot-local</url>
        <snapshots>
            <enabled>true</enabled>
        </snapshots>
    </repository>
    <repository>
        <id>spring-milestones</id>
        <name>Spring Milestones</name>
        <url>http://repo.spring.io/libs-milestone-local</url>
        <snapshots>
            <enabled>false</enabled>
        </snapshots>
    </repository>
    <repository>
        <id>spring-releases</id>
        <name>Spring Releases</name>
        <url>http://repo.spring.io/libs-release-local</url>
        <snapshots>
            <enabled>false</enabled>
        </snapshots>
    </repository>
</repositories>
<pluginRepositories>
    <pluginRepository>
        <id>spring-snapshots</id>
        <name>Spring Snapshots</name>
        <url>http://repo.spring.io/libs-snapshot-local</url>
        <snapshots>
            <enabled>true</enabled>
        </snapshots>
    </pluginRepository>
    <pluginRepository>
        <id>spring-milestones</id>
        <name>Spring Milestones</name>
        <url>http://repo.spring.io/libs-milestone-local</url>
        <snapshots>
            <enabled>false</enabled>
        </snapshots>
    </pluginRepository>
</pluginRepositories>
<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

  2. 创建子模块(product_server,order_server)

    2.1 引入子模块坐标

<dependencies>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.32</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>

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

    2.2 编写子模块application.yml 配置文件

server:
  port: 9001
spring:
  application:
    name: service-product
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/netdisk?useUnicode=true&characterEncoding=utf8
    username: root
    password:
  jpa:
    database: MySQL
    show-sql: true
    open-in-view: true

    2.3 编写子模块启动类

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

  3. 创建子模块注册机(eureka_server)

    3.1 导入坐标

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

    3.2  编写application.yml

server:
  port: 9000
# 配置 eureka server
eureka:
  instance:
    hostname: localhost
  client:
    register-with-eureka: false # 是否将自己注册到注册中心
    fetch-registry: false # 是否要从eureka中获取信息
    # 配置暴露给Eureka Client的请求地址
    service-url:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

    3.3 编写启动类

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

   4.  将服务提供者注册到eureka_server上

    4.1 导入坐标

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

    4.2 application.yml中添加Eureka的配置

# 配置 Eureka
eureka:
  client:
    service-url:
      defaultZone: http://localhost:9000/eureka/
      instance:
        prefer-ip-address: true # 使用ip地址注册

    4.3 启动类添加注解@EnableDiscoveryClient(可选)

@SpringBootApplication
@EntityScan("com/gfy/eureka/entity")
@EnableDiscoveryClient
public class ProductApplication {
    public static void main(String[] args) {
        SpringApplication.run(ProductApplication.class, args);
    }
}

  5. 服务调用者

    5.1 编写启动类

@RestController
@RequestMapping("order")
public class OrderController {

    @Autowired
    private RestTemplate restTemplate;

    @GetMapping("{id}")
    public Product findById(@PathVariable Long id){
        Product product = restTemplate.getForObject("http://localhost:9001/product/1", Product.class);
        return product;
    }
}

    5.2 编写服务调用者(order_server) 的controller 

@Autowired
private RestTemplate restTemplate;
@Autowired
private DiscoveryClient discoveryClient;

@GetMapping("{id}")
public Product findById(@PathVariable Long id){
    List<ServiceInstance> instances = discoveryClient.getInstances("service-product");
    ServiceInstance serviceInstance = instances.get(0);
    Product product = restTemplate.getForObject("http://"+serviceInstance.getHost()+":"+ serviceInstance.getPort() +"/product/1", Product.class);
    return product;
}

 

===============================================

Eureka细节

在Eureka控制台显示服务IP

# 配置 Eureka
eureka:
  client:
    service-url:
      defaultZone: http://localhost:9000/eureka/
      instance:
        prefer-ip-address: true # 使用ip地址注册
        instance-ip: ${spring.cloud.client.ip-address}:${server.port}  #向注册中心中注入服务IP

Eureka 自我保护机制

统计所有服务接收率,若在阈值以下,则不会剔除注册的服务

server:
  enable-self-preservation: false # 自我保护
  eviction-interval-timer-in-ms: 4000 # 剔除服务间隔

 

 

标签:http,SpringCloud,boot,笔记,eureka,学习,spring,org,server
From: https://www.cnblogs.com/Fei-Gao/p/16811042.html

相关文章

  • 一次 JMeter 脚本请求错误 Could not read JSON: Unexpected character : expected a
        用Badboy录制的脚本,有个界面是Ajax提交表单,先有HTTPStatus415错误(解决方案参考《​​一次JMeter脚本请求错误HTTPStatus41......
  • 有哪些好用的深度学习的GPU云服务器平台?
    ​​​​简单来说,如果你是长期使用GPU服务器,建议选择带显卡的硬件服务器,综合性能也比较好。如果是用来进行短周期或者临时使用,建议租用云服务器,既方便又快捷,可按需购买,可以......
  • 有哪些好用的深度学习的GPU云服务器平台?
    ​​​​简单来说,如果你是长期使用GPU服务器,建议选择带显卡的硬件服务器,综合性能也比较好。如果是用来进行短周期或者临时使用,建议租用云服务器,既方便又快捷,可按需购买,可以......
  • 一次 Oracle 服务 TNS-12535 故障解决笔记
      一次Oracle服务TNS-12535故障解决笔记    说来有些惭愧,貌似很简单的一个问题:防火墙隔离端口。但是着实浪费了笔者一些时间。笔者把问题解决过程记录下来,只为了......
  • 某次 oracle 连接超时故障,使用 df 命令快速定位问题的笔记
    oracle忽然假死,所有连接都超时。df一下数据区满了:99%。清理数据/扩充,再df:重启服务,问题解决。......
  • 主流监控系统 Prometheus 学习指南
    Prometheus是一个开源的完整监控解决方案,本文将从指标抓取到查询及可视化展示,以及最后的监控告警,对Prometheus做一个基本的认识。Prometheus是一个数据监控的解决方案,......
  • 运营笔记
     发布时段:【职场类】早晨7-8点,视频类的更容易点开,如果没引起情绪波动,一般难有互动中午12-2点,x晚上6点x晚上9点后,会稍稍好一点下午5点-5点半,不错 周五下午1点-4......
  • 脚本语言学习
    脚本语言学习一、前言:越来越懒了通过一条条指令完成重复复杂的操作查看打印的执行日志内容成功 ok /失败 解决问题持续跟新,先写着 二、语言类别1、groovy学......
  • 第八周学习笔记
    第5章定时器及时钟服务硬件定时器定时器是由时钟源和可编程计数器组成的硬件设备。时钟源通常是一个晶体振荡器,会产生周期性电信号,以精确的频率驱动计数器。使用一个......
  • 【Axure】学习链接
     一、Axure视频教程,0基础入门,2小时学会(推荐,适合初学者了解)(1)学习链接(2)推荐原因:观看人数多,且讲解仔细,特别适合刚入门的人员进行原型,本人也是从这个视频入口开始学......