2019年11月17日 yls
サービス・インターフェース・モジュールを作成します。
インタフェース工学は、プロバイダーと消費者の背中を使用し、唯一のインタフェースは実装を提供していない提供
だけで、各モジュールのインターフェイスへの書き込みの重複を避けるために、インタフェースの特定の実装クラスモジュールを記述する必要があります
インターフェースに依存関係を紹介
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency>
Serializableインタフェースを実装しなければならない、またはダボとの間の合意を転送することはできませんエンティティクラスを作成します。
@Data @AllArgsConstructor public class User implements Serializable { private String name; }
インタフェースの作成
public interface UserService { List<User> getAll(); List<User> getAll2(); }
サービスプロバイダを作成します。
依存性の導入
<!--引入创建的接口服务--> <dependency> <groupId>com.yls</groupId> <artifactId>common-api</artifactId> <version>1.0-SNAPSHOT</version> </dependency> <!--由于服务提供者不是web项目 ,只需引入spring-boot-starter,不用引入spring-boot-starter-web--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <!--dubbo--> <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>0.2.0</version> </dependency>
設定ファイルを変更します。
#服务名称 dubbo.application.name=provider1 #注册中心地址 dubbo.registry.address=39.97.234.52:2181,39.97.234.52:2182,39.97.234.52:2183 #注册中心类型 dubbo.registry.protocol=zookeeper #版本号 dubbo.application.version=3 # Dubbo Protocol #协议名称 dubbo.protocol.name=dubbo #服务暴露端口 dubbo.protocol.port=20880
実装するサービス・インターフェース
//暴露服务 //这里的@Service是Dubbo提供的,不是spring中的 //version必填 @Service(version = "${dubbo.application.version}") @Component public class UserImpl implements UserService { @Override public List<User> getAll() { User user1 = new User("张三"); User user2 = new User("lisi"); List<User> list = Arrays.asList(user1, user2); return list; } }
サービス開始
//@EnableDubbo等价于在配置文件中配置dubbo.scan.base-packages //扫描实现类所在的包,注册Bean @EnableDubbo @SpringBootApplication public class ProviderApplication { public static void main(String[] args) { SpringApplication.run(ProviderApplication.class,args); } }
消費者の作成
依存性の導入
<!--消费者是web项目--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--dubbo--> <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>0.2.0</version> </dependency> <!--引入创建的接口服务--> <dependency> <groupId>com.yls</groupId> <artifactId>common-api</artifactId> <version>1.0-SNAPSHOT</version> </dependency>
設定ファイルを変更します。
#注册中心 dubbo.registry.address=39.97.234.52:2181,39.97.234.52:2182,39.97.234.52:2183 dubbo.registry.protocol=zookeeper #dubbo应用名称 dubbo.application.name=consumer1
消費者インタフェースを実装
//服务消费者的Service是spring的 @Service public class OrderImpl implements OrderService { //使用dubbo提供的@Reference访问远程服务 //version对应服务提供者的version @Reference(version = "3") private UserService userService; @Override public List<User> init() { List<User> list = userService.getAll(); list.forEach(item -> System.out.println(item.getName())); return list; } }
コントローラを作成します。
@Controller public class OrderController { @Autowired private OrderService orderService; @ResponseBody @RequestMapping("/init") public List<User> init() { return orderService.init(); } }
スタートサービスコンシューマ
@EnableDubbo @SpringBootApplication public class ConsumerApplication { public static void main(String[] args) { SpringApplication.run(ConsumerApplication.class, args); } }
関連サプリメントダボ
登録センターすべてのダウンは、ダボが働くことができればダボには、レジストリ、ダボが直接通信ダボからも存在しない場合でも、ローカル・キャッシュ・モードを使用します
//使用dubbo提供的@Reference访问远程服务 //version对应服务提供者的version //url:如果没有注册中心,可以通过url配置服务提供者的dubbo协议端口,进行dubbo直连 @Reference(version = "3",url ="127.0.0.1:20880" ) private UserService userService;