Jmeter中的前置处理器(一)

 前置处理器

353d01fabe76421da9f3182966b67e39.png

1--JSR223 PreProcessor

功能特点

  • 自定义数据处理:使用脚本语言处理请求数据,实现高度定制化的数据处理和生成。
  • 动态数据生成:在请求发送前生成动态数据,如随机数、时间戳等。
  • 变量设置:设置和修改 JMeter 变量,以便在后续请求中使用。
  • 逻辑控制:根据特定条件控制请求的执行流程。

支持的脚本语言

  • Groovy:推荐使用,性能优越且功能强大。
  • JavaScript:支持 ECMAScript 标准。
  • BeanShell:支持 Java 语法。
  • 其他语言:支持任何符合 JSR223 规范的脚本语言。

配置步骤

  1. 添加 JSR223 PreProcessor

    • 右键点击需要处理的请求(HTTP请求或其他取样器)。
    • 选择“添加” -> “预处理器” -> “JSR223 PreProcessor”。
  2. 配置 JSR223 PreProcessor

    • 名称:给 JSR223 PreProcessor 一个有意义的名称。
    • 脚本语言:选择使用的脚本语言(例如 Groovy)。
    • 脚本文件:选择脚本文件路径(可选,如果脚本较长或需要版本控制)。
    • 脚本:直接在脚本编辑框中编写脚本。
    • 参数:定义脚本中使用的参数(可选)。

示例配置

假设我们需要在发送请求之前生成一个随机数,并将其作为请求参数传递。

  1. 创建测试计划

    • 右键点击“测试计划” -> 新建 -> 输入测试计划名称(例如“Web应用性能测试”)。
  2. 添加线程组

    • 右键点击测试计划 -> 添加 -> 线程组 -> 输入线程组名称(例如“用户模拟”)。
  3. 添加HTTP请求

    • 右键点击线程组 -> 添加 -> 取样器 -> HTTP请求。
    • 配置HTTP请求:
      • 名称:请求名称(例如“获取用户列表”)。
      • 服务器名称或IP:目标服务器的地址(例如example.com)。
      • 端口号:目标服务器的端口(例如80)。
      • 协议:HTTP或HTTPS(例如HTTP)。
      • 方法:请求的方法(例如GET)。
      • 路径:请求的路径(例如/api/users)。
  4. 添加 JSR223 PreProcessor

    • 右键点击HTTP请求 -> 添加 -> 预处理器 -> JSR223 PreProcessor。
    • 配置 JSR223 PreProcessor:
      • 名称:生成随机数
      • 脚本语言:Groovy
      • 脚本:在脚本编辑框中编写以下 Groovy 脚本:
         
        import java.util.Random
        
        // 生成一个随机数
        Random random = new Random()
        int randomNumber = random.nextInt(1000)
        
        // 将随机数设置为 JMeter 变量
        vars.put("randomNumber", randomNumber.toString())
        
        // 打印随机数到 JMeter 日志
        log.info("Generated random number: " + randomNumber)
  5. 使用生成的随机数

    • 返回到HTTP请求配置,添加生成的随机数作为请求参数。
    • 在“参数”部分添加:
      • 名称:random
      • ${randomNumber}
  6. 运行测试

    • 点击工具栏上的“启动”按钮,运行测试。
  7. 查看日志

    • 查看 JMeter 日志文件(通常位于 JMeter 安装目录的 jmeter.log 文件中),确认随机数已成功生成并打印。

优化建议

  1. 脚本语言选择

    • 推荐使用 Groovy,因为它性能优越且功能强大,是 JMeter 官方推荐的脚本语言。
  2. 脚本文件

    • 如果脚本较长或需要版本控制,可以将脚本保存到文件中,并在 JSR223 PreProcessor 中选择脚本文件路径。
  3. 参数

    • 如果脚本需要使用外部参数,可以在“参数”部分定义参数,并在脚本中引用这些参数。
  4. 性能影响

    • 注意复杂脚本可能会对测试性能产生影响,特别是在大规模性能测试中。可以通过优化脚本和减少不必要的操作来提高性能。
  5. 错误处理

    • 在脚本中添加适当的错误处理逻辑,确保脚本在遇到异常时能够优雅地处理。
  6. 日志记录

    • 使用日志记录功能可以帮助调试和分析脚本执行情况,确保日志文件路径有效且有足够的写权限。

 

