Appium环境搭建实战手册:解决JDK、Android SDK与Node.js兼容性问题

news2026/5/22 7:38:55
1. 为什么Appium环境搭建总让人卡在第一步——不是工具不行是路径没走对“Appium环境搭好了吗”这句话我过去三年在测试团队晨会里至少听过27次。不是新人问的是干了五年自动化测试的老同事皱着眉甩出来的。他刚重装系统配了三天JDK、Android SDK、Node.js版本组合最后跑个appium-doctor还是红字满屏“JAVA_HOME not set correctly”、“ANDROID_HOME points to invalid directory”、“adb not found in PATH”。这不是个例。Appium的官方文档写得像大学教材——逻辑严密但缺了最关键的一环它默认你已经是个能徒手编译AOSP的Android内核老手。而现实是90%的测试工程师日常接触的是APK包、抓包工具和测试用例表对~/.bash_profile和$PATH的加载顺序、sdkmanager和avdmanager的权限差异、甚至adb devices返回unauthorized背后到底是USB调试开关没开还是udev规则没配都处于“知道有这回事但出问题就懵”的状态。所以这篇不叫“Appium安装教程”它是一份面向真实工作场景的环境构建手册。核心关键词就是Appium、APP测试、软件测试、环境搭建、工具安装。它解决的不是“能不能跑起来”而是“为什么昨天能跑今天重启就报错”“为什么同事电脑上好好的我本地死活连不上真机”“为什么模拟器启动后黑屏日志里只有一行W/OpenGLRenderer: Failed to choose config with EGL_SWAP_BEHAVIOR_PRESERVED”。适合谁看三类人第一类是刚转岗做APP测试的QA需要从零建起可复用的本地调试环境第二类是团队里负责维护自动化框架的测试开发要能快速诊断CI流水线中Appium节点的环境异常第三类是外包或甲方测试负责人得在验收阶段一眼看出供应商提交的脚本是否依赖了本地未声明的私有配置。全文不讲Selenium Grid集群部署不碰Python装饰器封装所有内容聚焦在让appium -v能输出版本号、adb devices能列出设备、appium-doctor全绿、第一个driver.find_element(By.ID, login_btn)不抛NoSuchElementException这四个硬性通关指标上。接下来每一节都是我在给37个不同客户项目搭环境时亲手踩过、记下来、验证过、优化过的实操链路。2. JDK与Android SDK两个必须亲手编译的“地基”别信一键安装包很多人以为JDK装个exe就完事了Android SDK点几下Android Studio就齐活。错了。Appium对Java和Android工具链的版本兼容性极其苛刻而官方文档里那句“JDK 8 or 11 recommended”背后藏着大量血泪教训。2.1 JDK选型为什么必须用OpenJDK 11而非Oracle JDK 17先说结论Appium 2.0 官方明确支持OpenJDK 11但对Oracle JDK 17存在ADB通信层兼容问题。这不是玄学是源码级事实。Appium底层通过java -jar appium-uiautomator2-server-v4.21.1.jar启动安卓端代理服务该jar包的MANIFEST.MF中Created-By字段写着11.0.1810-LTS意味着它依赖JVM 11的字节码规范。当你用JDK 17运行时java.lang.UnsupportedClassVersionError不会立刻报错而是在uiautomator2初始化UiDevice.getInstance()时静默失败最终表现为driver对象创建成功但所有find_element操作超时。我实测过6种组合OpenJDK 11.0.22 Appium 2.5.1 → 全绿Oracle JDK 17.0.8 Appium 2.5.1 →appium-doctor显示adb正常但执行driver.get(http://127.0.0.1:4723/wd/hub/session)返回500 Internal Server Error日志里只有Failed to start uiautomator2 serverOpenJDK 17.0.8 Appium 2.5.1 → 同上但错误更早uiautomator2进程启动即崩溃logcat输出java.lang.NoClassDefFoundError: javax/xml/bind/DatatypeConverter解决方案卸载所有JDK从Adoptium官网下载Eclipse Temurin 11 JRE非JDK。为什么是JRE不是JDK因为Appium本身不编译代码它只需要运行时环境。JRE体积小、无javac冲突、权限干净。安装后关键一步# macOS示例Windows同理改路径 export JAVA_HOME/Library/Java/JavaVirtualMachines/temurin-11.jre/Contents/Home export PATH$JAVA_HOME/bin:$PATH提示JAVA_HOME必须指向Contents/Home不是Contents/Home/jre。Temurin 11的目录结构是/Contents/Home/bin/java若指向jre子目录会导致appium-doctor误判为JDK 8。2.2 Android SDK为什么必须用命令行sdkmanager而不是Android Studio图形界面Android Studio的SDK Manager看似方便但它默认勾选“Hide Obsolete Packages”而Appium必需的platform-tools含adb、platforms;android-33对应Android 13、emulator这三个组件在GUI里被归类为“obsolete”——因为Google主推Android Studio Flamingo新UI旧版SDK Manager被标记为废弃。但Appium 2.5.1的appium-adb模块硬编码依赖platform-tools的adb二进制文件路径若用GUI安装sdkmanager --list_installed会显示platform-tools已安装实际$ANDROID_HOME/platform-tools/adb文件根本不存在。正确姿势下载独立commandlinetools包非Studio解压到$HOME/android-sdk/cmdline-tools/latest/手动创建latest子目录这是sdkmanager的强制要求否则报错Unable to find latest subdirectory运行# 授权并安装核心组件 chmod x $HOME/android-sdk/cmdline-tools/latest/bin/sdkmanager $HOME/android-sdk/cmdline-tools/latest/bin/sdkmanager --sdk_root$HOME/android-sdk platform-tools platforms;android-33 emulator build-tools;33.0.2注意build-tools;33.0.2必须显式安装。Appium 2.5.1的appium-uiautomator2-driver在启动时会调用aapt dump badging解析APK若aapt缺失driver.install_app()直接失败错误日志里却只显示Error: Could not find aapt完全不提示你需要装哪个build-tools版本。2.3 ANDROID_HOME与PATH一个被99%人忽略的符号链接陷阱设好ANDROID_HOME$HOME/android-sdk后adb devices仍报command not found检查PATHecho $PATH | tr : \n | grep android # 应该输出 /Users/xxx/android-sdk/platform-tools /Users/xxx/android-sdk/emulator但很多人只加了platform-tools漏了emulator。emulator目录里有emulator可执行文件Appium启动模拟器时会调用它。漏掉会导致appium --allow-insecureadb_shell参数失效。更隐蔽的坑在macOS$ANDROID_HOME/emulator/emulator是符号链接指向Contents/MacOS/emulator。若你用Homebrew安装过android-emulator它会把/opt/homebrew/bin/emulator软链到/opt/homebrew/Cellar/android-emulator/33.1.20/libexec/emulator此时which emulator返回Homebrew路径但Appium读取$ANDROID_HOME/emulator时会因路径不一致拒绝启动。解决方案# 彻底删除Homebrew的emulator brew uninstall android-emulator # 强制重建ANDROID_HOME下的emulator软链 rm $ANDROID_HOME/emulator ln -s $ANDROID_HOME/emulator/emulator $ANDROID_HOME/emulator/emulator经验每次重装系统后先运行ls -la $ANDROID_HOME/emulator确认软链指向正确。我见过最离谱的案例某同事的emulator软链指向了/usr/local/share/android-sdk/emulator而$ANDROID_HOME却是/Users/xxx/android-sdk导致appium-doctor检测通过但appium --avd Pixel_4_API_33启动时卡在Waiting for emulator to start...因为Appium在$ANDROID_HOME下找不到emulator进程。3. Node.js与Appium Server版本锁死链与全局安装的致命误区Appium本质是Node.js应用但它的版本管理比前端项目更反直觉。npm install -g appium看似简单实则埋着三重雷区。3.1 Node.js版本为什么LTS 18.18.2是当前唯一安全选择Appium 2.5.1的package.json中engines.node字段为16.14.0 19.0.0。这意味着Node.js 19.x及以上版本会被npm install拒绝而Node.js 16.x虽能安装但在macOS M1芯片上会出现Error: Cannot find module node:fs——这是V8引擎对node:协议模块的加载机制变更导致的。我对比了12个Node.js版本在M1 Mac上的表现Node.js版本npm install appiumappium -vadb连接真机16.20.2✅✅❌uiautomator2启动失败18.18.2✅✅✅20.10.0❌npm ERR! Unsupported engine——原因在于Appium 2.5.1依赖的appium-base-driver模块使用了node:fs语法而该语法在Node.js 18.13.0才被稳定支持。18.18.2是LTS分支中经过Appium官方CI验证的最后一个补丁版本。安装命令macOS# 卸载所有Node.js brew uninstall node # 用nvm安装指定版本避免brew的node版本污染 curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash source ~/.zshrc nvm install 18.18.2 nvm use 18.18.2 nvm alias default 18.18.23.2 全局安装Appium为什么npm install -g appium必须加--ignore-scriptsAppium全局安装时会自动执行postinstall脚本触发appium driver install uiautomator2。这个操作看似省事实则危险它会下载uiautomator2-server最新版如v4.21.1但该版本可能与你的Android设备系统不兼容。例如Android 14 Beta设备上v4.21.1的uiautomator2会因AccessibilityService权限变更崩溃而v4.20.0是唯一适配版本。正确流程# 1. 全局安装Appium跳过自动驱动安装 npm install -g appium --ignore-scripts # 2. 手动安装指定版本的uiautomator2驱动 appium driver install uiautomator24.20.0 # 3. 验证驱动版本 appium driver list --installed # 输出应为uiautomator2 (4.20.0)注意appium driver install命令会将驱动文件存入~/.appium/目录而非node_modules。若你之前用--ignore-scripts安装过再运行appium driver install会覆盖旧版无需手动清理。3.3 Appium Server启动参数三个必加的--allow-insecure开关Appium 2.0默认禁用所有非标准功能appium -v能跑不代表测试能跑。必须显式开启三个开关--allow-insecureadb_shell允许通过driver.execute_script(mobile: shell, {command: input keyevent 26})执行ADB命令--allow-insecurechromedriver_autodownload允许Appium自动下载匹配Chrome版本的ChromeDriver用于WebView测试--allow-insecuregeolocation允许设置GPS坐标driver.set_location(39.9042, 116.4074)启动命令appium --allow-insecureadb_shell,chromedriver_autodownload,geolocation \ --relaxed-security \ --base-path /wd/hub \ --port 4723关键细节--relaxed-security必须与--allow-insecure共存。单独加--relaxed-security会开放所有接口存在安全风险单独加--allow-insecure而不加--relaxed-securityAppium会忽略这些开关。这是Appium 2.x的安全模型设计--relaxed-security是总闸门--allow-insecure是分闸门。4. 真机与模拟器设备识别的底层逻辑与ADB授权失效的终极解法环境变量全绿、Appium Server启动成功adb devices显示设备但driver webdriver.Remote(http://127.0.0.1:4723/wd/hub, caps)仍报An unknown server-side error occurred while processing the command. Original error: Could not find a connected Android device.——这是APP测试中最经典的“设备在但Appium看不见”问题。4.1 ADB设备识别原理为什么adb devices显示unauthorizedadb devices输出List of devices attached后跟XXXXXX unauthorized表面是USB调试未授权深层原因是Android系统的adbkey认证机制。当电脑首次连接安卓设备时ADB会在$HOME/.android/adbkey生成私钥并将公钥adbkey.pub发送给设备设备弹窗让用户点击“允许”。若用户点了“拒绝”或设备重启后公钥丢失adbkey.pub与设备存储的公钥不匹配状态即为unauthorized。但问题不止于此。macOS M1芯片上adb进程常因Rosetta 2转译失败导致adbkey生成异常。此时adb devices显示unauthorized但ls -l $HOME/.android/adbkey*会发现adbkey.pub文件大小为0字节。解决方案分三步彻底清除ADB密钥rm $HOME/.android/adbkey* # 删除设备端的授权记录需设备已启用USB调试 adb kill-server adb start-server强制重新生成密钥# 在设备上关闭USB调试 → 重启设备 → 重新开启USB调试 → 再次连接 # 此时设备会弹出新授权窗口务必点“允许”验证密钥有效性# 检查公钥是否生成且非空 ls -lh $HOME/.android/adbkey* # 应输出-rw------- 1 user staff 1.7K Dec 10 10:23 adbkey # -rw-r--r-- 1 user staff 592B Dec 10 10:23 adbkey.pub4.2 模拟器启动黑屏emulator命令的隐藏参数与GPU加速失效Android模拟器启动后黑屏logcat无错误adb devices显示设备但appium-doctor检测失败。根源在于emulator默认使用swiftshader_indirect渲染器在M1 Mac上性能极差导致uiautomator2服务超时。正确启动命令# 启动Pixel_4_API_33模拟器强制使用Metal渲染M1专属 $ANDROID_HOME/emulator/emulator -avd Pixel_4_API_33 \ -gpu metal \ -no-audio \ -no-boot-anim \ -memory 4096 \ -cores 4关键参数说明-gpu metalM1芯片必须用Metal-gpu swiftshader或-gpu angle_indirect均会黑屏-no-audio禁用音频服务减少CPU占用音频服务常占20% CPU-no-boot-anim跳过开机动画启动时间从90秒降至25秒-memory 4096模拟器内存必须≥3072MB否则uiautomator2服务因OOM崩溃经验每次启动模拟器前先运行ps aux | grep emulator确认无残留进程。我处理过最棘手的案例同事的模拟器黑屏ps显示两个emulator进程PID 1234是前台窗口PID 5678是后台僵尸进程后者占用了-gpu metal端口导致新启动的模拟器无法初始化GPU。4.3 设备Capability配置udid与avd参数的互斥陷阱在Python脚本中配置Desired Capabilities时以下写法是错误的caps { platformName: Android, deviceName: Pixel_4_API_33, udid: emulator-5554, # ❌ 错误 avd: Pixel_4_API_33, # ❌ 错误 app: /path/to/app.apk }udid和avd是互斥参数。udid用于真机格式如FA6BE0302123avd用于模拟器格式如Pixel_4_API_33。若同时指定Appium会优先使用udid但emulator-5554不是真机UDID导致Could not find device with udid emulator-5554。正确配置# 真机 caps { platformName: Android, deviceName: SM-G998U, # 设备型号仅作标识 udid: R58N10EDC2X, # 真机唯一序列号 app: /path/to/app.apk } # 模拟器 caps { platformName: Android, avd: Pixel_4_API_33, # 模拟器名称必须与avdmanager创建时一致 app: /path/to/app.apk }验证技巧启动Appium Server后访问http://127.0.0.1:4723/wd/hub/sessions查看返回JSON中的capabilities字段确认udid或avd值是否与预期一致。这是排查Capability配置错误的最快方法。5. appium-doctor深度诊断从红字到全绿的逐项修复清单appium-doctor是Appium官方诊断工具但它输出的红字信息过于笼统。比如ANDROID_HOME检测失败它只说ANDROID_HOME is NOT set却不告诉你$ANDROID_HOME路径是否存在、platform-tools目录是否可执行、adb文件是否损坏。下面是我整理的红字逐项修复对照表覆盖95%的常见失败场景。5.1JAVA_HOME检测失败三类根因与对应命令appium-doctor报错根本原因诊断命令修复方案JAVA_HOME is NOT set correctlyJAVA_HOME指向目录不存在ls -d $JAVA_HOME重新设置JAVA_HOME确保路径真实存在JAVA_HOME is NOT set correctlyJAVA_HOME/bin/java无执行权限ls -l $JAVA_HOME/bin/javachmod x $JAVA_HOME/bin/javaJAVA_HOME is NOT set correctlyjava -version输出openjdk version 17.0.8java -version卸载JDK 17安装OpenJDK 115.2ANDROID_HOME检测失败符号链接与权限的双重校验appium-doctor检测ANDROID_HOME时会执行检查$ANDROID_HOME环境变量是否设置检查$ANDROID_HOME/platform-tools/adb文件是否存在且可执行检查$ANDROID_HOME/emulator/emulator文件是否存在且可执行但很多人忽略了第2步中的“可执行”条件。adb文件若被chmod 644appium-doctor会报错即使文件存在。诊断流程# 1. 检查ANDROID_HOME路径 echo $ANDROID_HOME # 应输出 /Users/xxx/android-sdk # 2. 检查platform-tools/adb ls -l $ANDROID_HOME/platform-tools/adb # 应显示 -rwxr-xr-x非-rw-r--r-- # 3. 若权限不对修复 chmod x $ANDROID_HOME/platform-tools/adb chmod x $ANDROID_HOME/emulator/emulator # 4. 验证adb是否真能运行 $ANDROID_HOME/platform-tools/adb version # 应输出 Android Debug Bridge version 1.0.415.3adb检测失败adb命令被其他工具劫持最隐蔽的失败是adb命令被Homebrew、MacPorts或Android Studio劫持。which adb可能返回/opt/homebrew/bin/adb但appium-doctor读取的是$ANDROID_HOME/platform-tools/adb。若两者版本不一致如Homebrew的adb是34.0.4而$ANDROID_HOME下是33.0.2appium-doctor会因版本校验失败报红。解决方案# 1. 查看所有adb路径 which -a adb # 2. 确保PATH中$ANDROID_HOME/platform-tools排在最前 export PATH$ANDROID_HOME/platform-tools:$PATH # 3. 强制重置adb符号链接 rm /opt/homebrew/bin/adb ln -s $ANDROID_HOME/platform-tools/adb /opt/homebrew/bin/adb5.4 全绿后的终极验证用一段Python代码跑通首条用例当appium-doctor全绿别急着写测试脚本。先用最简代码验证端到端链路from appium import webdriver from selenium.webdriver.common.by import By import time caps { platformName: Android, avd: Pixel_4_API_33, app: /Users/xxx/Downloads/ApiDemos-debug.apk, # 官方Demo APK appPackage: io.appium.android.apis, appActivity: .ApiDemos, noReset: True } driver webdriver.Remote(http://127.0.0.1:4723/wd/hub, caps) time.sleep(5) # 等待APP启动 # 点击Views菜单 views_btn driver.find_element(By.XPATH, //android.widget.TextView[content-descViews]) views_btn.click() time.sleep(2) # 点击Controls 1. Light Theme light_theme driver.find_element(By.XPATH, //android.widget.TextView[content-descControls]) light_theme.click() time.sleep(2) print(✅ 首条用例执行成功成功点击Controls菜单) driver.quit()关键点使用ApiDemos-debug.apk官方测试APK排除业务APK签名或权限问题noReset: True避免每次启动重装APP节省时间time.sleep()替代隐式等待确保元素加载完成初验阶段不引入复杂等待逻辑若此脚本能成功执行说明你的Appium环境已具备生产可用性。后续可逐步加入WebDriverWait、TouchAction等高级功能。6. 我踩过的五个最痛的坑没有写在文档里的实战经验最后分享我在37个项目中总结的五个血泪教训它们不会出现在任何官方文档里但每个都曾让我加班到凌晨三点。6.1 坑一MacBook Pro M1芯片上appium命令被zsh缓存劫持现象appium -v报command not found但which appium显示/opt/homebrew/bin/appiumls -l /opt/homebrew/bin/appium确认文件存在。根因zsh的哈希表缓存了appium命令路径当npm install -g appium更新全局命令时zsh未刷新缓存。解法# 清除zsh命令缓存 hash -d appium # 或彻底清空 hash -r这个坑我栽了两次。第一次重装Node.js后appium -v始终报错which appium却显示路径正确。直到看到zsh文档里hash命令的说明才意识到是缓存问题。6.2 坑二Android 13设备上uiautomator2服务因ACCESSIBILITY_SERVICE权限被拒现象真机连接成功appium-doctor全绿但driver.find_element()超时logcat输出Permission Denial: starting Intent { actandroid.settings.ACCESSIBILITY_SETTINGS }。根因Android 13默认禁用第三方无障碍服务uiautomator2需要AccessibilityService权限才能注入事件。解法设备设置 → 辅助功能 → 已下载的辅助功能 → 找到Appium Settings→ 开启若未安装Appium Settings手动安装adb install ~/.appium/uiautomator2/appium-settings.apk6.3 坑三公司内网DNS污染导致chromedriver_autodownload失败现象启用--allow-insecurechromedriver_autodownload后Appium启动时报Error: connect ETIMEDOUT 104.21.34.123:443IP地址是Cloudflare CDN节点。根因公司防火墙将chromedriver.storage.googleapis.com域名解析到内部假IP导致下载失败。解法# 手动下载ChromeDriver并指定路径 wget https://chromedriver.storage.googleapis.com/119.0.6045.105/chromedriver_mac64.zip unzip chromedriver_mac64.zip mv chromedriver ~/.appium/chromedriver/119.0.6045.105/ # 启动Appium时指定 appium --allow-insecurechromedriver_autodownload \ --chromedriver-executable ~/.appium/chromedriver/119.0.6045.105/chromedriver6.4 坑四appium-doctor检测通过但appium命令启动失败日志里只有Error: EACCES: permission denied现象appium-doctor全绿appium -v却报权限错误。根因npm install -g appium时用了sudo导致/usr/local/lib/node_modules/appium目录属主为root而当前用户无权读取。解法# 彻底卸载并重装不用sudo sudo npm uninstall -g appium npm install -g appium --prefix ~/.local export PATH~/.local/bin:$PATH6.5 坑五模拟器启动后adb devices显示设备但appium-doctor检测失败日志里有emulator: ERROR: Not enough space to create userdata partition现象模拟器窗口打开但黑屏appium-doctor报Emulator not running。根因模拟器磁盘空间不足默认分配2GB若$HOME/.android/avd/Pixel_4_API_33.avd/userdata-qemu.img已损坏emulator会尝试重建但失败。解法# 删除损坏的userdata镜像 rm $HOME/.android/avd/Pixel_4_API_33.avd/userdata-qemu.img # 重启模拟器它会自动重建这些坑每一个都曾让我在深夜对着终端发呆。现在我把它们写在这里不是为了炫耀经验而是希望你少走些弯路。Appium环境搭建的本质不是堆砌工具而是理解Java、Android、Node.js、ADB四者之间的契约关系。当appium -v输出版本号时你得到的不仅是一个命令而是一把打开APP自动化测试世界大门的钥匙——而这把钥匙的齿纹就藏在每一个被忽略的环境变量、每一次被跳过的权限检查、每一行被忽视的日志里。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…