最新资讯

  • WebLogic服务器中JMS消息服务集成实战详解

WebLogic服务器中JMS消息服务集成实战详解

2026-02-04 04:14:00 栏目:最新资讯 4 阅读

本文还有配套的精品资源,点击获取

简介:WebLogic Server是Oracle提供的主流Java企业级中间件,广泛用于部署高可用、可扩展的分布式应用。JMS(Java Message Service)作为标准消息传递API,支持异步通信与系统解耦。本文结合源码与工具实践,深入讲解如何在WebLogic中配置和使用JMS服务,涵盖队列、主题、消息驱动Bean(MDB)、事务管理及安全机制等内容。通过“src”源码目录与“lib”依赖库的实际结构,帮助开发者掌握JMS资源创建、消息收发、集群容错与性能调优等关键技能,构建高效稳定的 enterprise 级消息系统。

1. WebLogic与JMS集成概述

WebLogic Server作为企业级Java EE应用服务器,内置了高性能的JMS消息引擎,支持可靠、可扩展的消息传递。JMS(Java Message Service)是Java平台标准的消息中间件API,用于实现异步通信与解耦架构。WebLogic通过其JMS服务提供队列(Queue)和主题(Topic)两种消息模型,支持持久化、事务、安全控制及集群高可用等企业级特性。本章将为后续配置与开发奠定理论基础。

2. JMS模块配置与核心资源创建

在企业级Java应用中,消息中间件是实现异步通信、系统解耦和高可用架构的核心组件。Oracle WebLogic Server作为成熟的Java EE容器,内置了强大的JMS(Java Message Service)支持能力,能够为分布式系统提供稳定的消息传递服务。要充分发挥WebLogic的JMS功能,必须正确配置JMS模块及相关核心资源——包括JMS服务器、连接工厂(ConnectionFactory)、目的地(Destination)等。本章将深入探讨如何通过WebLogic控制台或WLST脚本完成这些关键资源的创建与优化配置,并结合实际场景分析其背后的运行机制。

合理的JMS资源配置不仅影响系统的性能与可靠性,还直接决定消息是否能被持久化存储、是否具备故障转移能力以及能否满足高并发需求。特别是在微服务架构日益普及的今天,基于队列或主题的消息驱动模式已成为跨服务通信的标准方式之一。因此,掌握JMS模块的配置方法,是构建可扩展、容错性强的企业级消息系统的前提条件。

我们将从底层基础设施开始,逐步构建完整的JMS环境。首先介绍JMS服务器的配置过程,重点说明如何绑定持久化存储以确保消息不丢失;接着详细阐述JMS模块的创建流程及连接工厂的属性设置;然后深入讲解队列与主题的管理策略,涵盖配额控制、转发规则等高级特性;最后搭建测试环境并验证整个配置的有效性,确保后续开发和部署工作可以顺利进行。

2.1 JMS服务器配置

JMS服务器是WebLogic平台上承载所有JMS操作的运行时实体。它负责管理消息的存储、传输、分发以及与目的地之间的交互。一个JMS服务器必须关联到特定的WebLogic服务器实例或集群成员上,并且通常需要绑定一个持久化存储来保证消息的可靠传递,尤其是在发生服务器宕机的情况下仍能恢复未处理的消息。

2.1.1 创建JMS服务器并绑定持久化存储

在WebLogic中,JMS服务器本身并不自动创建,必须手动定义。创建过程中最关键的一步是为其指定一个持久化存储(Persistent Store),用于保存持久化消息。若未配置持久化存储,JMS服务器只能处理非持久化消息,一旦服务器重启,所有未消费的消息将会丢失。

持久化存储类型选择

WebLogic支持两种类型的持久化存储:

存储类型 描述 适用场景
文件存储(File Store) 使用文件系统存储消息数据,配置简单,适合中小规模应用 单节点环境、开发测试环境
JDBC存储(JDBC Store) 将消息写入数据库表中,依赖外部数据库(如Oracle、MySQL) 高可用集群环境,要求强一致性

推荐在生产环境中使用 JDBC Store ,因为它更容易集成到集群环境中,支持共享存储,从而实现跨服务器的消息恢复。

创建文件持久化存储示例(控制台方式)
  1. 登录WebLogic Admin Console。
  2. 导航至 Services > Persistent Stores > New > File Store
  3. 输入名称 MyFileStore ,选择目标服务器(例如 Server-0 )。
  4. 设置目录路径(如 /u01/oracle/stores/jms ),点击“Finish”。
# 目录需提前创建并赋予WebLogic进程读写权限
mkdir -p /u01/oracle/stores/jms
chown oracle:oracle /u01/oracle/stores/jms
WLST脚本自动化创建JMS服务器与文件存储

以下是一个完整的WLST Python脚本,用于批量创建文件存储和JMS服务器:

connect('weblogic', 'welcome1', 't3://localhost:7001')

edit()
startEdit()

try:
    # 创建File Store
    cd('/')
    cmo.createFileStore('MyFileStore')

    cd('/FileStores/MyFileStore')
    cmo.setDirectory('/u01/oracle/stores/jms')
    cmo.addTarget(getMBean('/Servers/Server-0'))

    # 创建JMS Server并绑定Store
    cd('/')
    cmo.createJMSServer('MyJMSServer')

    cd('/JMSServers/MyJMSServer')
    cmo.setPersistentStore(getMBean('/FileStores/MyFileStore'))
    cmo.addTarget(getMBean('/Servers/Server-0'))

    save()
    activate()
    print("✅ JMS Server 和 File Store 创建成功")