4448524e70b14ffda2e5a172bcb53466.png


2--用户参数

功能特点

  • 动态参数设置:为不同的虚拟用户设置不同的参数值。
  • 灵活管理:可以方便地管理和修改参数值。
  • 适用于多用户测试:特别适合需要模拟多个用户的不同行为的测试场景。

配置步骤

  1. 添加用户参数预处理器

    • 右键点击需要添加预处理器的请求或线程组。
    • 选择“添加” -> “预处理器” -> “用户参数”(User Parameters)。
  2. 配置用户参数预处理器

    • 名称:给用户参数预处理器一个有意义的名称。
    • 参数名称:设置参数的名称。
    • 参数值:为每个虚拟用户设置参数值。
    • 线程号:指定参数值对应的虚拟用户编号。

参数说明

  • 参数名称:设置参数的名称,可以在后续的请求中引用这些参数。
  • 参数值:为每个虚拟用户设置参数值,每个虚拟用户对应一行。
  • 线程号:指定参数值对应的虚拟用户编号。线程号从1开始,对应线程组中的每个虚拟用户。

示例配置

假设我们需要测试一个Web应用,并为每个虚拟用户设置不同的用户名和密码。

  1. 创建测试计划

    • 右键点击“测试计划” -> 新建 -> 输入测试计划名称(例如“Web应用性能测试”)。
  2. 添加线程组

    • 右键点击测试计划 -> 添加 -> 线程组 -> 输入线程组名称(例如“用户模拟”)。
    • 配置线程组:
      • 线程数:3(模拟3个用户)
      • 循环次数:1(每个用户发送1次请求)
      • 启动延迟:0(立即启动)
  3. 添加用户参数预处理器

    • 右键点击线程组 -> 添加 -> 预处理器 -> 用户参数。
    • 配置用户参数预处理器:
      • 名称:用户参数
      • 参数名称
        • 用户名:username
        • 密码:password
      • 参数值
        • 用户名
          • 线程1:user1
          • 线程2:user2
          • 线程3:user3
        • 密码
          • 线程1:pass1
          • 线程2:pass2
          • 线程3:pass3
  4. 添加HTTP请求

    • 右键点击线程组 -> 添加 -> 取样器 -> HTTP请求。
    • 配置HTTP请求:
      • 名称:登录请求
      • 服务器名称或IP:目标服务器的地址(例如example.com)。
      • 端口号:目标服务器的端口(例如80)。
      • 协议:HTTP或HTTPS(例如HTTP)。
      • 方法:POST
      • 路径:请求的路径(例如/login)。
      • 参数
        • 名称:username
        • :${username}
        • 名称:password
        • :${password}
  5. 运行测试

    • 点击工具栏上的“启动”按钮,运行测试。

优化建议

  1. 参数命名

    • 确保参数名称有意义且易于理解,便于在后续请求中引用。
  2. 参数值管理

    • 如果参数值较多或需要频繁修改,可以考虑将参数值存储在外部文件中,并在测试计划中引用这些文件。
  3. 多参数场景

    • 如果有多个参数需要设置,可以在用户参数预处理器中添加多个参数名称和对应的参数值。
  4. 组合使用

    • 用户参数预处理器可以与其他预处理器(如JSR223预处理器)和定时器组合使用,以实现更复杂的测试逻辑。

示例配置详细说明

