最新资讯

  • 使用Quarkus构建首个Keycloak MCP服务器实战指南

使用Quarkus构建首个Keycloak MCP服务器实战指南

2026-01-31 10:13:12 栏目:最新资讯 3 阅读

A Keycloak示例 - 使用Quarkus构建我的第一个MCP服务器工具

最近我写了一篇关于"在Java生态系统中采用模型上下文协议"的文章。现在也是时候开始尝试自己编写MCP服务器了(也许这不是第一次)。

我当然不想错过社区展示的所有酷炫功能。我的目标是学习,并可能创建一个更实用的示例。在这篇文章中,我将选择Keycloak,并为其编写一个实验性的MCP服务器实现。这篇文章也是为了激发对这个主题的兴趣。为Keycloak开发MCP服务器会有用吗?

什么是模型上下文协议?

模型上下文协议是Anthropic于2024年11月引入的标准。MCP的目的是建立一个标准,帮助社区编写和使用工具、提示和资源。想象一下,你开始为Slack这样的工具编写工具,我也开始为Slack编写工具。看啊,我们都有自己的实现,但随后Slack也推出了自己的工具。这时我们就有个小问题:一是没有标准的方式与这些工具通信;二是如果Slack或GitHub负责为其服务创建和暴露工具,会使你我的生活更轻松。这正是我认为MCP非常有用的用例。

MCPServerClientLLMUserMCPServerClientLLMUser
您的提问(包含可用工具信息)1
分析问题并决定使用哪些工具2
指示使用选定的工具3
执行选定的工具4
工具结果5
转发工具结果6
使用工具结果制定答案7
最终响应!8

解释:
用户向LLM发送查询/问题。
LLM分析问题并决定是否需要调用工具。
LLM然后指示客户端执行工具。
客户端在MCP服务器上执行工具。
客户端将结果返回给LLM。
LLM为用户制定结果。

虽然这只是一个基本示例。现实是MCP还支持提示和资源。同样重要的是要说明,MCP通常并不真正带来新功能,而是专注于标准。自其出现以来,我们已经有多个MCP服务器和框架实现可供使用,如Quarkus、Spring AI、MCP SDK等。

MCP使我们能够通过提供例如预构建集成选择和在不同LLM之间切换的灵活性来开发代理和复杂工作流。

Stdio与SSE

在使用标准IO进行本地开发(服务器和客户端在同一台机器上)或构建CLI应用程序与使用HTTP上的服务器发送事件进行远程开发之间应该做出关键区分。后者应该被强调为在实际多应用程序使用中最实用的。另一个需要注意的重要事项是MCP服务器通过JSON-RPC进行通信。

JSON-RPC是一种无状态、轻量级的远程过程调用协议。该规范主要定义了几种数据结构及其处理规则。它在传输方面是不可知的,因为这些概念可以在同一进程内、通过套接字、通过HTTP或在许多不同的消息传递环境中使用。

逻辑分解:

StdioSSEJava AppMCP ClientMCP ServerKeycloak

Keycloak

如果您不熟悉Keycloak;它是一个开源的身份和访问管理软件。当前版本是26,已经在实际环境中广泛使用。它通过OAuth/OIDC、AD、LDAP和SAML v2提供单点登录功能。如果您不太熟悉Keycloak,我还编写了一个小型自定进度的Keycloak教程,涵盖了所有基础知识和一些高级配置。

开始吧

从quarkus cli或通过code.quarkus.io创建项目。

在我的示例中,我使用stdio。这意味着基于CLI的标准输入输出扩展。

在pom.xml中添加stdio Quarkus扩展:

<dependency>
    <groupId>io.quarkiverse.mcpgroupId>
    <artifactId>quarkus-mcp-server-stdioartifactId>
    <version>1.0.0.Alpha5version>
dependency>

很棒。一个有趣的事实是Keycloak也是使用Quarkus构建的。最初它基于Wildfly,但大约2年前团队将整个项目迁移到了Quarkus。Keycloak Admin CLI,顾名思义,是用于管理Keycloak的强大工具,使用REST API。我将在这个项目中使用它。让我们也将其添加到pom.xml中:

<dependency>
    <groupId>io.quarkusgroupId>
    <artifactId>quarkus-keycloak-admin-rest-clientartifactId>
dependency>

好的,这应该为开始设置好了基础。

由于我是从头开始。是时候编写第一个服务了。我将编写一个UserService,它将通过Keycloak Admin客户端调用领域内用户的CRUD操作。

什么是领域

领域是给定组或应用程序或服务的所有配置、选项的逻辑命名空间。领域保护和管理一组用户、应用程序和注册的身份代理、客户端等的安全元数据。用户可以在管理控制台内的特定领域中创建。角色(权限类型)可以在领域级别定义,您还可以设置用户角色映射以将这些权限分配给特定用户。用户属于一个领域并登录到该领域。领域彼此隔离,只能管理和验证它们控制的用户。

RealmUsersGroupsRolesClients

Keycloak的UserService

让我们开始编写一个服务类来访问Keycloak。

@ApplicationScoped // [1]
public class UserService {
    
    @Inject 
    Keycloak keycloak; // [2]

}

服务在应用程序启动时启动@ApplicationScoped。我还注入了import org.keycloak.admin.client.Keycloak客户端来调用Keycloak上的管理API。

以下getUsers方法将领域作为输入。这意味着我强制用户指定一个领域。因为在keycloak安装中可能有多个领域。一旦接收到realm参数,我就可以调用user().list()来获取领域中的所有用户。

public List<UserRepresentation> getUsers(String realm) {
    return keycloak.realm(realm).users().list();
}

对于addUser方法,我需要用户创建参数和领域。这样,当进行工具调用时,我想确保上下文是领域。例如,用户可能要求从两个领域获取用户,然后将用户添加到其中一个。

