美文网首页springcloud学习笔记
SpringCloud学习二: spring-cloud-con

SpringCloud学习二: spring-cloud-con

作者: Bertram_Wang | 来源:发表于2019-03-12 19:28 被阅读0次

首先我们所有的子工程项目都是使用SpringBoot做快速启动框架。所在直接在总工程pom.xml文件引入jar包即可。示例:

<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>com.study.springcloud</groupId>
<artifactId>spring-cloud-study</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<description>springcloud学习DEMO</description>
<modules>
    <module>study-1-spring-cloud-config</module>
</modules>
<properties>
    <!-- 字符编码 -->
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <!-- JDK版本 -->
    <java.version>1.8</java.version>
    <!-- maven打包插件-->
    <maven-jar-plugin.version>2.6</maven-jar-plugin.version>
</properties>

<!-- Inherit defaults from Spring Boot -->
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.5.RELEASE</version>
</parent>

<dependencies>
    <!-- 热部署 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <optional>true</optional>
    </dependency>

    <!-- 测试包,当我们使用 mvn package 的时候该包并不会被打入,因为它的生命周期只在 test 之内 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>

    <!-- 简化简单实体getter,setter -->
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <scope>provided</scope>
    </dependency>

</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugin</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>2.1</version>
            <configuration>
                <skip>true</skip>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-surefire-plugin</artifactId>
            <configuration>
                <skip>true</skip>
            </configuration>
        </plugin>
    </plugins>
</build>
</project>

使用的是springboot2.0.5.RELEASE版本。这样所有子项目不需要单独依赖了。
简单说明一下<artifactId>lombok</artifactId> 用于简化模板化代码的。例如:

package bertram.springcloud.study.test;

import org.junit.Test;

import lombok.Data;

/**
 * <p> <p>
 * @Author Bertram.Wang
 * @Date 2019年3月12日
 */
@Data
public class User {
    private Integer id;
    
    @Test
    public void test1() {
        User user = new User();
        user.setId(1);
        System.out.println(user.getId());
    }
}

没有看到申明方法:getId,setId;@Data相当于申明了这些模板方法;可以使用的。执行结果:1;具体请参考:https://projectlombok.org/;这里就不多说了。后面或许会再写一个使用方法。

再看看spring-cloud-config-server 服务搭建;在子项目中添加必要的依赖:pom.xml文件示例:

<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>
<parent>
  <groupId>com.study.springcloud</groupId>
  <artifactId>spring-cloud-study</artifactId>
  <version>0.0.1-SNAPSHOT</version>
</parent>
<artifactId>study-1-spring-cloud-config</artifactId>
<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-config-server</artifactId>
    </dependency>
</dependencies>

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

</project>

注意版本号的兼容性;<version>Finchley.SR2</version>

版本兼容
具体可以参考官网说明: https://spring.io/projects/spring-cloud

在创建配置文件:
spring.cloud.config.server.git.uri: git仓库链接
引用官方文档原文:
服务器可以使用@EnableConfigServer注释轻松嵌入到Spring Boot应用程序中。所以这个应用程序是一个配置服务器:
创建springboot启动类,添加注解 @EnableConfigServer即可。

git仓库文档结构

仓库文件

示例:

server:
  # 指定端口号
  port: 8888 
  servlet: 
    context-path: /config
---
spring:
  application:
    name: spring-cloud-config
  cloud: 
    config: 
     server: 
        git: 
          uri: https://git.coding.net/wangpp/fileManage.git
          # 指定目录
          search-paths: API

启动类 Application.java

package bertram.springcloud.study;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;

/**
 * <p>启动类<p>
 * @Author Bertram.Wang
 * @Date 2019年3月12日
 */
@SpringBootApplication
// 轻松实现配置服务器
@EnableConfigServer 
public class Application {

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

就是简单的启动类添加注解@EnableConfigServer;

启动访问链接:http://localhost:8888/config/app/dev/master
就是访问一下文件。
API
...app-dev.yml
{app}: 项目;
{dev}: 环境;
{master}: 主分支;

提示异常: 需要身份验证,但没有注册任何任凭。
org.eclipse.jgit.api.errors.TransportException: https://git.coding.net/wangpp/fileManage.git: Authentication is required but no CredentialsProvider has been registered

修改配置文件添加用户名和密码即可。

      uri: https://git.coding.net/wangpp/fileManage.git
      search-paths: API
      username: 18170146395@163.com
      password: XXXXXXXX

再次刷新页面:


image.png

下一节在项目中使用配置文件。

相关文章

网友评论

    本文标题:SpringCloud学习二: spring-cloud-con

    本文链接:https://www.haomeiwen.com/subject/xhjgpqtx.html