假设我们有一个简单的测试计划,包含一个线程组和一个HTTP请求,并希望为每个虚拟用户设置不同的用户名和密码。

  1. 创建测试计划

    • 右键点击“测试计划” -> 新建 -> 输入测试计划名称(例如“Web应用性能测试”)。
  2. 添加线程组

    • 右键点击测试计划 -> 添加 -> 线程组 -> 输入线程组名称(例如“用户模拟”)。
    • 配置线程组:
      • 线程数:3(模拟3个用户)
      • 循环次数:1(每个用户发送1次请求)
      • 启动延迟:0(立即启动)
  3. 添加用户参数预处理器

    • 右键点击线程组 -> 添加 -> 预处理器 -> 用户参数。
    • 配置用户参数预处理器:
      • 名称:用户参数
      • 参数名称
        • 用户名:username
        • 密码:password
      • 参数值
        • 用户名
          • 线程1:user1
          • 线程2:user2
          • 线程3:user3
        • 密码
          • 线程1:pass1
          • 线程2:pass2
          • 线程3:pass3
  4. 添加HTTP请求

    • 右键点击线程组 -> 添加 -> 取样器 -> HTTP请求。
    • 配置HTTP请求:
      • 名称:登录请求
      • 服务器名称或IP:example.com
      • 端口号:80
      • 协议:HTTP
      • 方法:POST
      • 路径:/login
      • 参数
        • 名称:username
        • :${username}
        • 名称:password
        • :${password}
  5. 运行测试

    • 点击工具栏上的“启动”按钮,运行测试。

 

2d813526261f4f68b165941f99d39501.png


3--HTML链接解析器

功能特点

  • 自动提取链接:从HTML响应中自动提取链接。
  • 动态参数传递:将提取的链接作为参数传递给后续的请求。
  • 支持多种链接类型:支持提取各种类型的链接,包括URL、图像、CSS文件等。
  • 适用于自动化测试:特别适合需要自动化测试页面中所有链接的场景。

配置步骤

  1. 添加HTML链接解析器

    • 右键点击需要添加预处理器的请求或线程组。
    • 选择“添加” -> “预处理器” -> “HTML 链接解析器”(HTML Link Parser)。
  2. 配置HTML链接解析器

    • 名称:给HTML链接解析器一个有意义的名称。
    • 要解析的响应:选择要解析的响应类型(例如,从上一个请求的响应中解析)。
    • 要解析的链接类型:选择要提取的链接类型(例如,URL、图像、CSS文件等)。
    • 输出变量名:设置提取的链接存储的变量名。
    • 匹配数字:设置要提取的链接数量(例如,提取前10个链接)。

参数说明

  • 名称:给HTML链接解析器一个有意义的名称。
  • 要解析的响应:选择要解析的响应类型,通常选择“从上一个请求的响应中解析”。
  • 要解析的链接类型:选择要提取的链接类型,例如:
    • URL:提取页面中的URL链接。
    • 图像:提取页面中的图像链接。
    • CSS文件:提取页面中的CSS文件链接。
    • JavaScript文件:提取页面中的JavaScript文件链接。
  • 输出变量名:设置提取的链接存储的变量名,可以在后续请求中引用这些变量。
  • 匹配数字:设置要提取的链接数量,例如,提取前10个链接。

示例配置

假设我们需要测试一个Web应用,并从页面中提取所有URL链接,然后对这些链接进行进一步的请求。

  1. 创建测试计划

    • 右键点击“测试计划” -> 新建 -> 输入测试计划名称(例如“Web应用性能测试”)。
  2. 添加线程组

    • 右键点击测试计划 -> 添加 -> 线程组 -> 输入线程组名称(例如“用户模拟”)。
    • 配置线程组:
      • 线程数:1(模拟1个用户)
      • 循环次数:1(每个用户发送1次请求)
      • 启动延迟:0(立即启动)
  3. 添加初始HTTP请求

    • 右键点击线程组 -> 添加 -> 取样器 -> HTTP请求。
    • 配置HTTP请求:
      • 名称:首页请求
      • 服务器名称或IP:目标服务器的地址(例如example.com)。
      • 端口号:目标服务器的端口(例如80)。
      • 协议:HTTP或HTTPS(例如HTTP)。
      • 方法:GET
      • 路径:请求的路径(例如/)。
  4. 添加HTML链接解析器

    • 右键点击首页请求 -> 添加 -> 预处理器 -> HTML链接解析器。
    • 配置HTML链接解析器:
      • 名称:HTML链接解析器
      • 要解析的响应:从上一个请求的响应中解析
      • 要解析的链接类型:URL
      • 输出变量名:url_links
      • 匹配数字:-1(提取所有链接)
  5. 添加后续HTTP请求

    • 右键点击线程组 -> 添加 -> 取样器 -> HTTP请求。
    • 配置HTTP请求:
      • 名称:链接请求
      • 服务器名称或IP:{__V(url_links_{__intSum(${__counter(true,)},1,)})}
      • 端口号:80
      • 协议:HTTP
      • 方法:GET
      • 路径:/
  6. 运行测试

    • 点击工具栏上的“启动”按钮,运行测试。