public String addUser(String realm, String username, String firstName, String lastName, String email, String password) {
    UserRepresentation user = new UserRepresentation(); // 设置用户字段 [1]
    user.setFirstName(firstName);
    user.setLastName(lastName);
    user.setUsername(username);
    user.setEnabled(true);
    user.setEmail(email);

    CredentialRepresentation credential = new CredentialRepresentation(); // 添加密码 [2]
    credential.setType(CredentialRepresentation.PASSWORD);
    credential.setValue(password);
    credential.setTemporary(false);
    user.setCredentials(List.of(credential));
    
    Response response = keycloak.realm(realm).users().create(user); // 发送创建请求 [3]
    if (response.getStatus() == Response.Status.CREATED.getStatusCode()) {
        return "Successfully created user: " + username;
    } else {
        Log.error("Failed to create user. Status: " + response.getStatus());
        response.close();
        return "Error creating user: "+" "+username;
    }
}

1 - UserRepresentation类是Admin REST API的一部分,用于在Keycloak领域内管理用户的上下文中表示用户。该类封装了与用户相关的各种属性和属性,允许管理员以编程方式创建、更新和检索用户信息。

2 - CredentialRepresentation类用于表示与用户帐户关联的凭据。该类是Keycloak Admin REST API的一部分,对于管理用户身份验证方法(如密码、OTP和其他凭据类型)至关重要。

3 - 最后,我向Keycloak发送创建用户请求。此部分下面还有一些错误处理,以确保调用工具时,我可以返回正确的状态。

类似地,我还实现了以下两个函数,用于删除用户和按用户名获取用户。

public String deleteUser(String realm, String username)
public UserRepresentation getUserByUsername(String realm, String username)

UserService的完整代码列表可在github上找到。

为了使上述内容成功运行,我还需要做两个操作性的工作。

在属性文件中添加以下行。这意味着我在端口8081上运行我们的本地keycloak实例。

quarkus.keycloak.admin-client.server-url=http://localhost:8081

通过docker-compose的Keycloak开发模式

还有一个用于keycloak的docker-compose.yaml文件,将在本地启动它。它所做的只是以开发模式启动keycloak,并暴露端口8081。目前我正在使用podman运行此文件。

services:
  keycloak:
    image: quay.io/keycloak/keycloak:latest
    container_name: keycloak
    environment:
      - KEYCLOAK_ADMIN=admin
      - KEYCLOAK_ADMIN_PASSWORD=admin
    ports:
      - "8081:8080"
    command: >
      start-dev
    volumes:
      - keycloak_data:/opt/keycloak/data
    restart: unless-stopped

volumes:
  keycloak_data:

要运行上述文件:docker-compose up

创建UserTool

工具是一个组件,通过使LLM能够执行特定操作并与外部系统交互来增强其能力。这可能是API、数据库、内部系统等。这正是我在这里要做的,为keycloak构建工具。我们创建以下流程,其中UserTool将调用UserService,后者又调用Keycloak进行操作。我已经创建了UserService。现在是创建UserTool的时候了。

KeycloakUserServiceUserToolKeycloakUserServiceUserTool
调用UserService(例如,用户/领域/客户端)1
调用Keycloak(获取用户/领域/客户端)2
返回结果(UserRepresentation, RealmRepresentation, ClientRepresentation)3
从UserService返回转换结果为String4

在以下UserTool类中,我注入UserService和ObjectMapper。我使用com.fasterxml.jackson.databind.ObjectMapper将一些结果转换为String,例如List。

public class UserTool {

    @Inject
    UserService userService;

    @Inject
    ObjectMapper mapper;
}

接下来,让我们创建一个MCP服务器可以暴露的工具。

@Tool(description = "Get all users from a keycloak realm") // [1]
String getUsers(@ToolArg(description = "A String denoting the name of the realm where the users reside") String realm) { // [2]
    try {
        return mapper.writeValueAsString(userService.getUsers(realm)); // [3]
    } catch (Exception e) {
        throw new ToolCallException("Failed to get users from realm");
    }
}

1 - @Tool(description = “Get all users from a keycloak realm”)
@Tool:表示getUsers方法被LLM识别为可调用函数或工具。
description描述此工具的作用,例如获取所有用户。当请求从keycloak获取所有用户时,LLM可以调用此工具。

由于LLM可以理解自然语言,所有导致从keycloak获取用户上下文的提问应该*理论上调用此工具。还要注意,如果我添加太多与其他工具描述混淆的细节,LLM可能不会调用所需的工具并最终产生幻觉。应注意如何编写描述。我建议简洁直接,避免歧义和重叠。

2 - ToolArg向LLM指定此工具需要一个参数。在我的情况下,它必须是一个领域。因此,如果用户只说获取所有用户,LLM应该回来询问哪个领域。如上所述,请注意description参数。

3 - 最后,一旦结果从UserService返回,在这种情况下是一个List。我使用ObjectMapper将其转换为String,以便LLM可以理解响应。我也尝试过使用Jsonb,效果也不错。

@Tool(description = "Create a new user in keycloak realm with the following mandatory fields realm, username, firstName, lastName, email, password")  // [1]
String addUser(@ToolArg(description = "A String denoting the name of the realm where the user resides") String realm,  // [2]
               @ToolArg(description = "A String denoting the username of the user to be created") String username,
               @ToolArg(description = "A String denoting the first name of the user to be created") String firstName,
               @ToolArg(description = "A String denoting the last name of the user to be created") String lastName,
               @ToolArg(description = "A String denoting the email of the user to be created") String email,
               @ToolArg(description = "A String denoting the password of the user to be created") String password) {
    return userService.addUser(realm, username, firstName, lastName, email, password);  // [3]
}

1 - 由于这是创建新用户的方法。我指定了需要的确切内容。
2 - 成功执行此工具所需的所有不同参数。
3 - 最后,一旦UserService返回,我将结果传递给LLM进行进一步处理。

打包

我们应该将以下属性添加到application.properties中。

