首页 > 其他分享 >使用dubbo 2.7 编写接口,使用jmeter调用

使用dubbo 2.7 编写接口,使用jmeter调用

时间:2023-05-02 11:55:46浏览次数:32  
标签:dubbo -- spring boot server org jmeter 2.7

创建spring-boot

winddows 安装 zookeeper3.4.14 并启动

父项目用的boot创建的时候添加web依赖,其他用的是maven

父项目pom
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <packaging>pom</packaging>
    <modules>
        <module>common-api</module>
        <module>server-provider</module>
        <module>server-consumer</module>
    </modules>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.12.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.cjl</groupId>
    <artifactId>08-dubbo-boot-parent</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>08-dubbo-boot-parent</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.7.8</version>
        </dependency>

    <!-- 注意包是com.alibaba.spring-->
    <dependency>
        <groupId>com.alibaba.spring</groupId>
        <artifactId>spring-context-support</artifactId>
        <version>1.0.5</version>
    </dependency>

    <dependency>
        <groupId>org.apache.dubbo</groupId>
        <artifactId>dubbo-spring-boot-starter</artifactId>
        <version>2.7.5</version>
        <exclusions>
            <exclusion>
                <artifactId>org.apache.dubbo</artifactId>
                <groupId>dubbo</groupId>
            </exclusion>
        </exclusions>
    </dependency>

        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-dependencies-zookeeper</artifactId>
            <version>2.7.4.1</version>
            <type>pom</type>
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

        <!--<dependency>-->
            <!--<groupId>com.alibaba.boot</groupId>-->
            <!--<artifactId>dubbo-spring-boot-starter</artifactId>-->
            <!--<version>0.2.0</version>-->
        <!--</dependency>-->
        <!-- zookeeper -->
        <!--<dependency>-->
            <!--<groupId>org.apache.zookeeper</groupId>-->
            <!--<artifactId>zookeeper</artifactId>-->
            <!--<version>3.4.8</version>-->
        <!--</dependency>-->
        <!--<dependency>-->
            <!--<groupId>com.101tec</groupId>-->
            <!--<artifactId>zkclient</artifactId>-->
            <!--<version>0.10</version>-->
        <!--</dependency>-->
    </dependencies>

</project>