优化建议

  1. 链接类型选择

    • 根据实际需求选择要提取的链接类型。如果只需要提取URL链接,可以选择“URL”;如果需要提取图像链接,可以选择“图像”。
  2. 输出变量名

    • 确保输出变量名有意义且易于理解,便于在后续请求中引用。
  3. 匹配数量

    • 如果需要提取所有链接,可以设置匹配数量为-1。如果只需要提取部分链接,可以设置具体的数量。
  4. 动态引用链接

    • 使用JMeter函数(如__V__counter等)动态引用提取的链接,确保每个请求都能正确地使用提取的链接。
  5. 错误处理

    • 在测试计划中添加断言和监听器,确保提取的链接和后续请求的正确性。

示例配置详细说明

假设我们有一个简单的测试计划,包含一个线程组和两个HTTP请求,并希望从首页请求中提取所有URL链接,然后对这些链接进行进一步的请求。

  1. 创建测试计划

    • 右键点击“测试计划” -> 新建 -> 输入测试计划名称(例如“Web应用性能测试”)。
  2. 添加线程组

    • 右键点击测试计划 -> 添加 -> 线程组 -> 输入线程组名称(例如“用户模拟”)。
    • 配置线程组:
      • 线程数:1(模拟1个用户)
      • 循环次数:1(每个用户发送1次请求)
      • 启动延迟:0(立即启动)
  3. 添加初始HTTP请求

    • 右键点击线程组 -> 添加 -> 取样器 -> HTTP请求。
    • 配置HTTP请求:
      • 名称:首页请求
      • 服务器名称或IP:example.com
      • 端口号:80
      • 协议:HTTP
      • 方法:GET
      • 路径:/
  4. 添加HTML链接解析器

    • 右键点击首页请求 -> 添加 -> 预处理器 -> HTML链接解析器。
    • 配置HTML链接解析器:
      • 名称:HTML链接解析器
      • 要解析的响应:从上一个请求的响应中解析
      • 要解析的链接类型:URL
      • 输出变量名:url_links
      • 匹配数字:-1(提取所有链接)
  5. 添加后续HTTP请求

    • 右键点击线程组 -> 添加 -> 取样器 -> HTTP请求。
    • 配置HTTP请求:
      • 名称:链接请求
      • 服务器名称或IP:{__V(url_links_{__intSum(${__counter(true,)},1,)})}
      • 端口号:80
      • 协议:HTTP
      • 方法:GET
      • 路径:/
  6. 运行测试

    • 点击工具栏上的“启动”按钮,运行测试。

d4f3f10a248047208ac06f30d059d3af.png

 


4--HTTP URL 重写修饰符

功能特点

  • 会话管理:将会话标识符嵌入到URL中,确保服务器能够正确识别和管理会话。
  • 动态参数传递:动态修改HTTP请求的URL,传递必要的会话信息。
  • 适用于会话跟踪:特别适合需要会话跟踪和状态管理的测试场景。