except Exception as e:
    print("❌ 配置失败:", str(e))
    cancelEdit('y')

代码逻辑逐行解读:

  • connect() :连接到WebLogic管理服务器。
  • edit()/startEdit() :开启配置编辑会话。
  • createFileStore() :在域级别创建一个新的文件存储对象。
  • setDirectory() :指定该存储使用的本地文件路径。
  • addTarget() :将存储绑定到具体的服务器实例。
  • createJMSServer() :创建JMS服务器实例。
  • setPersistentStore() :将之前创建的File Store赋给JMS服务器,启用持久化能力。
  • save()/activate() :提交更改并生效。

参数说明:
- MyFileStore :自定义名称,用于标识存储。
- /u01/oracle/stores/jms :应确保存在且权限正确。
- Server-0 :目标托管服务器名,需已存在。

消息持久化流程图(Mermaid)
graph TD
    A[生产者发送持久化消息] --> B[JMS Server接收消息]
    B --> C{是否配置 Persistent Store?}
    C -- 是 --> D[写入File Store或JDBC Store]
    C -- 否 --> E[仅存于内存,重启即丢]
    D --> F[消息落盘成功]
    F --> G[通知生产者ACK]
    G --> H[等待消费者拉取消息]
    H --> I[消费后从Store删除]

此流程清晰地展示了消息从发送到落盘再到消费的完整路径,强调了持久化存储的关键作用。

2.1.2 配置JMS服务器的高可用与负载均衡策略

在企业级部署中,单点JMS服务器存在明显的可用性风险。为了提升系统的鲁棒性,必须通过集群部署和故障转移机制实现高可用(HA)。WebLogic允许将多个JMS服务器分布在不同的Managed Server上,并借助 通用JMS服务器(Uniform Distributed Destination, UDD) 实现负载均衡与自动故障切换。

集群中的JMS服务器部署模型
部署模式 特点 推荐场景
独立JMS服务器 每个Managed Server拥有独立JMS Server 简单应用,无需集群
均匀分布目的地(UDD) 自动在集群节点间分布队列/主题 高并发、高可用系统
共享持久化存储(Shared Store) 多个JMS服务器共享同一JDBC Store 跨节点消息恢复
使用JDBC Store实现共享存储(高可用基础)

当JMS服务器部署在集群中时,建议使用 JDBC Store 而非File Store,因为后者无法被多个服务器同时访问。

-- 示例:为JDBC Store准备Oracle数据库表结构
CREATE TABLE WLS_JDBC_STORE (
    ID NUMBER PRIMARY KEY,
    DATA BLOB NOT NULL,
    XID VARCHAR2(255)
);

在控制台中配置JDBC Store步骤如下:

  1. 创建JDBC数据源(如 jdbc/JmsDataSource )。
  2. 进入 Services > Persistent Stores > New > JDBC Store
  3. 选择之前创建的数据源。
  4. 指定表前缀(如 WLS_JDBC_STORE )。
  5. 绑定到集群中的多个服务器。
故障转移与负载均衡机制

WebLogic通过以下机制保障JMS高可用:

  • 自动迁移(Migration) :当某台服务器宕机,其上的JMS服务器可在预设策略下迁移到其他健康节点。
  • 客户端重连(Client Reconnect) :JMS客户端可通过T3集群地址自动发现新位置。
  • 分布式队列负载均衡 :消息投递均匀分布到各成员队列。
// 客户端连接工厂使用集群地址
String connectionURL = "t3://server1:7001,server2:7002,server3:7003";
InitialContext ctx = new InitialContext();
ConnectionFactory cf = (ConnectionFactory) ctx.lookup("jndi/connectionFactory");
Connection conn = cf.createConnection(); // 自动选择活跃节点

参数说明:
- t3://... :T3协议支持集群感知,比IIOP更高效。
- JNDI名称必须在所有节点一致。
- 客户端无需知道具体服务器位置,由WebLogic透明路由。

高可用架构流程图(Mermaid)
graph LR
    Client[JMS客户端] --> LB[WebLogic集群前端负载均衡器]
    LB --> S1[Server-1 + JMS-1]
    LB --> S2[Server-2 + JMS-2]
    LB --> S3[Server-3 + JMS-3]

    S1 --> DB[(共享JDBC Store)]
    S2 --> DB
    S3 --> DB

    subgraph 故障转移
        S1 -.->|宕机| S2
        S2 -.->|接管| S1的任务
    end

该图展示了典型的WebLogic集群JMS部署结构,其中所有JMS服务器共享同一个数据库存储,确保即使某个节点失效,消息也不会丢失,且可在其他节点继续处理。

此外,WebLogic提供了 Whole Server Migration Service Migration 两种迁移策略:
- Whole Server Migration :整个服务器实例迁移(适用于虚拟化环境)。
- Service Migration :仅迁移JMS服务(轻量级,响应更快)。

合理配置迁移策略,结合心跳检测与自动恢复机制,可显著提升系统的容灾能力。

2.2 JMS模块与连接工厂

JMS模块是组织JMS资源的逻辑单元,类似于Java中的包(package)。它包含连接工厂、队列、主题等资源定义,并可通过JNDI对外暴露。JMS模块分为两种类型:
- 系统模块(System Module) :由WebLogic内部管理,一般不推荐修改。
- 自定义模块(Custom Module) :用户自行创建,便于版本管理和部署。

2.2.1 创建JMS模块并配置连接工厂(ConnectionFactory)

