Spring Cloud微服务连载(一):搭建服务注册中心以及注册服务提供者

10万+IT人都在关注的史上最全面的企业级微服务快速开发学习脚踩:5分钟快速搭建一个标准的Spring Cloud服务注册中心

前言:springcloud项目是基于springboot框架,我们演示的都创建springboot工程

一、创建一个普通的Spring Boot工程

首先我们通过spring官网创建一个普通的Spring Boot工程,官网地址 https://start.spring.io/ 如下图所示,springboot版本此处选择1.5.19(不太稳定),创建好工程下载下来导入到开发工具里,修改pom.xml文件里springboot的版本号为 1.5.6.RELEASE

添加Eureka依赖

工程创建成功并导入开发工具之后,修改工程名为chenyun-cloud-eureka 向该工程的pom.xml文件中添加eureka-server的依赖,目前eureka的稳定版本是Dalston.SR3,添加完依赖之后,pom.xml文件如下所示:

<?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.sang</groupId>
    <artifactId>eureka-server</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

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

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.6.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>
    </properties>

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

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-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>Dalston.SR3</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>

启动服务注册中心

启动服务注册中心的方式很简单,就是在Spring Cloud的入口类上添加一个@EnableEurekaServer注解,如下

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

 配置服务注册中心

最后我们再做一点简单的配置就可以了,配置就写在Spring Cloud的配置文件application.yml中,写法如下:

spring:
  application:
    name: eureka-center
server:
  port: 8880
eureka:
  instance:
    hostname: 10.220.146.3
  client:
    register-with-eureka: false
    fetch-registry: false
    service-url:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

配置说明:

1.server.port=8880 表示设置该服务注册中心的端口号
2.eureka.instance.hostname=10.220.146.3表示配置该服务注册中心的hostname
3.eureka.client.register-with-eureka=false,由于我们目前创建的应用是一个服务注册中心,而不是普通的应用,默认情况下,这个应用会向注册中心(也是它自己)注册它自己,设置为false表示禁止这种默认行为
4.eureka.client.fetch-registry=false,表示不去检索其他服务,因为服务注册中心本身的职责就是维护服务实例,它也不需要去检索其他服务

测试

现在我们就可以启动这个Spring Cloud服务,服务启动成功之后,在浏览器中输入:http://localhost:8880就能够看到如下页面

看到上面这个页面之后,表示服务注册中心已经搭建好了。现在服务注册中心有了之后,我们可以向这个服务注册中心注册一个服务提供者了。

我们用同样的方式创建一个spring boot 工程,命名为 chenyun-cloud-hello-service。现在我们添加一个Controller,在该Controller中提供一个访问入口,如下:

 

@RestController
public class HelloController {

    private final Logger logger = Logger.getLogger(HelloController.class);
	
    @Autowired
    private DiscoveryClient client;

    @RequestMapping(value = "/hello", method = RequestMethod.GET)
    @ResponseBody
    public String index() {
        List<ServiceInstance> instances = client.getInstances("HELLO-SERVICE");
        for (int i = 0; i < instances.size(); i++) {
            logger.info("/hello服务的host:" + instances.get(i).getHost() + ",service_id:" + instances.get(i).getServiceId());
        }
        return "Hello World";
    }
}

这里创建服务之后,在日志中将服务相关的信息就可以打印出来了

激活Eureka中的DiscoveryClient

在Spring Cloud的入口函数处,通过添加@EnableDiscoveryClient注解来激活Eureka中的DiscoveryClient实现(因为我们在HelloController中注入了DiscoveryClient)。

@EnableDiscoveryClient
@SpringBootApplication
public class ProviderApplication {

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

配置服务名称和注册中心地址

最后的最后,我们在application.yml文件中配置一下服务名和注册中心地址即可,如下:

spring:
  application:
    name: hello-service
server:
  port: 8881
eureka:
  instance:
    instance-id: ${spring.application.name}:${server.port}
    prefer-ip-address: true 
  client:
    service-url:
      defaultZone: http://10.220.146.3:8880/eureka/

测试

我们就可以测试了,直接运行这个Spring Cloud工程,运行成功之后,我们刷新刚才的http://localhost:8880,就可以看到有一个服务已经注册成功了。如下:

更多JavaEE资料请关注下面公众号,欢迎广大开发者朋友一起交流。笔者电话(微信):18629374628 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章