配置步骤

  1. 添加HTTP URL重写修饰符

    • 右键点击需要添加预处理器的请求或线程组。
    • 选择“添加” -> “预处理器” -> “HTTP URL 重写修饰符”(HTTP URL Rewriting Modifier)。
  2. 配置HTTP URL重写修饰符

    • 名称:给HTTP URL重写修饰符一个有意义的名称。
    • 参数名称:设置会话标识符的名称(例如JSESSIONID)。
    • 参数值:设置会话标识符的值(可以是静态值或动态变量)。
    • 检查响应头:选择是否从响应头中提取会话标识符。
    • 检查响应数据:选择是否从响应数据中提取会话标识符。
    • 检查Cookie:选择是否从Cookie中提取会话标识符。

参数说明

  • 名称:给HTTP URL重写修饰符一个有意义的名称。
  • 参数名称:设置会话标识符的名称,通常是服务器生成的会话标识符名称(例如JSESSIONID)。
  • 参数值:设置会话标识符的值,可以是静态值或动态变量(例如${session_id})。
  • 检查响应头:选择是否从响应头中提取会话标识符,默认值为“否”。
  • 检查响应数据:选择是否从响应数据中提取会话标识符,默认值为“否”。
  • 检查Cookie:选择是否从Cookie中提取会话标识符,默认值为“否”。

示例配置

假设我们需要测试一个Web应用,并确保每个请求都包含会话标识符(例如JSESSIONID),以便服务器能够正确识别和管理会话。

  1. 创建测试计划

    • 右键点击“测试计划” -> 新建 -> 输入测试计划名称(例如“Web应用性能测试”)。
  2. 添加线程组

    • 右键点击测试计划 -> 添加 -> 线程组 -> 输入线程组名称(例如“用户模拟”)。
    • 配置线程组:
      • 线程数:1(模拟1个用户)
      • 循环次数:1(每个用户发送1次请求)
      • 启动延迟:0(立即启动)
  3. 添加HTTP请求

    • 右键点击线程组 -> 添加 -> 取样器 -> HTTP请求。
    • 配置HTTP请求:
      • 名称:首页请求
      • 服务器名称或IP:目标服务器的地址(例如example.com)。
      • 端口号:目标服务器的端口(例如80)。
      • 协议:HTTP或HTTPS(例如HTTP)。
      • 方法:GET
      • 路径:请求的路径(例如/)。
  4. 添加HTTP URL重写修饰符

    • 右键点击首页请求 -> 添加 -> 预处理器 -> HTTP URL 重写修饰符。
    • 配置HTTP URL重写修饰符:
      • 名称:HTTP URL重写修饰符
      • 参数名称:JSESSIONID
      • 参数值:${session_id}(假设session_id是从上一个请求中提取的会话标识符)
      • 检查响应头:是(从响应头中提取会话标识符)
      • 检查响应数据:否
      • 检查Cookie:是(从Cookie中提取会话标识符)
  5. 运行测试

    • 点击工具栏上的“启动”按钮,运行测试。

优化建议

  1. 参数名称和值

    • 确保参数名称和值正确无误。参数名称通常是服务器生成的会话标识符名称(例如JSESSIONID),参数值可以从上一个请求中提取或手动设置。
  2. 检查选项

    • 根据实际需求选择合适的检查选项。如果会话标识符存储在响应头中,选择“检查响应头”;如果存储在响应数据中,选择“检查响应数据”;如果存储在Cookie中,选择“检查Cookie”。
  3. 动态变量

    • 如果会话标识符是动态生成的,可以使用JMeter变量(例如${session_id})来传递会话标识符值。
  4. 错误处理

    • 在测试计划中添加断言和监听器,确保会话标识符的正确性和请求的成功率。

示例配置详细说明