quarkus.package.jar.type=uber-jar # [1]
quarkus.log.file.enable=true # [2]
quarkus.log.file.path=kcadmin-quarkus.log # [3]

1 - 告诉Quarkus创建一个uber jar。Uberjar,也称为"fat jar"或"shadow jar",是一种Java存档文件,包含运行Java应用程序所需的所有依赖项和资源。
2 - 我还想要一个日志文件,以便我可以了解发生了什么。
3 - 日志文件的地址和名称。

mvn clean package

应用程序的完整源代码可以在这里找到。如果您只想运行它的话 😃

使用Goose运行

一个本地的、可扩展的、开源的AI代理,可自动化工程任务。

Goose by block提供了一个CLI工具,具有添加MCP作为扩展的能力。使用goose configure添加LLM配置和API密钥。

一旦CLI配置完成,我现在可以通过将其添加为扩展来添加打包的MCP服务器。

goose session --with-extension="java -jar target/keycloak-mcp-server-1.0.0-SNAPSHOT-runner.jar" 

以下是一些可以提问的示例:

( O)> can I create a new user in keycloak?
是的,您可以在Keycloak中创建新用户。为此,您需要提供以下用户信息:

- **领域**:用户将驻留的领域名称。
- **用户名**:新用户的用户名。
- **名字**:用户的名字。
- **姓氏**:用户的姓氏。
- **电子邮件**:用户的电子邮件地址。
- **密码**:用户帐户的密码。

您可以提供这些详细信息,我可以协助您创建用户。

-
( O)> can you delete user sshaaf from realm quarkus

好的,总结一下。希望您喜欢它,并准备好编写您的第一个MCP服务器实现。

总结

本文探讨了为Keycloak创建一个实用的模型上下文协议服务器,旨在学习并展示其在AI驱动管理方面的潜力。MCP标准化了LLM与外部工具、提示和资源的交互方式,解决了分散的自定义集成问题。文章详细介绍了使用Quarkus和Keycloak Admin REST客户端构建这个实验性Keycloak MCP服务器的过程,重点关注指定领域内的用户管理操作。它提供了UserService和MCP UserTool的代码片段,解释了如何为LLM使用定义工具及其参数。最后,文章展示了如何打包Quarkus应用程序并使用"Goose"(一个AI代理CLI)运行它,以使用自然语言查询与Keycloak交互。示例的源代码可以在这里找到。

资源

  • Goose - https://github.com/block/goose
  • MCP - https://modelcontextprotocol.io/docs/concepts/tools
  • Keycloak MCP Server - 示例 https://github.com/sshaaf/keycloak-mcp-server
  • MCP和调用您的REST API - https://github.com/learnj-ai/llm-jakarta/tree/workshop/step-09-mcp
  • Quarkus - https://quarkus.io/blog/mcp-server/
  • 使用Quarkus创建MCP服务器 - https://iocanel.com/2025/03/creating-an-mcp-server-with-quarkus-and-backstage/
    更多精彩内容 请关注我的个人公众号 公众号(办公AI智能小助手)
    对网络安全、黑客技术感兴趣的朋友可以关注我的安全公众号(网络安全技术点滴分享)

本文地址:https://www.yitenyun.com/3988.html

搜索文章

Tags

