中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

dubbo與zookeeper怎么在springboot中使用

發布時間:2021-03-23 15:18:50 來源:億速云 閱讀:165 作者:Leah 欄目:編程語言

今天就跟大家聊聊有關dubbo與zookeeper怎么在springboot中使用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

創建服務接口模塊

接口工程只提供接口,不提供實現,在后面的提供者和消費者中使用

在使用接口的模塊中只需要寫具體實現類,避免了在每個模塊中重復編寫接口

在接口中引入依賴包

<dependency>
      <groupId>org.projectlombok</groupId>
      <artifactId>lombok</artifactId>
      <optional>true</optional>
    </dependency>

創建一個實體類,一定要實現Serializable接口,否則dubbo協議之間無法傳輸

@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

@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相關補充

dubbo使用本地緩存方式,如果注冊中心全部宕機,dubbo也能正常工作,就算沒有注冊中心,dubbo也能通過dubbo直連通信

//使用dubbo提供的@Reference訪問遠程服務
  //version對應服務提供者的version
  //url:如果沒有注冊中心,可以通過url配置服務提供者的dubbo協議端口,進行dubbo直連
  @Reference(version = "3",url ="127.0.0.1:20880" )
  private UserService userService;

看完上述內容,你們對dubbo與zookeeper怎么在springboot中使用有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

甘谷县| 阳山县| 平邑县| 曲水县| 伊春市| 龙井市| 寿光市| 达拉特旗| 九江市| 龙江县| 黄大仙区| 呼伦贝尔市| 囊谦县| 洮南市| 雷山县| 教育| 武平县| 广宁县| 垫江县| 镇坪县| 交城县| 保德县| 峨山| 育儿| 略阳县| 太白县| 海口市| 溆浦县| 建始县| 宁武县| 鄯善县| 玉林市| 康平县| 米林县| 无为县| 乐亭县| 噶尔县| 海城市| 罗平县| 朔州市| 鄱阳县|