创建JMS模块是配置JMS资源的第一步。模块中最重要的资源之一是 连接工厂(ConnectionFactory) ,它是客户端获取JMS连接的入口。

控制台创建JMS模块流程
  1. 进入 Services > Messaging > JMS Modules > New
  2. 输入名称 MyJMSModule ,选择目标(单服务器或集群)。
  3. 创建完成后,进入模块详情页,点击“New Resource”添加资源。
  4. 选择“Connection Factory”,输入JNDI名(如 jndi/cf )。
  5. 设置客户端ID(可选),启用XA事务支持。
WLST脚本创建JMS模块与连接工厂
connect('weblogic', 'welcome1', 't3://localhost:7001')
edit()
startEdit()

try:
    # 创建JMS模块
    create('MyJMSModule', 'JMSSystemResource')
    cd('/JMSSystemResources/MyJMSModule')
    set('Targets', jarray.array([ObjectName('com.bea:Name=Server-0,Type=Server')], ObjectName))

    # 创建子部署(Subdeployment),用于绑定JMS服务器
    cd('/JMSSystemResources/MyJMSModule')
    create('JmsSubDeploy', 'SubDeployment')

    # 创建ConnectionFactory
    cd('/JMSSystemResources/MyJMSModule/JMSResource/MyJMSModule')
    cf = create('MyConnectionFactory', 'ConnectionFactory')

    # 设置JNDI名称
    cf.setJNDIName('jndi/cf')

    # 配置事务与会话池
    cf.getTransactionParams().setXaConnectionFactoryEnabled(true)
    cf.getClientParams().setClientIdPolicy('Restricted')
    cf.getConnectionParams().setMaxConnections(50)

    save()
    activate()
    print("✅ JMS模块与连接工厂创建成功")
except Exception as e:
    print("❌ 配置异常:", str(e))
    cancelEdit('y')

代码逻辑逐行解读:

  • create('MyJMSModule', 'JMSSystemResource') :注册一个名为MyJMSModule的JMS模块。
  • set('Targets') :将模块部署到指定服务器。
  • create('JmsSubDeploy', 'SubDeployment') :子部署用于将资源绑定到特定JMS服务器。
  • create('MyConnectionFactory', 'ConnectionFactory') :在模块内创建连接工厂。
  • setJNDIName() :设定客户端查找用的JNDI路径。
  • setXaConnectionFactoryEnabled(true) :启用XA分布式事务支持。
  • setMaxConnections(50) :限制最大连接数,防止资源耗尽。

参数说明:
- XaConnectionFactoryEnabled :若涉及数据库与消息的两阶段提交,必须开启。
- ClientIdPolicy :限制每个连接工厂只能有一个固定ClientID,避免冲突。
- MaxConnections :根据应用负载调整,过高可能导致线程阻塞。

2.2.2 连接工厂的属性设置与JNDI绑定

连接工厂的属性直接影响客户端行为,主要包括:

属性类别 关键参数 说明
事务参数 XA启用、回滚重试次数 决定是否参与全局事务
客户端参数 ClientID策略、重连延迟 控制客户端身份与网络恢复行为
连接参数 最大连接数、连接超时 影响资源利用率
流控参数 生产者速率限制 防止突发流量压垮系统
JNDI绑定验证命令
# 使用weblogic.WLST查看JNDI树
java weblogic.WLST
connect('weblogic','welcome1','t3://localhost:7001')
ls(jndiName='jndi')

输出应包含:

jndi/cf --> ConnectionFactory

表示绑定成功,客户端可通过该名称查找到连接工厂。

2.3 JMS目的地配置

JMS目的地是消息发送的目标地址,分为 队列(Queue) 主题(Topic) 两类。它们分别对应点对点和发布/订阅模型。

2.3.1 队列(Queue)与主题(Topic)的创建与管理

队列创建(WLST脚本)
cd('/JMSSystemResources/MyJMSModule/JMSResource/MyJMSModule')
queue = create('MyQueue', 'Queue')

queue.setJNDIName('jndi/queue')
queue.setSubDeploymentName('JmsSubDeploy')  # 关联子部署
主题创建
topic = create('MyTopic', 'Topic')
topic.setJNDIName('jndi/topic')
topic.setSubDeploymentName('JmsSubDeploy')

说明:
- setSubDeploymentName() 必须与前面定义的子部署名称一致,否则资源不会激活。
- 队列允许多个消费者,但每条消息仅被一个消费者处理。
- 主题支持一对多广播,所有订阅者都能收到消息。

2.3.2 目的地的高级配置:阈值、配额与转发策略

配置消息配额(Quota)
cd('/JMSSystemResources/MyJMSModule/JMSResource/MyJMSModule')
quota = create('HighVolumeQuota', 'Quota')

quota.setBytesMaximum(104857600)  # 100MB
quota.setMessagesMaximum(5000)
quota.setPolicy('FIFO')  # 超限时按先进先出丢弃

# 应用到队列
queue.getCachingParams().setTotalCachingEnabled(true)
queue.setQuota(quota)

参数说明:
- BytesMaximum :最大字节数。
- MessagesMaximum :最多消息条数。
- Policy :溢出策略,可选 FIFO , Priority , ExpirationFirst

转发策略(Forwarding Destinations)

可用于实现消息路由:

bridge = create('ErrorBridge', 'MessageDrivenBean')
bridge.setSourceDestination(queue)
bridge.setTargetDestination(errorQueue)
bridge.setSelector("JMSRedelivered = TRUE")