#ios面试 #ios弱网 #断点续传 #ios开发 #objective-c #ios #ios缓存 #服务器 #python #pip #conda #远程工作 #kubernetes #笔记 #平面 #容器 #linux #学习方法 香港站群服务器 多IP服务器 香港站群 站群服务器 #Trae #IDE #AI 原生集成开发环境 #Trae AI #分阶段策略 #模型协议 #人工智能 #运维 #kylin #github #git #docker #后端 #数据库 #Conda # 私有索引 # 包管理 #数信院生信服务器 #Rstudio #生信入门 #生信云服务器 #物联网 #websocket #进程控制 #低代码 #爬虫 #音视频 #学习 #内网穿透 #网络 #cpolar #开发语言 #云原生 #iventoy #VmWare #OpenEuler #MobaXterm #ubuntu #Dell #PowerEdge620 #内存 #硬盘 #RAID5 #华为云 #部署上线 #动静分离 #Nginx #新人首发 #vscode #mobaxterm #深度学习 #计算机视觉 #node.js #fastapi #html #css #unity #c# #游戏引擎 #FTP服务器 #开源 #hadoop #hbase #hive #zookeeper #spark #kafka #flink #算法 #大数据 #科技 #自然语言处理 #神经网络 #缓存 #golang #java #redis #银河麒麟高级服务器操作系统安装 #银河麒麟高级服务器V11配置 #设置基础软件仓库时出错 #银河麒高级服务器系统的实操教程 #生产级部署银河麒麟服务系统教程 #Linux系统的快速上手教程 #harmonyos #鸿蒙PC #安全 #nginx #tcp/ip #vllm #大模型 #Streamlit #Qwen #本地部署 #AI聊天机器人 #RTP over RTSP #RTP over TCP #RTSP服务器 #RTP #TCP发送RTP #我的世界 #web安全 #需求分析 #centos #ssh #ide #华为 #ModelEngine #jvm #android #腾讯云 #udp #电脑 #自动化 #jmeter #功能测试 #软件测试 #自动化测试 #职场和发展 #prometheus #gpu算力 #grafana #qt #c++ #asp.net大文件上传 #asp.net大文件上传下载 #asp.net大文件上传源码 #ASP.NET断点续传 #asp.net上传文件夹 #ping通服务器 #读不了内网数据库 #bug菌问答团队 #jar #架构 #mcu #asp.net #面试 #flask #http #fiddler #分布式 #银河麒麟 #系统升级 #信创 #国产化 #jenkins #多个客户端访问 #IO多路复用 #回显服务器 #TCP相关API #AI编程 #计算机网络 #编辑器 #研发管理 #禅道 #禅道云端部署 #RAID #RAID技术 #磁盘 #存储 #elasticsearch #性能优化 #C++ #课程设计 #凤希AI伴侣 #云计算 #c语言 #stm32 #json #openlayers #bmap #tile #server #vue #spring boot #vuejs #eBPF #网络协议 #Harbor #todesk #uni-app #小程序 #notepad++ #信令服务器 #Janus #MediaSoup #ansible #流媒体 #NAS #飞牛NAS #监控 #NVR #EasyNVR #游戏 #MC #windows #数据结构 #链表 #链表的销毁 #链表的排序 #链表倒置 #判断链表是否有环 #flutter #数码相机 #SSH #X11转发 #Miniconda #sqlserver #debian #改行学it #创业创新 #程序员创富 #MCP #MCP服务器 #儿童书籍 #儿童诗歌 #童话故事 #经典好书 #儿童文学 #好书推荐 #经典文学作品 #deepseek #cpp #项目 #高并发 #LoRA # RTX 3090 # lora-scripts #1024程序员节 #php #前端 #claude #arm开发 #企业开发 #ERP #项目实践 #.NET开发 #C#编程 #编程与数学 #gemini #gemini国内访问 #gemini api #gemini中转搭建 #Cloudflare #mysql #screen 命令 #mvp #个人开发 #设计模式 #AI论文写作工具 #学术论文创作 #论文效率提升 #MBA论文写作 #DisM++ # GLM-4.6V # 系统维护 #金融 #mcp #金融投资Agent #Agent #京东云 #版本控制 #Git入门 #开发工具 #代码托管 #AIGC #ida #制造 #个人博客 #深度优先 #DFS #svn #n8n #嵌入式编译 #ccache #distcc #毕设 #vue.js #ollama #ai #llm #智能路由器 #django #RustDesk #IndexTTS 2.0 #本地化部署 #毕业设计 #车辆排放 #oracle #SA-PEKS # 关键词猜测攻击 # 盲签名 # 限速机制 #树莓派4b安装系统 #我的世界服务器搭建 #minecraft #Spring AI #STDIO协议 #Streamable-HTTP #McpTool注解 #服务器能力 #Android #Bluedroid #时序数据库 #智能手机 #Ansible #Playbook #AI服务器 #AI #大模型学习 #javascript #压力测试 #ui #libosinfo #ssl #openEuler #Hadoop #单片机 #嵌入式硬件 #TCP #客户端 #嵌入式 #DIY机器人工房 #WEB #maven #gitlab #语音识别 #说话人验证 #声纹识别 #CAM++ #laravel #diskinfo # TensorFlow # 磁盘健康 #windows11 #microsoft #系统修复 #流量监控 #高级IO #select #算力一体机 #ai算力服务器 #微服务 #p2p #Windows #gitea #macos #idm #网站 #截图工具 #批量处理图片 #图片格式转换 #图片裁剪 #万悟 #联通元景 #智能体 #镜像 #结构体 #scala #测试用例 #测试工具 #tomcat #webrtc #Android16 #音频性能实战 #音频进阶 #微信小程序 #微信 #健身房预约系统 #健身房管理系统 #健身管理系统 #密码学 #阿里云 #SSE # AI翻译机 # 实时翻译 #1panel #vmware #apache #r-tree #聊天小程序 #鸭科夫 #逃离鸭科夫 #鸭科夫联机 #鸭科夫异地联机 #开服 #北京百思可瑞教育 #百思可瑞教育 #北京百思教育 #无人机 #Deepoc #具身模型 #开发板 #未来 #web #webdav #NFC #智能公交 #服务器计费 #数据挖掘 #FP-增长 #risc-v #pytorch #tdengine #涛思数据 #PyTorch #CUDA #Triton #交互 #SSH公钥认证 # PyTorch # 安全加固 #ci/cd #Proxmox VE #虚拟化 #VMware #spring #部署 #GPU服务器 #8U #硬件架构 #语言模型 #DeepSeek #昇腾300I DUO #NPU #CANN #搜索引擎 #opencv #cosmic #运维开发 #网络安全 #扩展屏应用开发 #android runtime #H5 #跨域 #发布上线后跨域报错 #请求接口跨域问题解决 #跨域请求代理配置 #request浏览器跨域 #黑群晖 #虚拟机 #无U盘 #纯小白 #支付 #远程桌面 #远程控制 #东方仙盟 #游戏机 #JumpServer #堡垒机 #API限流 # 频率限制 # 令牌桶算法 #VS Code调试配置 #iBMC #UltraISO #bash #振镜 #振镜焊接 #teamviewer #蓝湖 #Axure原型发布 #lua #llama #单元测试 #集成测试 #tensorflow #arm #YOLO # Triton # 目标检测 #pycharm #muduo库 #uv #uvx #uv pip #npx #Ruff #pytest #web server #请求处理流程 #SRS #直播 #蓝耘智算 #信息可视化 #claude code #codex #code cli #ccusage #milvus #springboot #知识库 #910B #昇腾 #react.js #aws #Anaconda配置云虚拟环境 #MQTT协议 #Ascend #MindIE #政务 #rocketmq #selenium #守护进程 #复用 #screen #系统架构 # 双因素认证 #Clawdbot #个人助理 #数字员工 #jupyter #rustdesk #postgresql #连接数据库报错 #unity3d #服务器框架 #Fantasy #源码 #闲置物品交易系统 #umeditor粘贴word #ueditor粘贴word #ueditor复制word #ueditor上传word图片 #YOLOFuse # Base64编码 # 多模态检测 #经验分享 #安卓 #IPv6 #DNS #进程 #操作系统 #进程创建与终止 #shell #SPA #单页应用 #web3.py #YOLOv8 # Docker镜像 #麒麟OS #jetty #swagger #visual studio code #java-ee #transformer #prompt #计算机 #nas #mamba #LangGraph #CLI #Python #JavaScript #langgraph.json # 高并发部署 #sqlite #chatgpt #journalctl #epoll #电气工程 #C# #PLC #视频去字幕 #webpack #openresty #学术写作辅助 #论文创作效率提升 #AI写论文实测 #wordpress #雨云 #负载均衡 #翻译 #开源工具 #sql #intellij-idea #大模型部署 #mindie #大模型推理 #业界资讯 #esp32教程 #模版 #函数 #类 #笔试 #Go并发 #高并发架构 #Goroutine #系统设计 #Dify #ARM架构 #鲲鹏 #.net #net core #kestrel #web-server #asp.net-core #langchain #大模型开发 #程序员 #OPCUA #简单数论 #埃氏筛法 #SSH Agent Forwarding # 容器化 #数据分析 #SSH反向隧道 # Miniconda # Jupyter远程访问 #agi #集成学习 #serverless #EMC存储 #存储维护 #NetApp存储 #青少年编程 #eureka #C语言 #mongodb #cursor #yum #uvicorn #uvloop #asgi #event #cesium #可视化 #https #homelab #Lattepanda #Jellyfin #Plex #Emby #Kodi #yolov12 #研究生life #三维 #3D #三维重建 #PTP_1588 #gPTP #rtsp #转发 #CPU利用率 #Termux #Samba #Linux #fpga开发 #CVE-2025-61686 #漏洞 #路径遍历高危漏洞 #neo4j #NoSQL #SQL #Llama-Factory # 大模型推理 #rust #echarts #GPU #AutoDL ##租显卡 #进程等待 #wait #waitpid #前端框架 #reactjs #web3 #HeyGem # 服务器IP # 端口7860 #pdf #大模型教程 #AI大模型 # 自动化部署 # VibeThinker #Aluminium #Google # GPU租赁 # 自建服务器 #硬件工程 #Ubuntu服务器 #硬盘扩容 #命令行操作 #SMTP # 内容安全 # Qwen3Guard #web服务器 #MinIO服务器启动与配置详解 #clickhouse #H5网页 #网页白屏 #H5页面空白 #资源加载问题 #打包部署后网页打不开 #HBuilderX #CTF #VMWare Tool #agent #ai大模型 #心理健康服务平台 #心理健康系统 #心理服务平台 #心理健康小程序 #arm64 #插件 #开源软件 #DHCP #散列表 #哈希算法 #串口服务器 #Modbus #MOXA #模型上下文协议 #MultiServerMCPC #load_mcp_tools #load_mcp_prompt #GATT服务器 #蓝牙低功耗 #ms-swift # 一锤定音 # 大模型微调 #VMware Workstation16 #服务器操作系统 #adb #论文笔记 #硬件 #leetcode #ShaderGraph #图形 #dify #信号处理 #PowerBI #企业 #MS #Materials #idea #intellij idea #c++20 #能源 #markdown #建站 #googlecloud #5G #vnstat #memcache #文心一言 #AI智能体 #大剑师 #nodejs面试题 #vp9 #C2000 #TI #实时控制MCU #AI服务器电源 #攻防演练 #Java web #红队 # 树莓派 # ARM架构 #GB28181 #SIP信令 #SpringBoot #视频监控 #WT-2026-0001 #QVD-2026-4572 #smartermail #数据仓库 #银河麒麟操作系统 #openssh #华为交换机 #信创终端 #驱动开发 #UDP的API使用 #处理器 #飞牛nas #fnos #Modbus-TCP #智能体来了 #智能体对传统行业冲击 #行业转型 #AI赋能 #系统管理 #服务 #机器学习 #推荐算法 #ambari #elk #Socket网络编程 #管道Pipe #system V #RAG #LLM #chat #azure #YOLO26 #目标检测 #muduo #TcpServer #accept #高并发服务器 #远程开发 #SAP #ebs #metaerp #oracle ebs #log # 高并发 #系统安全 #postman #国产化OS #浏览器自动化 #python #html5 #excel #计算几何 #斜率 #方向归一化 #叉积 #copilot # 批量管理 #chrome #微PE #硬盘克隆 #DiskGenius #glibc #媒体 #SSH免密登录 # CUDA #交通物流 #vivado license #手机h5网页浏览器 #安卓app #苹果ios APP #手机电脑开启摄像头并排查 #ARM服务器 # 多模态推理 #IO #统信UOS #win10 #qemu #fabric #可信计算技术 #openHiTLS #TLCP #DTLCP #商用密码算法 #ONLYOFFICE #MCP 服务器 #ArkUI #ArkTS #鸿蒙开发 #CPU #测评 #CCE #Dify-LLM #Flexus #Nacos #服务器繁忙 #powerbi #go #win11 #puppeteer #KMS #slmgr #spine #智能家居 #POC #问答 #交付 #xlwings #Excel #mybatis #实时音视频 #spring cloud #bootstrap #nfs #iscsi #文件IO #输入输出流 #文件管理 #文件服务器 #信息与通信 #tcpdump #embedding #Host #渗透测试 #SSRF #kmeans #聚类 # 大模型 # 模型训练 #scanf #printf #getchar #putchar #cin #cout #大语言模型 #Java #程序人生 #蓝桥杯 #paddleocr #企业级存储 #网络设备 #Smokeping #pve #分类 #CMake #Make #C/C++ #pencil #pencil.dev #设计 #ddos #vps #zotero #WebDAV #同步失败 #代理模式 #工具集 #大模型应用 #API调用 #PyInstaller打包运行 #服务端部署 #java大文件上传 #java大文件秒传 #java大文件上传下载 #java文件传输解决方案 #排序算法 #jdk #排序 #PyCharm # 远程调试 # YOLOFuse # REST API # GLM-4.6V-Flash-WEB #欧拉 # keep-alive #aiohttp #asyncio #异步 #软件 #本地生活 #电商系统 #商城 #.netcore # IndexTTS 2.0 # 自动化运维 #全链路优化 #实战教程 #儿童AI #图像生成 #星图GPU # 模型微调 #LobeChat #vLLM #GPU加速 #麒麟 #SSH保活 #rdp #everything #AB包 #iphone #海外服务器安装宝塔面板 #Zabbix #CosyVoice3 #语音合成 #FASTMCP #ZooKeeper #ZooKeeper面试题 #面试宝典 #深入解析 #ComfyUI # 推理服务器 #n8n解惑 #Tracker 服务器 #响应最快 #torrent 下载 #2026年 #Aria2 可用 #迅雷可用 #BT工具通用 #rabbitmq #esp32 arduino #duckdb #高斯溅射 # 语音合成 #产品运营 #Puppet # IndexTTS2 # TTS #联机教程 #局域网联机 #局域网联机教程 #局域网游戏 #模拟退火算法 #云服务器 #个人电脑 #广播 #组播 #并发服务器 #x86_64 #数字人系统 #MC群组服务器 #gpu #nvcc #cuda #nvidia #其他 #TensorRT # 推理优化 #unix #编程 #c++高并发 #百万并发 #机器人 #zabbix #CS2 #debian13 #Jetty # CosyVoice3 # 嵌入式服务器 #信创国产化 #达梦数据库 #RXT4090显卡 #RTX4090 #深度学习服务器 #硬件选型 #IntelliJ IDEA #Spring Boot #SQL注入主机 #uip #k8s #wsl #树莓派 #温湿度监控 #WhatsApp通知 #IoT #MySQL #建筑缺陷 #红外 #数据集 #Kylin-Server #国产操作系统 #服务器安装 #AI技术 #LangFlow # 智能运维 # 性能瓶颈分析 #VibeVoice # 云服务器 #devops #戴尔服务器 #戴尔730 #装系统 #junit #黑客技术 #文件上传漏洞 #ThingsBoard MCP #代理 #平板 #零售 #智能硬件 #vncdotool #链接VNC服务器 #如何隐藏光标 # 服务器IP访问 # 端口映射 #A2A #GenAI #gateway #Comate #遛狗 #bug #FHSS #eclipse #servlet #自动化运维 #服务器解析漏洞 #nodejs #UOS #海光K100 #统信 #算力建设 #数据安全 #注入漏洞 #VPS #搭建 #智慧校园解决方案 #智慧校园一体化平台 #智慧校园选型 #智慧校园采购 #智慧校园软件 #智慧校园专项资金 #智慧校园定制开发 #wpf #ffmpeg #SSH密钥 # ControlMaster #练习 #基础练习 #数组 #循环 #九九乘法表 #计算机实现 #dynadot #域名 #ETL管道 #向量存储 #数据预处理 #DocumentReader #esb接口 #走处理类报异常 #firefox #safari #le audio #蓝牙 #低功耗音频 #通信 #连接 #memory mcp #Cursor #网路编程 #smtp #smtp服务器 #PHP #银河麒麟部署 #银河麒麟部署文档 #银河麒麟linux #银河麒麟linux部署教程 # 远程连接 #Buck #NVIDIA #算力 #交错并联 #DGX #Qwen3-14B # 大模型部署 # 私有化AI #AI 推理 #NV #ue5 #ServBay #SFTP # WebUI # 网络延迟 #指针 #策略模式 #matlab #anaconda #虚拟环境 #ranger #MySQL8.0 #SSH跳板机 # Python3.11 #LVDS #高速ADC #DDR #bond #服务器链路聚合 #网卡绑定 #word #ESP32 # OTA升级 # 黄山派 #ansys #ansys问题解决办法 #screen命令 #mariadb # Connection refused #Gunicorn #WSGI #Flask #并发模型 #容器化 #性能调优 #视频 #性能测试 #LoadRunner #雨云服务器 #Minecraft服务器 #教程 #MCSM面板 #ceph #门禁 #梯控 #智能一卡通 #门禁一卡通 #消费一卡通 #智能梯控 #一卡通 #源代码管理 #超时设置 #客户端/服务器 #网络编程 #挖矿 #Linux病毒 #sql注入 #ai编程 #鸿蒙 # 服务器配置 # GPU #数据恢复 #视频恢复 #视频修复 #RAID5恢复 #流媒体服务器恢复 #AI-native #Gateway #认证服务器集成详解 #框架搭建 #状态模式 #dba #Tokio #计组 #数电 #react native #CVE-2025-68143 #CVE-2025-68144 #CVE-2025-68145 #工程设计 #预混 #扩散 #燃烧知识 #层流 #湍流 #weston #x11 #x11显示服务器 #WinSCP 下载安装教程 #FTP工具 #服务器文件传输 # 批量部署 #Xshell #Finalshell #生信 #生物信息学 #组学 #RSO #机器人操作系统 #ASR #SenseVoice # TTS服务器 # 键鼠锁定 #中间件 #远程连接 #node #上下文工程 #langgraph #意图识别 #证书 #scrapy #AI写作 #winscp #后端框架 #参数估计 #矩估计 #概率论 # 数字人系统 # 远程部署 #视觉检测 #visual studio #传感器 #MicroPython #RK3576 #瑞芯微 #硬件设计 #LE Audio #BAP #Docker #Node.js # child_process #iot #gRPC #注册中心 #scikit-learn #随机森林 #安全威胁分析 #c #仙盟创梦IDE #运维工具 #GLM-4.6V-Flash-WEB # AI视觉 # 本地部署 #网络攻击模型 #动态规划 #pyqt #dlms #dlms协议 #逻辑设备 #逻辑设置间权限 #r语言 #智慧城市 #企业微信 #3d #Minecraft #PaperMC #我的世界服务器 #ipmitool #BMC # 黑屏模式 #C #STDIO传输 #SSE传输 #WebMVC #WebFlux #IndexTTS2 # 阿里云安骑士 # 木马查杀 #kong #Kong Audio #Kong Audio3 #KongAudio3 #空音3 #空音 #中国民乐 #入侵 #日志排查 #人大金仓 #Kingbase #小艺 #搜索 #Spring AOP #Keycloak #Quarkus #AI编程需求分析 #hibernate #多进程 #python技巧 #多模态 #微调 #超参 #LLamafactory #es安装 #产品经理 #就业 #Java程序员 #Java面试 #后端开发 #Spring源码 #Spring #模型训练 #V11 #kylinos #raid #raid阵列 #KMS激活 #numpy #CSDN #论文阅读 #软件工程 #Langchain-Chatchat # 国产化服务器 # 信创 #database #pjsip #blender #warp #数字化转型 #实体经济 #商业模式 #软件开发 #数智红包 #商业变革 #创业干货 #人脸识别sdk #视频编解码 #人脸识别 #决策树 #HistoryServer #Spark #YARN #jobhistory #DooTask #sglang #防毒面罩 #防尘面罩 #编程助手 #电子电气架构 #系统工程与系统架构的内涵 #自动驾驶 #汽车 #Routine #m3u8 #HLS #移动端H5网页 #APP安卓苹果ios #监控画面 直播视频流 #Prometheus #挖漏洞 #日志分析 #交换机 #三层交换机 #UEFI #BIOS #Legacy BIOS #内存接口 # 澜起科技 # 服务器主板 # 显卡驱动备份 #Socket #计算机毕业设计 #程序定制 #毕设代做 #课设 #开关电源 #热敏电阻 #PTC热敏电阻 #文件传输 #电脑文件传输 #电脑传输文件 #电脑怎么传输文件到另一台电脑 #电脑传输文件到另一台电脑 #身体实验室 #健康认知重构 #系统思维 #微行动 #NEAT效应 #亚健康自救 #ICT人 #云开发 #性能 #优化 #RAM #KMS 激活 #AI智能棋盘 #Rock Pi S #边缘计算 #wireshark #nacos #银河麒麟aarch64 # 服务器迁移 # 回滚方案 #大模型入门 #云计算运维 #asp.net上传大文件 #coffeescript #漏洞挖掘 #gpt #数学建模 #SSH别名 #寄存器 #BoringSSL #企业存储 #RustFS #对象存储 #高可用 #log4j #模块 # 公钥认证 # 权限修复 #STUN #turn #ICE #群晖 #音乐 # ARM服务器 # 鲲鹏 #http头信息 #Coturn #TURN #H3C # 代理转发 # 跳板机 # HiChatBox # 离线AI #TCP服务器 #开发实战 #SMARC #ARM #全文检索 #银河麒麟服务器系统 #Reactor #Shiro #反序列化漏洞 #CVE-2016-4437 #短剧 #短剧小程序 #短剧系统 #微剧 #空间计算 #原型模式 #nosql #tcp/ip #网络 #可撤销IBE #服务器辅助 #私钥更新 #安全性证明 #双线性Diffie-Hellman #数据访问 #I/O模型 #并发 #水平触发、边缘触发 #多路复用 #CNAS #CMA #程序文件 #SSH复用 # 远程开发 #高仿永硕E盘的个人网盘系统源码 #磁盘配额 #存储管理 #形考作业 #国家开放大学 #系统运维 #网络安全大赛 #C++ UA Server #SDK #跨平台开发 #云服务器选购 #Saas #线程 #机器视觉 #6D位姿 #outlook #错误代码2603 #无网络连接 #2603 #mssql #实时检测 #卷积神经网络 #lucene #DAG #支持向量机 #b树 #具身智能 #Fun-ASR # 语音识别 #HarmonyOS APP #密码 #windbg分析蓝屏教程 #国产PLM #瑞华丽PLM #瑞华丽 #PLM #AI电商客服 #spring ai #oauth2 #数据可视化 #nmodbus4类库使用教程 #docker-compose #目标跟踪 #rtmp #声源定位 #MUSIC #fs7TF # 远程访问 #xml #ROS # 局域网访问 # 批量处理 #统信操作系统 #内存治理 #游戏美术 #技术美术 #游戏策划 #游戏程序 #用户体验 #IFix # 高温监控 #TLS协议 #HTTPS #漏洞修复 #运维安全 #gerrit #opc ua #opc #npu # 环境迁移 #matplotlib #安全架构 #idc #远程软件 # GLM-TTS # 数据安全 #xshell #host key # 远程运维 #数据报系统 #TTS私有化 # IndexTTS # 音色克隆 #内网 #程序开发 #程序设计 #大作业 #2026年美赛C题代码 #2026年美赛 #设计师 #图像处理 #量子计算 #分布式数据库 #集中式数据库 #业务需求 #选型误 #代理服务器 #rsync # 数据同步 #ip #智能制造 #供应链管理 #工业工程 #库存管理 #Apple AI #Apple 人工智能 #FoundationModel #Summarize #SwiftUI #多线程 #海外短剧 #海外短剧app开发 #海外短剧系统开发 #短剧APP #短剧APP开发 #短剧系统开发 #海外短剧项目 #claudeCode #content7 #跳槽 #工作 #网安应急响应 #odoo # GLM # 服务连通性 #HarmonyOS #晶振 #WinDbg #Windows调试 #内存转储分析 # 串口服务器 # NPort5630 #appche #TTS #重构 #AI视频创作系统 #AI视频创作 #AI创作系统 #AI视频生成 #AI工具 #文生视频 #AI创作工具 # GPU集群 #服务器开启 TLS v1.2 #IISCrypto 使用教程 #TLS 协议配置 #IIS 安全设置 #服务器运维工具 #ftp #sftp #uniapp #合法域名校验出错 #服务器域名配置不生效 #request域名配置 #已经配置好了但还是报错 #uniapp微信小程序 #华为od #华为od机试 #华为od机考 #华为od最新上机考试题库 #华为OD题库 #华为OD机试双机位C卷 #od机考题库 #YOLO识别 #YOLO环境搭建Windows #YOLO环境搭建Ubuntu # 轻量化镜像 # 边缘计算 #华为机试 #OpenHarmony #Python办公自动化 #Python办公 #SSH跳转 #套接字 #I/O多路复用 #字节序 #samba #mtgsig #美团医药 #美团医药mtgsig #美团医药mtgsig1.2 #opc模拟服务器 #cpu #服务器线程 # SSL通信 # 动态结构体 #RWK35xx #语音流 #实时传输 #clawdbot #超算中心 #PBS #lsf #报表制作 #职场 #用数据讲故事 #梯控一卡通 #电梯一卡通 #考勤一卡通 #语音生成 #AI部署 # ms-swift #PN 结 #JNI #pxe #Matrox MIL #二次开发 #数据采集 #浏览器指纹 #vertx #vert.x #vertx4 #runOnContext #lvs #adobe # TURN # NAT穿透 #MCP服务器注解 #异步支持 #方法筛选 #声明式编程 #自动筛选机制 #WRF #WRFDA #数据迁移 #MinIO #麦克风权限 #访问麦克风并录制音频 #麦克风录制音频后在线播放 #用户拒绝访问麦克风权限怎么办 #uniapp 安卓 苹果ios #将音频保存本地或上传服务器 #机器人学习 #express #cherry studio #gmssh #宝塔 #Exchange #free #vmstat #sar #sentinel #宝塔面板部署RustDesk #RustDesk远程控制手机 #手机远程控制 #系统安装 #铁路桥梁 #DIC技术 #箱梁试验 #裂纹监测 #四点弯曲 #可再生能源 #绿色算力 #风电 #视觉理解 #Moondream2 #多模态AI #若依 #TRO #TRO侵权 #TRO和解 #Discord机器人 #云部署 #程序那些事 #AI应用编程 #服务器IO模型 #非阻塞轮询模型 #多任务并发模型 #异步信号模型 #多路复用模型 #UDP套接字编程 #UDP协议 #网络测试 #前端开发 #EN4FE #勒索病毒 #勒索软件 #加密算法 #.bixi勒索病毒 #数据加密 #领域驱动 #CA证书 #自由表达演说平台 #演说 #移动端h5网页 #调用浏览器摄像头并拍照 #开启摄像头权限 #拍照后查看与上传服务器端 #摄像头黑屏打不开问题 #AI Agent #开发者工具 #流程图 #图论 #国产开源制品管理工具 #Hadess #一文上手 #工业级串口服务器 #串口转以太网 #串口设备联网通讯模块 #串口服务器选型 #okhttp #范式 #计算机外设 #webgl #区块链 #Karalon #AI Test #remote-ssh #健康医疗 #ET模式 #非阻塞 #高考 #工程实践 #租显卡 #训练推理 #AI应用 #测速 #iperf #iperf3 #图像识别 #Linux多线程 #bigtop #hdp #hue #kerberos #轻量化 #低配服务器 #Beidou #北斗 #SSR #Anything-LLM #IDC服务器 #私有化部署 #Ubuntu #ESP32编译服务器 #Ping #DNS域名解析 #API #taro #wps #simulink #docker安装seata #面向对象 #基础语法 #标识符 #常量与变量 #数据类型 #运算符与表达式 #信息安全 #信息收集 #poll #生产服务器问题查询 #日志过滤 #Autodl私有云 #深度服务器配置 # 水冷服务器 # 风冷服务器 #VoxCPM-1.5-TTS # 云端GPU # PyCharm宕机 #主板 #总体设计 #电源树 #框图 #传统行业 #Syslog #系统日志 #日志监控 #stl #IIS Crypto # AI部署 #材料工程 #智能电视 #VMware创建虚拟机 #远程更新 #缓存更新 #多指令适配 #物料关联计划 #数模美赛 #AI生成 # outputs目录 # 自动化 #攻击溯源 #starrocks #二值化 #Canny边缘检测 #轮廓检测 #透视变换 #人脸活体检测 #live-pusher #动作引导 #张嘴眨眼摇头 #苹果ios安卓完美兼容 #OSS #L6 #L10 #L9 #ipv6 #阿里云RDS #composer #symfony #java-zookeeper #软件需求 #项目申报系统 #项目申报管理 #项目申报 #企业项目申报 #dubbo #新浪微博 #传媒 #DuckDB #协议 #汇编 #思爱普 #SAP S/4HANA #ABAP #NetWeaver #typescript #npm #xss #Ward #音诺ai翻译机 #AI翻译机 # Ampere Altra Max #考研 #WAN2.2 #日志模块 #Arduino BLDC #核辐射区域探测机器人 #电梯 #电梯运力 #电梯门禁 #esp32 #mosquito # GPU服务器 # tmux #RK3588 #RK3588J #评估板 #核心板 #嵌入式开发 #VSCode # Qwen3Guard-Gen-8B #resnet50 #分类识别训练 #运维 #Python3.11 #反向代理 #AI工具集成 #容器化部署 #分布式架构 #2025年 #FRP #edge #迭代器模式 #观察者模式 # IP配置 # 0.0.0.0 #自动化巡检 #0day漏洞 #DDoS攻击 #漏洞排查 #静脉曲张 #腿部健康 #运动 #CS336 #Assignment #Experiments #TinyStories #Ablation #边缘AI # Kontron # SMARC-sAMX8 #vue上传解决方案 #vue断点续传 #vue分片上传下载 #vue分块上传下载 #ossinsight #AE #rag #OpenAI #故障 #jquery #节日 #fork函数 #进程创建 #进程终止 #分子动力学 #化工仿真 #小智 #游戏服务器断线 #期刊 #SCI #session #restful #ajax #Linly-Talker # 数字人 # 服务器稳定性 #JADX-AI 插件 #隐私合规 #网络安全保险 #法律风险 #风险管理