首页 > 其他分享 >dubbo+zookeeper+springboot远程连接,虚拟机和主机分布式操作

dubbo+zookeeper+springboot远程连接,虚拟机和主机分布式操作

时间:2022-11-10 19:24:12浏览次数:38  
标签:dubbo springboot 虚拟机 zookeeper server org public

dubbo+zookeeper+springboot远程连接,虚拟机和主机分布式操作

springboot版本:阿里云2.3.7

实现目标

在主机上的消费者可以调用虚拟机中生产者的接口方法

项目目录

image-20221110184358403

pom.xml

<dependencies>
        <!-- https://mvnrepository.com/artifact/org.apache.dubbo/dubbo-spring-boot-starter -->
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>2.7.18</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
        <dependency>
            <groupId>com.github.sgroschupf</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.1</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.curator/curator-recipes -->
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-recipes</artifactId>
            <version>5.1.0</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.zookeeper/zookeeper -->
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.6.2</version>
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>


        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

生产者

生产者部署在服务器端/ubuntu20.04虚拟机

虚拟机开放2181端口与21880端口

sudo iptables -I INPUT -p tcp --dport 21880 -j ACCEPT
sudo iptables -I INPUT -p tcp --dport 2181 -j ACCEPT

官网下载zookeeper的压缩包,压缩包名字中要带bin,如apache-zookeeper-3.7.1-bin.tar.gz。

解压文件,进入apache-zookeeper-3.7.1-bin\conf,

在当前目录复制一个zoo_sample.cfg,并重命名为zoo.cfg。

进入apache-zookeeper-3.7.1-bin\bin目录,

运行zookeeper服务

image-20221110190304916

appliacation.yml

# 应用名称
spring.application.name=provider-server
# 应用服务 WEB 访问端口
server.port=8281


# 注册 服务应用/ 中心 的地址
dubbo.application.name=provider-server
# 服务应用的名称
dubbo.registry.address=zookeeper://192.168.241.128:2181

# 哪些包要被注册
dubbo.scan.base-packages=com.jupiter.service

dubbo.protocol.port=21880

service

TicketService接口

public interface TicketService {
    public String getTicket();
}

实现类

@DubboService(interfaceName = "com.jupiter.service.TicketService")//项目 一启动项目就注册到注册中心
@Component
public class TicketServiceImpl implements TicketService , Serializable {
    @Override
    public String getTicket() {
        return   "获得一张票"+ ", 消费者的请求: " + RpcContext.getContext().getRemoteAddress();
    }
}

在目录

.......\provider-server路径下打开cmd使用mvn进行打包

mvn clean package

image-20221110185813319

打包成功在文件路径下会出现一个target文件夹,

将其复制到虚拟机

进入虚拟机的target文件夹image-20221110185955844

在当前目录打开terminal,输入以及命令运行jar包,打开了生产者的服务

java -jar provider-server-0.0.1-SNAPSHOT.jar

消费者

消费者部署在主机端

application.yml

# 应用名称
spring.application.name=consumer-server
# 应用服务 WEB 访问端口
server.port=8182


# 消费者去哪里拿,需要暴露自己的名字
dubbo.application.name=consumer-server
# 注册中心的地址
dubbo.registry.address=zookeeper://192.168.241.128:2181
dubbo.protocol.port=21880
dubbo.consumer.check=false




application.properties

dubbo:
  registry:
    timeout: 200000
  service:
    timeout: 200000
  consumer:
    timeout: 200000
  provider:
    timeout: 200000

service

TicketService接口

如果要使@Reference注解生效,就需要有与被引用包的相同目录与接口

public interface TicketService {
    public String getTicket();
}

消费方法

@Service
public class UserService {

    //想拿到provider提供的票 要去注册中心拿到
    @DubboReference(url = "dubbo://192.168.241.128:21880/")//引用,Pom坐标,路径相同的接口命
    TicketService ticketService;

    public String buyTicket(){
        String ticket = ticketService.getTicket();
        System.out.println("在注册中心获取==>"+ticket);
        return ticket;
    }

}

测试

@SpringBootTest
class ConsumerServerApplicationTests {
    @Autowired
    UserService userService;
    @Test
    void contextLoads() {
        userService.buyTicket();
    }



}

运行测试方法

运行结果

image-20221110185431830

标签:dubbo,springboot,虚拟机,zookeeper,server,org,public
From: https://www.cnblogs.com/AlwaysSui/p/16878101.html

相关文章

  • springboot整合项目-商城项目订单系统以及aop监测
    订单系统1.持久层1.将数据插入到订单表中insertintot_order(oid除外所有的字段)values(字段的值)2.将数据还要插入订单项的表中insertintot_order_item(oid除......
  • SpringBoot 整合mybatis-plus
    SpringBoot整合mybatis-plus1、导入Maven依赖<dependencies><!--web依赖--><dependency><groupId>org.springframework.boot</groupId>......
  • SpringBoot启用Https(二十六)
    死亡的日子终究会到来,在那一天到来之前,别忘记,来我坟前再看一眼上一章简单介绍了SpringBoot自定义日志Starter(二十五),如果没有看过,​​请观看上一章​​关于这一章节的内......
  • SpringBoot整合Redis(十九)
    二八佳人体似酥,腰间仗剑斩愚夫。虽然不见人头落,暗里教君骨髓枯。上一章简单介绍了多数据源配置MyBatisPlus(十八),如果没有看过,​​请观看上一章​​一.Redis的介绍和安装......
  • SpringBoot整合Velocity(十二)
    二八佳人体似酥,腰间仗剑斩愚夫。虽然不见人头落,暗里教君骨髓枯。上一章简单介绍了SpringBoot整合FreeMarker(十一),如果没有看过,​​请观看上一章​​学习整合之前,可以看一......
  • SpringBoot通过Cors解决跨域问题(三十一)
    上一章简单介绍了SpringBoot全局异常处理(三十),如果没有看过,​​请观看上一章​​本章节参考江南一点雨大神的文章:​​SpringBoot2系列教程(十四)CORS解决跨域问题......
  • SpringBoot自定义Starter(二十四)
    即使有一天,我放弃了自己的身体,也请你,不要放弃我,我亲爱的灵魂.上一章简单介绍了Spring_Session解决Session共享的问题(二十三),如果没有看过,​​请观看上一章​​一.自定义......
  • SpringBoot上传和下载文件(二十七)
    当死亡来临,每一个人都不会接受自己的命运,他们会反抗.上一章简单介绍了SpringBoot启用Https(二十六),如果没有看过,​​请观看上一章​​文件上传和下载,是常用的功能可以看老......
  • SpringBoot全局异常处理(三十)
    生活打了我们一巴掌,我们,一定要想办法再打回来上一章简单介绍了SpringBoot上传文件到远程服务器(二十九),如果没有看过,​​请观看上一章​​一.为什么要实现异常信息自定义......
  • SpringBoot自定义日志Starter(二十五)
    即使有一天,我放弃了自己的身体,也请你,不要放弃我,我亲爱的灵魂.上一章简单介绍了SpringBoot自定义Starter(二十四),如果没有看过,​​请观看上一章​​一.AOP实现日志功能......