即当消息重试多次失败后,自动转发至错误队列供人工干预。

2.4 配置验证与测试环境搭建

2.4.1 使用控制台和WLST脚本进行配置验证

查看JMS服务器状态
servers = getMBean('/JMSServers')
for server in servers:
    print(f"{server.getName()} -> State: {server.getState()}")

正常状态应为 ACTIVE

检查持久化存储健康状况
store = getMBean('/FileStores/MyFileStore')
print(f"Location: {store.getDirectory()}, State: {store.getState()}")

2.4.2 配置测试JMS客户端环境与依赖库

Maven依赖(用于Java客户端)

    com.oracle.weblogic
    wlthint3client
    14.1.1.0

简易测试程序(发送消息)
InitialContext ctx = new InitialContext();
ConnectionFactory cf = (ConnectionFactory) ctx.lookup("jndi/cf");
Destination queue = (Destination) ctx.lookup("jndi/queue");

Connection conn = cf.createConnection();
Session sess = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
MessageProducer prod = sess.createProducer(queue);

TextMessage msg = sess.createTextMessage("Hello WebLogic JMS!");
prod.send(msg);
System.out.println("消息已发送");

运行此程序前,确保WebLogic服务器启动且JNDI路径正确。

最终,完整的JMS环境应在控制台的 Monitoring > Statistics 中显示活动连接、消息数量等指标,证明配置已生效。

3. JMS消息模型与消息处理机制

消息驱动架构的核心在于消息模型与处理机制的设计。在JMS(Java Message Service)中,支持两种主要的消息传递模型: 点对点(Point-to-Point, P2P) 发布/订阅(Publish/Subscribe, Pub/Sub) 。这两种模型在应用场景、消息生命周期、消费者行为等方面存在显著差异。理解它们的异同对于设计高可用、可扩展的企业级消息系统至关重要。本章将深入探讨这两种消息模型的工作原理、使用场景,并通过代码示例展示其在WebLogic环境下的实现方式。

3.1 队列与主题模型对比

3.1.1 点对点(P2P)与发布/订阅(Pub/Sub)模式的原理

在JMS中, 队列(Queue) 实现了 点对点(P2P) 模型,而 主题(Topic) 实现了 发布/订阅(Pub/Sub) 模型。它们在消息传递机制上有着本质的区别。

点对点(P2P)模型
  • 消息发送方(生产者) 将消息发送到一个 队列(Queue)
  • 多个消费者 可以监听同一个队列,但 每条消息只会被一个消费者消费一次
  • 消息具有 持久性(可配置) ,即使在消费者未启动时,消息也会被保留
  • 适用于 任务队列、订单处理、工作流调度 等场景
发布/订阅(Pub/Sub)模型
  • 发布者(Publisher) 向一个 主题(Topic) 发送消息
  • 多个订阅者(Subscriber) 可以订阅该主题, 每条消息会被所有订阅者接收
  • 支持 持久订阅(Durable Subscriber) 非持久订阅(Non-Durable Subscriber)
  • 适用于 广播通知、实时数据推送、新闻订阅 等场景
两种模型的对比表格
特性 P2P(队列) Pub/Sub(主题)
消息消费方式 点对点,一条消息被一个消费者消费 广播式,一条消息被多个订阅者消费
是否保留消息 可配置持久化 可配置持久订阅
消费者数量 一个或多个,但每条消息只被消费一次 多个,每条消息被所有订阅者消费
使用场景 订单处理、任务分发 实时通知、广播系统
消息顺序性 支持顺序消费 不保证顺序性(除非启用有序主题)

3.1.2 不同模型在实际业务中的适用场景

选择合适的模型取决于具体的业务需求:

  • P2P模型适用于需要确保任务被处理且仅被处理一次的场景 ,例如银行交易处理、支付队列、后台批处理等。
  • Pub/Sub模型适用于需要广播信息或实时通知的场景 ,例如股票行情推送、实时日志聚合、系统状态广播等。
代码示例:P2P模式下的队列发送与接收
// 发送端代码
public class QueueSender {
    public static void main(String[] args) throws Exception {
        InitialContext context = new InitialContext();
        ConnectionFactory factory = (ConnectionFactory) context.lookup("jms/MyConnectionFactory");
        Destination queue = (Destination) context.lookup("jms/MyQueue");

        Connection connection = factory.createConnection();
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        MessageProducer producer = session.createProducer(queue);

        TextMessage message = session.createTextMessage("这是P2P队列消息");
        producer.send(message);

        session.close();
        connection.close();
    }
}
// 接收端代码
public class QueueReceiver {
    public static void main(String[] args) throws Exception {
        InitialContext context = new InitialContext();
        ConnectionFactory factory = (ConnectionFactory) context.lookup("jms/MyConnectionFactory");
        Destination queue = (Destination) context.lookup("jms/MyQueue");

        Connection connection = factory.createConnection();
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        MessageConsumer consumer = session.createConsumer(queue);

        connection.start();
        Message message = consumer.receive();
        if (message instanceof TextMessage) {
            TextMessage textMessage = (TextMessage) message;
            System.out.println("收到队列消息:" + textMessage.getText());
        }

        session.close();
        connection.close();
    }
}
代码逻辑分析
  1. InitialContext 获取JNDI上下文,用于查找连接工厂和目的地。
  2. ConnectionFactory 创建连接对象,建立与JMS服务器的通信。
  3. Session 表示一个会话,定义了事务性和确认模式( AUTO_ACKNOWLEDGE )。
  4. MessageProducer 用于发送消息, producer.send() 将消息发送到指定队列。
  5. MessageConsumer 用于接收消息, consumer.receive() 阻塞式接收。
