微服务实战03-注册数据服务

EurekaServer ,它扮演的角色是注册中心,用于注册各种微服务,以便于其他微服务找到和访问。有了EurekaServer,还需要一些微服务,注册到EurekaServer上去。

这一节,我们来写一个注册微服务。为了简单起见,我们不用数据库,用java来模拟即可。

1.订单模块

创建一个订单模块

模块名是oms,是Order Manage Service的缩写,为什么简写呢,因为我要装杯。

pom.xml 添加依赖:

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

spring-cloud-starter-netflix-eureka-client 表示这是个 eureka 客户端。

spring-boot-starter-web 表示这是个web服务,会提供控制层,因为我们要提供访问接口,所以要加web。

Order实体类

这是订单的实体类,为了方便起见,我们要加上lombok。

在parent工程的pom里面加上lombok

依赖配置

<!-- lombok -->
<dependency>
  <groupId>org.projectlombok</groupId>
  <artifactId>lombok</artifactId>
  <scope>compile</scope>
</dependency>

dto文件在这

代码:

@Data
public class Order {
   private Integer orderId;   //订单号
   private String productName;  //货品名称
   private Integer quantity;  //数量
}

eclipse还需要安装lombok插件才行,光有jar包还不够,如果搞不定就老老实实生成get/set方法吧,这个没关系。

Order服务类

public interface OrderService {
   public List<Order> queryOrders();
}

再来个实现类

@Service
public class OrderServiceImpl implements OrderService {

 @Override
 public List<Order> queryOrders() {
  List<Order> list = new ArrayList<>();
  Order o1 = new Order();
  o1.setOrderId(1);
  o1.setProductName("GBA");
  o1.setQuantity(10);
  
  Order o2 = new Order();
  o2.setOrderId(2);
  o2.setProductName("NDS");
  o2.setQuantity(10);
  
  list.add(o1);
  list.add(o2);
  
  return list;
 }

}

Order控制层

@RestController
public class OrderController {
 
    @Autowired
    private OrderService orderService;

    @Value("${server.port}")
   String port;

    @GetMapping("/order/list")
    public List<Order> queryOrders(){
      System.out.println("------------" + port);
      return orderService.queryOrders();
    }

}

引入端口,方便观察后面集群访问。

启动类

代码:

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

application.yml配置

spring:
  application:
    name: order-data-service
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8081/eureka/

order-data-service代表这是一个订单数据服务,给其他系统提供订单数据用的。 defaultZone用来设置注册中心的地址,跟eureka-server中的defaultZone是一样的。

现在我们启动两个数据服务。

选择oms,启动类也要选对

手动填写启动端口

注意,server.port左边有个--,一定要加。

启动完毕后,再去看eureka服务:

就显示这个服务了。

再用同样的办法,在8083端口起一个订单服务。

得到这样的变化。

访问者两个地址:http://localhost:8082/order/list和http://localhost:8083/order/list,观察后台的日志可以看到都能正常访问的。但是这种方式是通过 http 协议 访问微服务本身,和注册中心没有关系,也观察不到集群的效果,接下来我们就会讲如何用微服务,访问另一个微服务。

猜你喜欢

转载自blog.csdn.net/weixin_39570751/article/details/129526259