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 协议 访问微服务本身,和注册中心没有关系,也观察不到集群的效果,接下来我们就会讲如何用微服务,访问另一个微服务。