参数说明
  • Session.AUTO_ACKNOWLEDGE :自动确认模式,适用于大多数业务场景。
  • false :表示不启用事务,若启用事务则应设为 true 并调用 session.commit()

3.2 消息发送与接收机制

3.2.1 同步与异步消息消费方式

JMS支持两种主要的消息消费方式: 同步接收 异步接收(监听器模式)

同步接收
  • 通过 MessageConsumer.receive() 方法获取消息
  • 是一种阻塞式调用,适用于低并发、简单处理逻辑
  • 适合对消息消费顺序有严格要求的场景
异步接收
  • 使用 MessageListener 接口实现回调机制
  • 消息到达后自动触发 onMessage() 方法进行处理
  • 支持高并发、非阻塞式消息处理
  • 适合实时性强、吞吐量高的系统
异步接收示例代码
public class AsyncTopicSubscriber implements MessageListener {
    public void onMessage(Message message) {
        if (message instanceof TextMessage) {
            try {
                System.out.println("收到异步消息:" + ((TextMessage) message).getText());
            } catch (JMSException e) {
                e.printStackTrace();
            }
        }
    }

    public static void main(String[] args) throws Exception {
        InitialContext context = new InitialContext();
        ConnectionFactory factory = (ConnectionFactory) context.lookup("jms/MyConnectionFactory");
        Destination topic = (Destination) context.lookup("jms/MyTopic");

        Connection connection = factory.createConnection();
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        MessageConsumer consumer = session.createConsumer(topic);

        consumer.setMessageListener(new AsyncTopicSubscriber());
        connection.start();

        System.out.println("等待消息...");
    }
}
代码逻辑分析
  1. 实现 MessageListener 接口,重写 onMessage() 方法
  2. 创建连接和会话,创建消费者对象
  3. 调用 setMessageListener() 注册监听器
  4. 启动连接后,自动接收并处理消息
参数说明
  • connection.start() :启动连接,开始监听消息
  • setMessageListener() :注册监听器,设置异步回调机制

3.2.2 消息确认模式(Auto Acknowledge、Client Acknowledge等)

JMS定义了多种消息确认方式,常见的包括:

  • Session.AUTO_ACKNOWLEDGE :自动确认,适用于大多数场景
  • Session.CLIENT_ACKNOWLEDGE :客户端手动确认
  • Session.DUPS_OK_ACKNOWLEDGE :允许重复确认,适用于性能优先场景
  • Session.SESSION_TRANSACTED :事务性会话,需调用 session.commit()
示例代码:使用客户端确认模式
Session session = connection.createSession(false, Session.CLIENT_ACKNOWLEDGE);
MessageConsumer consumer = session.createConsumer(queue);
Message message = consumer.receive();
if (message instanceof TextMessage) {
    TextMessage textMessage = (TextMessage) message;
    System.out.println("收到消息:" + textMessage.getText());
    message.acknowledge(); // 手动确认
}
参数说明
  • Session.CLIENT_ACKNOWLEDGE :启用客户端手动确认模式
  • message.acknowledge() :显式调用确认方法,确保消息被正确消费

3.3 消息驱动Bean(MDB)的开发与部署

3.3.1 MDB的生命周期与并发处理机制

消息驱动Bean(Message-Driven Bean, MDB) 是EJB中专门用于处理异步消息的组件。它运行在容器中,自动监听指定的JMS目的地,具备良好的并发处理能力。

MDB的生命周期
  1. 容器创建MDB实例并初始化
  2. MDB监听JMS目的地
  3. 消息到达时,容器调用 onMessage() 方法
  4. 消息处理完成后,容器进行确认或回滚
  5. MDB实例可被复用,提高性能
并发处理机制
  • MDB支持 多线程并发消费
  • 可通过配置 maxSessions 控制并发线程数
  • 支持事务回滚、消息重试机制
UML时序图:MDB消息处理流程
sequenceDiagram
    participant JMS as JMS Server
    participant MDB as Message-Driven Bean
    participant EJBContainer as EJB Container
    participant AppServer as Application Server

    JMS->>EJBContainer: 发送消息到监听的JMS目的地
    EJBContainer->>MDB: 调用onMessage()方法
    MDB->>MDB: 处理消息逻辑
    MDB->>EJBContainer: 消息确认或回滚
    EJBContainer->>JMS: 提交或回滚事务

3.3.2 部署到WebLogic服务器并配置监听器属性

步骤一:创建EJB项目

使用Maven创建一个EJB项目,结构如下:

my-ejb-project/
├── src/
│   └── main/
│       └── java/
│           └── com/example/mdb/MyMDB.java
└── pom.xml
步骤二:编写MDB类
@MessageDriven(name = "MyMDB", activationConfig = {
    @ActivationConfigProperty(propertyName = "destinationType", propertyValue = "javax.jms.Queue"),
    @ActivationConfigProperty(propertyName = "destination", propertyValue = "jms/MyQueue")
})
public class MyMDB implements MessageListener {
    public void onMessage(Message message) {
        if (message instanceof TextMessage) {
            try {
                System.out.println("MDB收到消息:" + ((TextMessage) message).getText());
            } catch (JMSException e) {
                e.printStackTrace();
            }
        }
    }
}
参数说明
  • @MessageDriven :声明这是一个消息驱动Bean
  • activationConfig :配置监听的JMS类型和目的地名称
  • destinationType :目标类型(Queue或Topic)
  • destination :JNDI名称
