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