假设我们有一个简单的测试计划,包含一个线程组和一个HTTP请求,并希望确保每个请求都包含会话标识符(例如JSESSIONID),以便服务器能够正确识别和管理会话。

  1. 创建测试计划

    • 右键点击“测试计划” -> 新建 -> 输入测试计划名称(例如“Web应用性能测试”)。
  2. 添加线程组

    • 右键点击测试计划 -> 添加 -> 线程组 -> 输入线程组名称(例如“用户模拟”)。
    • 配置线程组:
      • 线程数:1(模拟1个用户)
      • 循环次数:1(每个用户发送1次请求)
      • 启动延迟:0(立即启动)
  3. 添加HTTP请求

    • 右键点击线程组 -> 添加 -> 取样器 -> HTTP请求。
    • 配置HTTP请求:
      • 名称:首页请求
      • 服务器名称或IP:example.com
      • 端口号:80
      • 协议:HTTP
      • 方法:GET
      • 路径:/
  4. 添加HTTP URL重写修饰符

    • 右键点击首页请求 -> 添加 -> 预处理器 -> HTTP URL 重写修饰符。
    • 配置HTTP URL重写修饰符:
      • 名称:HTTP URL重写修饰符
      • 参数名称:JSESSIONID
      • 参数值:${session_id}(假设session_id是从上一个请求中提取的会话标识符)
      • 检查响应头:是(从响应头中提取会话标识符)
      • 检查响应数据:否
      • 检查Cookie:是(从Cookie中提取会话标识符)
  5. 运行测试

    • 点击工具栏上的“启动”按钮,运行测试。

 

969cbed6a1164fd58d6e77ba093f6b2a.png


 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/915939.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2023年高校大数据挑战赛A题中文文本纠错求解全过程文档及程序

2023年高校大数据挑战赛 A题 中文文本纠错 原题再现: 中文文本纠错的任务主要是针对中文文本中出现的错误进行检测和纠正,属于人工智能自然语言处理的研究子方向。中文文本纠错通常使用的场景有政务公文、裁判文书、新闻出版等,中文文本纠错…

使用CNN进行验证码识别:深度学习与图像预处理教程

验证码(CAPTCHA)广泛用于区分人类和自动化程序(如机器人),通常由扭曲的字母、数字或符号组成。为了实现验证码的自动识别,深度学习尤其是卷积神经网络(CNN)非常有效。本文将带你一起…

基于 Python Django 的二手房间可视化系统分析

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…

探索 Sentinel 服务容错

Sentinel 是阿里巴巴开源的一款高可用防护组件,主要用于分布式系统中的流量控制、熔断降级和系统负载保护。它在 Java 微服务架构中扮演着重要的角色,帮助开发者确保系统的稳定性和可靠性。 以下是 Sentinel 的一些关键特性: 流量控制(Flow Control):通过对请求进行限流…

DBeaver 连接 OceanBase Oracle 租户

DBeaver 是一款通用的数据库工具软件,支持任何具有JDBC驱动程序的数据库。DBeaver 需要 Java 运行环境的支持。截稿时 DBeaver 24.0.0 版本默认提供的 OceanBase 驱动是连接 MySQL 的,想连接 Oracle 租户需要新建一个驱动器使用。 下载数据库驱动包 1、…

Dubbo 3.x源码(24)—Dubbo服务引用源码(7)接口级服务发现订阅refreshInterfaceInvoker

基于Dubbo 3.1,详细介绍了Dubbo服务的发布与引用的源码。 此前我们学习了Dubbo3.1版本的MigrationRuleHandler这个处理器,它用于通过动态更改规则来控制迁移行为。MigrationRuleListener的onrefer方法是Dubbo2.x 接口级服务发现与Dubbo3.x应用级服务发现…

企业如何提高招聘能力?

企业如何提高招聘能力? 许多企业在进行招聘工作时,常常会遇到各种问题和挑战。尽管付出了大量的时间和精力,但结果却并不总是如人意。例如,企业可能会经历一次又一次的面试,却仍然找不到一个能够适应岗位要求的合适人…

JAVA:探索 EasyExcel 的技术指南

1、简述 在 Java 开发中,Excel 文件的读写操作是一项常见的需求。阿里巴巴开源的 EasyExcel 提供了一种高效、简洁的解决方案,特别是在处理大规模数据时表现尤为突出。本文将详细介绍 EasyExcel 的优缺点、应用场景,并通过实例展示其基本用法…