`
commo-api
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>08-dubbo-boot-parent</artifactId>
        <groupId>com.cjl</groupId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.cjl</groupId>
    <artifactId>common-api</artifactId>
    <version>0.0.1-SNAPSHOT</version>


</project>
server-provider
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>com.cjl</groupId>
        <artifactId>08-dubbo-boot-parent</artifactId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>
    <groupId>com.cjl.dubbo</groupId>
    <artifactId>server-provider</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>server-provider</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>8</java.version>
    </properties>
    <dependencies>

        <dependency>
            <groupId>com.cjl</groupId>
            <artifactId>common-api</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>

            </plugin>
        </plugins>
    </build>

</project>

common 接口,实体类

server-provider

接口实现类

接口实现类

启动类

配置文件
server:
  port: 9001
dubbo:
  application:
    # 服务名称,保持唯一
    name: server-provider
    # zookeeper地址,用于向其注册服务
  registry:
    protocal: zookeeper
    address: zookeeper://127.0.0.1:2181
  protocol:
    name: dubbo
    port: 20882
  metadata-report:
    address: zookeeper://127.0.0.1:2181
  config-center:
    address: zookeeper://127.0.0.1:2181

运行启动类,看到这个就成了

使用父项目打包,把server-provider的jar包放到jmeter 的 lib/ext目录下
把jmeter的dubbo插件也放到 扩展目录下

启动jmeter

添加 dubbo取样器

  • 添加注册中心的类型、地址
  • 点击那个Get按钮从注册中心获取服务列表,填写接口入参

总结:主要是依赖难搞,百度了一大圈,dubbo 2.7 版本变化也大 。

jmeter调用的原理,相当于编写一个消费者,也可以用代码编写消费者,使用@RestController对外提供接口,jmeter就可以通过http调用消费者,达到调用dubbo接口的效果

标签:dubbo,--,spring,boot,server,org,jmeter,2.7
From: https://www.cnblogs.com/age28/p/17367506.html

相关文章

  • 性能_2 Jmeter脚本增强
    一、写脚本注意事项(回顾):协议:http,https必须写域名或ip:不能有/请求方法:看清楚接口文档路径:不要把域名和ip再次路径中,前后空格要看清楚%20空格的urlencoded编码内容编码:utf8请求体编码控制:内容编码消息头参数,勾选编码urlencoded响应乱码:......
  • springboot2.7.10集成swagger3.0 (springboot版本和swagger是有版本搭配的吗)
    springboot2.7.10集成swagger3.0https://blog.csdn.net/TuringZGJ/article/details/129832851  springboot版本和swagger是有版本搭配的吗 SpringbootSwagger各版本整理https://blog.csdn.net/m0_67401746/article/details/126506471 ......
  • 2023-4-30 #52.75 如果再次试着踏上 那条轨迹不可改变的结局
    Ptz2022SummerDay4IvanKazmenkoContest3B:若\(n\)为奇数,我们只需取补集;否则我们保留\(n\)是否存在,并将\(2\cdotsn\)取反(std做法:插入删除\(1\))。D:信息量只有\(2^{70}\)级别,将值域分为\(70\)块,每个块分别决定是否保留所有数,一个块期望会有比较多的数,被失真后仍......
  • 性能_1 Jmeter脚本编写
    一、万能法先把项目启动打开项目接口文档,接口文档:一般是开发特别注意事项:当你的接口请求参数为json格式时,一定要写请求头,请求头中一定要有Content-Type:application/json(响应体的格式)如果没有这个信息,100%报错,不局限于jmeterhttp请求包括哪些部分请求行:请求方法,请......
  • 【性能】JDK和Jmeter的安装与配置
    一、JDK环境配置1.下载JDK官网下载地址:http://www.oracle.com/technetwork/java/javase/downloads/java-archive-downloads-javase7-521261.html    选择对应系统的安装包,下载后安装,安装中记录JDK安装的地址,之后一直点击下一步到完成就可以。2.配置JDK环境 ......
  • Dubbo常见面试题
    关注Java后端技术栈“回复“面试”获取最新资料其实关于Dubbo的面试题,我觉得最好的文档应该还是官网,因为官网有中文版,照顾了很多阅读英文文档吃力的小伙伴。但是官网内容挺多的,于是这里就结合官网和平时面试被问的相对较多的题目整理了一下。1,说说一次Dubbo服务请求流程?基本工作流......
  • jmeter之 随机变量 组件
    随机变量界面详解添加随机变量组件的操作:选中“线程组”右键—>添加—>配置元件—>随机变量。随机变量界面如下:随机变量组件的详细说明:名称:随机变量组件的自定义名称,见名知意最好。注释:即添加一些备注信息,对该随机变量组件的简短说明,以便后期回顾时查看。变量名称(Varia......
  • Jmeter:图形界面压力测试工具
    Jmeter是一款强大的图形界面压力测试工具,完全用Java写成,关于Jmeter的介绍,网上其实有不少的文章,我原本是不想再重复写类似文章的,但我发现有些很关键性的,在我们测试中一定会用到的一些设置或操作很少见到有文章写清楚的,比如有这样的一个常见问题:如何对一个网站的多个链接进行压力测试......
  • jmeter参数化的6种方式
    1.用户自定义变量:添加“配置元件”->“用户定义的变量”。“名称”中输入变量名称,此处以登录为例,定义两个变量username和password。“值”中可以直接输入值,也可以通过Jmeter的函数__CSVRead,__StringFromFile从csv或dat文件中读取,还可以通过前缀加随机数的方法设置参数。 2.用......
  • jmeter使用教程
    基础配置1.设置jmeter页面为中文2.设置响应数据默认编码utf-83.扩展jar包存放位置常用工具前置工具常用函数计数${__counter(,)}随机数${__Random(1,10,)}随机字符串${__RandomString(1,abcde)}当前时间${__time(yyyy-MM-ddhh:mm:ss)}提取器json提取器正则......