步骤三:打包并部署到WebLogic
mvn clean package

将生成的 .jar 文件通过 WebLogic 控制台或 WLST 脚本部署到服务器:

java weblogic.Deployer -adminurl t3://localhost:7001 -username weblogic -password weblogic123 -deploy my-ejb-project.jar

3.4 消息类型与序列化处理

3.4.1 文本消息(TextMessage)、对象消息(ObjectMessage)与字节消息(BytesMessage)

JMS支持多种消息类型,常见的包括:

消息类型 描述 适用场景
TextMessage 包含字符串文本的消息 通用消息、日志传输
ObjectMessage 包含Java对象的消息 传输业务实体
BytesMessage 包含字节数据的消息 二进制数据传输
示例:使用ObjectMessage传输对象
// 发送端
ObjectMessage objMsg = session.createObjectMessage();
MyData data = new MyData("测试数据", 123);
objMsg.setObject(data);
producer.send(objMsg);
// 接收端
if (message instanceof ObjectMessage) {
    MyData data = (MyData) ((ObjectMessage) message).getObject();
    System.out.println("收到对象消息:" + data.toString());
}

3.4.2 自定义对象序列化与反序列化实现

若使用 ObjectMessage ,对象必须实现 Serializable 接口:

public class MyData implements Serializable {
    private String name;
    private int value;

    public MyData(String name, int value) {
        this.name = name;
        this.value = value;
    }

    // Getter / Setter / toString()
}
自定义序列化方式(如JSON)
Gson gson = new Gson();
String json = gson.toJson(data);
TextMessage msg = session.createTextMessage(json);
producer.send(msg);
if (message instanceof TextMessage) {
    String json = ((TextMessage) message).getText();
    MyData data = gson.fromJson(json, MyData.class);
}
优缺点对比
序列化方式 优点 缺点
Java原生序列化 简单易用,无需额外依赖 可读性差,跨语言不友好
JSON 可读性强,跨语言支持好 需引入第三方库
XML 标准化程度高 性能差,代码复杂

本章从消息模型的对比出发,详细介绍了P2P与Pub/Sub模型的原理与适用场景,并通过代码示例展示了其在WebLogic平台下的实现方式。同时,深入探讨了消息的同步与异步消费机制、确认模式,以及消息驱动Bean的生命周期与并发处理机制。最后,讲解了JMS消息类型的使用及其序列化方式的选择,为后续章节的高级应用打下坚实基础。

4. JMS高级特性与企业级应用

JMS(Java Message Service)不仅支持基本的消息传递功能,还提供了诸如事务管理、高可用性、消息持久化和安全性等高级特性,这些特性对于构建企业级的分布式系统至关重要。本章将深入探讨这些高级功能,并结合企业级应用场景进行详细解析,帮助读者掌握如何在WebLogic Server中高效地利用JMS来实现可靠、安全、可扩展的消息通信架构。

4.1 JMS与事务管理(JTA)集成

事务管理是确保系统中多个操作要么全部成功、要么全部失败的重要机制。在JMS中,事务管理可以通过本地事务(Local Transaction)或分布式事务(JTA, Java Transaction API)来实现。在企业级应用中,JMS通常需要与数据库或其他资源管理器协同工作,此时使用JTA可以实现跨资源的事务一致性。

4.1.1 本地事务与分布式事务的配置

本地事务(Local Transaction)

本地事务是指在一个会话(Session)内进行的消息发送或接收操作被包含在事务中。以下是一个使用本地事务发送消息的示例代码:

ConnectionFactory factory = (ConnectionFactory) context.lookup("jms/MyConnectionFactory");
Connection connection = factory.createConnection();
Session session = connection.createSession(true, Session.SESSION_TRANSACTED);
Destination destination = (Destination) context.lookup("jms/MyQueue");

MessageProducer producer = session.createProducer(destination);
TextMessage message = session.createTextMessage("Hello, JMS with Local Transaction!");
producer.send(message);

// 提交事务
session.commit();

代码解析:

  • createSession(true, Session.SESSION_TRANSACTED) :启用本地事务。
  • session.commit() :提交事务,若发送失败则不会提交。
  • session.rollback() :可在异常处理中调用以回滚事务。
分布式事务(JTA)

当JMS操作需要与数据库操作在同一个事务中完成时,必须使用JTA。以下是一个典型的Spring Boot整合JTA的示例配置(使用Atomikos):


    org.springframework.boot
    spring-boot-starter-jta-atomikos

@JmsListener(destination = "jms/MyQueue")
@Transactional
public void processMessage(String message) {
    // 消费消息并更新数据库
    jdbcTemplate.update("INSERT INTO messages (content) VALUES (?)", message);
}

参数说明:

  • @Transactional :表示该方法应在事务中执行。
  • Atomikos作为JTA事务管理器,协调JMS与数据库事务。

逻辑分析:

  • 消息消费与数据库操作在一个事务中,确保数据一致性。
  • 若数据库操作失败,JMS消息不会被确认,从而避免数据丢失。

4.1.2 保证消息发送与数据库操作的原子性

在企业级系统中,常需保证“发送消息”与“数据库更新”操作的原子性。使用JTA事务可以实现这一目标,如下图所示:

sequenceDiagram
    participant Client
    participant MDB
    participant DB
    participant JMS

    Client->>MDB: 发送请求
    MDB->>JMS: 启动JTA事务
    MDB->>DB: 更新数据库
    JMS->>MDB: 提交事务
    MDB->>Client: 返回结果