AI制作ppt

1,kimi: 实际上也是AiPPT.cn这个网站(但是有实际次数限制) 2,其余专业AI ppt生成网站: (1)gamma:https://gamma.app/ 大概能制作7~10页左右 free的ppt,其余要…

穿越数据迷宫:C++哈希表的奇幻旅程

文章目录 前言📔一、unordered系列关联式容器📕1.1 unordered 容器概述📕1.2 哈希表在 unordered 容器中的实现原理📕1.3 unordered 容器的特点 📔二、unordered_set 和 unordered_map 的基本操作📕2.1 un…

数据结构 -二叉搜索树

一.什么是二叉搜索树 树插入删除方便比线性数组 二.二叉搜索树的查找操作 尾递归可以用循环递归 三.二叉树的插入操作 35要挂在33上面必须记住33的位置 解决方法,要求递归函数返回一个 结点插到33的右子树 四.二叉搜索树的删除 要是删除的是叶子节点之间删除 只有一…

计算机三级 数据库技术

第一章 数据库应用系统开发方法 1.1 数据库应用系统生命周期 软件工程:软件工程的思想,即用工程的概念、原理、技术和方法对软件生产、开发的全过程进行跟踪和管理 软件开发方法:瀑布模型、快速原型模型、螺旋模型 DBAS生命周期模型 1.2 规划与分析 系统规划与定…

使用 AMD GPU 推理 Mixtral 8x22B

Inferencing with Mixtral 8x22B on AMD GPUs — ROCm Blogs 2024年5月1日,由 Clint Greene撰写。 简介 自从Mistral AI’s AI发布了Mixtral 8x7B以来,专家混合(MoE)在AI社区重新获得了关注。受此发展启发,多个AI公…

前后端、网关、协议方面补充

这里写目录标题 前后端接口文档简介前后端视角对于前端对于后端代码注册路由路由处理函数 关于httpGET/POST底层网络关于前端的获取 路由器网关路由器的IP简介公网IP(WAN IP)私网IP(LAN IP)无线网络IP(WIFI IP)查询路由器私网IP路由器公网IP LAN口与WIFI简介基本原理 手动配置电…

leetcode104:二叉树的最大深度

给定一个二叉树 root ,返回其最大深度。 二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。 示例 1: 输入:root [3,9,20,null,null,15,7] 输出:3示例 2: 输入:root [1,null,2] 输出…

大语言模型理论基础

文章目录 前言大语言模型必需知识概述大语言模型目标模型上下文神经网络的神经元常见激活函数SigmoidTanhRelusoftmax 通用近似定理多层感知机(MLP)拟合最后 前言 你好,我是醉墨居士,我们接下来对大语言模型一探究竟,…

关于VUE NPM安装失败的问题

最近使用 npm install --registryhttps://registry.npmmirror.com 安装一个新项目的依赖,各种失败。 最后发现是package-lock里面有老的淘宝的域名,整体替换掉就行了

【数据结构】宜宾大学-计院-实验七

实验七 二叉树 一、实验目的:二、实验内容:三、实验结果:1,2;3,4,5;6.数组顺序存储的优缺点二叉链表存储的优缺点 一、实验目的: 掌握二叉树的顺序存储结构 掌握二叉树的链式存储结构 二、实验内容: 1&am…

游戏如何应对内存修改

据观察,近年来游戏黑灰产攻击角度多样化趋势显著,主要面临工作室、定制注入挂、模拟点击挂、内存修改挂、破解版等多方面安全问题。 据FairGuard数据统计,在游戏面临的众多安全风险中,「内存修改」攻击占比约为13%,主…

git重置的四种类型(Git Reset)

git区域概念 1.工作区:IDEA中红色显示文件为工作区中的文件 (还未使用git add命令加入暂存区) 2.暂存区:IDEA中绿色(本次还未提交的新增的文件显示为绿色)或者蓝色(本次修改的之前版本提交的文件但本次还未提交的文件显示为蓝色)显示的文件为暂存区中的文件(使用了…