EurekaServer ,它扮演的角色是注册中心,用于注册各种微服务,以便于其他微服务找到和访问。有了EurekaServer,还需要一些微服务,注册到EurekaServer上去。
这一节,我们来写一个注册微服务。为了简单起见,我们不用数据库,用java来模拟即可。
创建一个订单模块
模块名是oms,是Order Manage Service的缩写,为什么简写呢,因为我要装杯。
pom.xml 添加依赖:
org.springframework.cloud spring-cloud-starter-netflix-eureka-client org.springframework.boot spring-boot-starter-web
spring-cloud-starter-netflix-eureka-client
表示这是个 eureka 客户端。
spring-boot-starter-web
表示这是个web服务,会提供控制层,因为我们要提供访问接口,所以要加web。
Order实体类
这是订单的实体类,为了方便起见,我们要加上lombok。
在parent工程的pom里面加上lombok
依赖配置
org.projectlombok lombok compile
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 queryOrders();
}
再来个实现类
@Service
public class OrderServiceImpl implements OrderService {@Overridepublic List queryOrders() {List 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 {@Autowiredprivate OrderService orderService;@Value("${server.port}")String port;@GetMapping("/order/list")public List 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 协议 访问微服务本身,和注册中心没有关系,也观察不到集群的效果,接下来我们就会讲如何用微服务,访问另一个微服务。
下一篇:字体设置。