图示说明:

  • JTA事务协调JMS与数据库资源。
  • 所有操作在事务中完成,失败则整体回滚。

4.2 高可用性与故障转移配置

高可用性是企业系统设计的重要目标之一。WebLogic Server 提供了丰富的机制来实现JMS的高可用性,包括集群部署、故障切换、消息重发等。

4.2.1 JMS服务器与目的地的集群部署

将JMS服务器和目的地部署在集群中,可以提高系统的可用性和负载均衡能力。以下是WebLogic控制台中配置JMS集群的步骤:

  1. 登录 WebLogic 控制台。
  2. 导航至 Services → Messaging → JMS Modules
  3. 创建或编辑JMS模块,选择 Distributed Destination (分布式目的地)。
  4. 将该目的地分配到集群中的多个JMS服务器节点上。

分布式队列配置示例:

配置项 说明
目的地类型 Queue
分布模式 Uniform
成员服务器 server-1, server-2
高可用性 启用

优势分析:

  • 消息可被多个服务器处理,避免单点故障。
  • 自动负载均衡,提升系统吞吐量。

4.2.2 故障切换机制与消息重发策略

WebLogic 支持自动故障切换(Failover)和消息重发机制。当某个JMS服务器宕机时,客户端会自动连接到其他可用节点。

配置步骤:

  1. 在 ConnectionFactory 中启用 HA 设置。
  2. 配置 ReconnectEnabled = true ReconnectAttempts = -1 (无限次重连)。
  3. 设置 ReconnectInterval = 5000 (单位:毫秒)。

Java客户端代码示例:

Properties props = new Properties();
props.put("weblogic.jndi.WLInitialContextFactory", "t3://server-1:7001,server-2:7002");
props.put(Context.SECURITY_PRINCIPAL, "weblogic");
props.put(Context.SECURITY_CREDENTIALS, "password");

InitialContext context = new InitialContext(props);
ConnectionFactory factory = (ConnectionFactory) context.lookup("jms/MyConnectionFactory");
Connection connection = factory.createConnection();
connection.setExceptionListener(exception -> {
    System.out.println("JMS Connection Exception: " + exception.getMessage());
});

逻辑说明:

  • 使用多地址连接(server-1与server-2),支持故障切换。
  • 异常监听器可捕获连接中断事件,实现自定义处理逻辑。

4.3 消息持久化与性能优化

消息持久化是确保消息在系统故障时不会丢失的重要机制。然而,持久化操作可能会影响系统性能。因此,合理的优化策略是企业应用中必须考虑的内容。

4.3.1 持久化消息的存储机制与性能影响

WebLogic 支持将消息持久化到文件系统或JDBC持久化存储(如数据库)。以下是两种方式的对比:

存储方式 优点 缺点
文件系统 性能较高 不支持跨节点共享
JDBC存储 支持高可用与共享 性能相对较低

配置步骤:

  1. 在 WebLogic 控制台中创建持久化存储(Persistent Store)。
  2. 选择 JDBC 或 File Store。
  3. 绑定到JMS服务器。

性能影响分析:

  • 文件系统存储 I/O 效率高,适合单节点部署。
  • JDBC 存储支持集群环境,但每次写入需访问数据库,延迟较高。

4.3.2 消息缓冲、并发消费与批量处理策略

为了提升性能,WebLogic 提供了多种优化策略:

  • 消息缓冲(Message Paging) :将消息缓存到内存,减少磁盘I/O。
  • 并发消费(Message-Driven Bean Pool Size) :设置MDB线程池大小,提升并发能力。
  • 批量确认(Batch Acknowledge) :减少每次确认的网络开销。

优化配置示例:


    MyJMSServer
    MyCluster
    MyJDBCStore
    1024

代码逻辑说明:

  • message-buffer-size :控制内存中缓存的消息数量,单位为KB。
  • 增大缓冲区可减少持久化频率,提高吞吐量。

并发消费配置:

在部署描述符 ejb-jar.xml 中配置MDB并发:


    MyMessageDrivenBean
    
        20
    

优化建议:

  • 根据消息流量动态调整线程池大小。
  • 对于高吞吐量场景,启用批量确认和缓冲机制。

4.4 安全性配置与访问控制

在企业环境中,安全性是消息系统不可忽视的一环。WebLogic 提供了完善的JMS安全机制,包括基于角色的访问控制、用户认证与SSL加密通信等。

4.4.1 配置JMS资源的安全策略与角色权限

步骤一:创建用户与角色
  1. 登录 WebLogic 控制台。
  2. 导航至 Security Realms → myrealm → Users and Groups
  3. 创建用户 jmsUser 和角色 jmsProducer jmsConsumer
步骤二:配置JMS资源权限
  1. 进入 Services → Messaging → JMS Modules
  2. 编辑目标队列或主题,选择 Security 标签。
  3. 为角色 jmsProducer jmsConsumer 授予相应权限。

权限说明:

权限类型 作用
Send 允许发送消息
Receive 允许接收消息
Delete 允许删除消息

4.4.2 用户认证与SSL加密通信实现

用户认证配置

在JMS客户端连接时,需提供用户名和密码:

ConnectionFactory factory = (ConnectionFactory) context.lookup("jms/MyConnectionFactory");
Connection connection = factory.createConnection("jmsUser", "password");
启用SSL加密通信
  1. 在 WebLogic 控制台中启用SSL:
    - 进入 Environment → Servers → server-name → Configuration → SSL
    - 启用 SSL Listen Port,并配置密钥库与信任库。

  2. 客户端连接时使用 t3s 协议:

props.put(Context.PROVIDER_URL, "t3s://localhost:7002");

安全策略总结:

  • 通过角色控制访问权限,防止越权操作。
  • 使用SSL加密传输,保障数据安全。
  • 定期更新密钥与证书,防止中间人攻击。

小结:

本章深入探讨了JMS在WebLogic中的高级特性,包括事务管理、高可用性配置、消息持久化优化以及安全性控制。通过本地事务与JTA的结合,可以实现业务操作的原子性;集群部署与故障切换机制保障了系统的高可用;合理配置持久化和并发策略可显著提升性能;而完善的权限控制与SSL加密则为系统安全提供了保障。这些内容构成了企业级JMS应用的核心支撑体系,是构建健壮、高效、安全消息系统的关键基础。

5. JMS项目实战与运维监控

5.1 项目结构与集成流程

在企业级Java应用中,良好的项目结构是保障可维护性、可扩展性和团队协作效率的关键。尤其在将JMS消息中间件集成到WebLogic平台时,合理的目录组织和依赖管理显得尤为重要。

5.1.1 基于src与lib目录的标准项目结构解析

一个典型的基于Maven或Ant构建的Java EE项目应遵循如下标准结构:

my-jms-app/
├── src/
│   ├── main/
│   │   ├── java/
│   │   │   └── com/example/jms/
│   │   │       ├── JmsProducer.java
│   │   │       ├── JmsConsumer.java
│   │   │       └── MessageProcessorMDB.java
│   │   ├── resources/
│   │   │   └── jndi.properties
│   │   └── webapp/
│   │       └── WEB-INF/web.xml
├── lib/
│   ├── wlthint3client.jar      // WebLogic Thin Client
│   ├── jms.jar                 // JMS API
│   └── spring-jms-5.3.21.jar   // 可选框架依赖
├── build.xml                   // Ant 构建脚本(若使用)
└── pom.xml                     // Maven 配置文件

其中:
- src/main/java 存放核心业务逻辑与JMS相关代码;
- resources 包含JNDI配置、日志配置等外部化参数;
- lib 目录用于存放非Maven托管的本地库,如WebLogic客户端jar包;
- wlthint3client.jar 是连接WebLogic服务器必需的轻量级客户端驱动。

JNDI配置示例(jndi.properties):

java.naming.factory.initial=weblogic.jndi.WLInitialContextFactory
java.naming.provider.url=t3://localhost:7001
java.naming.security.principal=weblogic
java.naming.security.credentials=welcome1

该配置允许Java应用通过T3协议连接至WebLogic Server,并查找已绑定的ConnectionFactory和Queue。

5.1.2 集成WebLogic JMS模块与Spring Boot等框架

现代微服务架构常采用Spring Boot作为开发框架。将其与WebLogic JMS集成可通过以下方式实现:

步骤一:添加依赖(pom.xml)

    org.springframework.boot
    spring-boot-starter-artemis
    


${project.basedir}/lib/wlthint3client.jar
步骤二:配置自定义JMS连接工厂Bean
@Configuration
public class JmsConfig {

    @Bean
    public ConnectionFactory jmsConnectionFactory() throws NamingException {
        InitialContext ctx = new InitialContext();
        return (ConnectionFactory) ctx.lookup("jms/MyConnectionFactory");
    }

    @Bean
    public JmsTemplate jmsTemplate() {
        JmsTemplate template = new JmsTemplate();
        template.setConnectionFactory(jmsConnectionFactory());
        template.setDefaultDestinationName("jms/MyQueue");
        return template;
    }
}
步骤三:使用JmsTemplate发送消息
@Service
public class OrderService {

    @Autowired
    private JmsTemplate jmsTemplate;

    public void sendOrder(String orderId) {
        jmsTemplate.convertAndSend(orderId, message -> {
            message.setStringProperty("MSG_TYPE", "ORDER_CREATED");
            return message;
        });
    }
}

此集成模式实现了松耦合设计,便于后续迁移到其他JMS提供者或云原生消息系统。

集成要素 说明
构建工具 推荐使用Maven统一管理依赖
客户端库 必须包含wlthint3client.jar
JNDI访问 使用WLInitialContextFactory初始化上下文
框架兼容性 Spring JMS抽象层支持自定义ConnectionFactory
部署方式 可打包为EAR/WAR部署至WebLogic,或独立运行JMS客户端

此外,在多环境部署中建议通过Spring Profiles区分开发、测试与生产配置:

spring:
  profiles: prod
  jndi:
    initial: weblogic.jndi.WLInitialContextFactory
    provider-url: t3://prod-wls-cluster:7001

这种结构化集成方式不仅提升了项目的清晰度,也为后续的监控与调优奠定了基础。

本文还有配套的精品资源,点击获取

简介:WebLogic Server是Oracle提供的主流Java企业级中间件,广泛用于部署高可用、可扩展的分布式应用。JMS(Java Message Service)作为标准消息传递API,支持异步通信与系统解耦。本文结合源码与工具实践,深入讲解如何在WebLogic中配置和使用JMS服务,涵盖队列、主题、消息驱动Bean(MDB)、事务管理及安全机制等内容。通过“src”源码目录与“lib”依赖库的实际结构,帮助开发者掌握JMS资源创建、消息收发、集群容错与性能调优等关键技能,构建高效稳定的 enterprise 级消息系统。


本文还有配套的精品资源,点击获取

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

搜索文章

Tags

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