ActiveMQ 快速上手:安装配置与基础通信实践(一)
一、引言
在当今分布式系统和微服务架构盛行的时代,消息通信作为实现系统间解耦、异步处理和可靠传输的关键技术,显得尤为重要。ActiveMQ 作为一款广泛应用的开源消息中间件,凭借其对 JMS 规范的全面支持、丰富的特性以及出色的性能,在消息通信领域占据着举足轻重的地位 。它不仅能够帮助开发者轻松实现应用程序之间的高效通信,还能在高并发、大规模的场景下稳定运行,为构建可靠的分布式系统提供坚实的基础。本文将带领大家快速上手 ActiveMQ,从安装配置到基础通信实践,一步步揭开它的神秘面纱,让你在实际项目中能够熟练运用这一强大的工具。
二、ActiveMQ 初相识
ActiveMQ 是 Apache 软件基金会所研发的开放源代码消息中间件,作为一个纯 Java 程序,只要操作系统支持 Java 虚拟机,ActiveMQ 便可执行。它在分布式系统中扮演着至关重要的角色,是企业级应用中实现消息通信的首选工具之一。
(一)特性亮点
- 多语言客户端支持:ActiveMQ 支持多种语言编写客户端,如 Java、C、C++、C#、Ruby、Perl、Python、PHP 等。这使得不同技术栈的项目都能够轻松接入 ActiveMQ,实现系统间的消息通信 。例如,一个以 Python 为主开发的数据处理系统,可以通过 ActiveMQ 与 Java 编写的后端服务进行高效的数据交互。
- 丰富的协议支持:它支持 OpenWire、Stomp、REST、WS Notification、XMPP、AMQP 等多种应用协议。这种多协议支持特性,让 ActiveMQ 可以适应不同的应用场景和通信需求。比如,在物联网场景中,ActiveMQ 可以通过 MQTT 协议与大量的物联网设备进行通信,实现设备状态监控和数据收集。
- JMS 规范全面支持:ActiveMQ 完全支持 JMS1.1 和 J2EE 1.4 规范,包括持久化、XA 消息、事务等特性。这保证了在 Java 企业级开发中,ActiveMQ 能够与其他遵循 JMS 规范的组件无缝集成,提供可靠的消息服务。例如,在一个分布式事务处理系统中,ActiveMQ 可以利用 XA 消息和事务特性,确保消息在多个参与者之间的可靠传递和一致性。
- Spring 集成友好:ActiveMQ 对 Spring 框架有着良好的支持,可以很容易地内嵌到使用 Spring 的系统里面去,并且支持 Spring2.0 的特性。借助 Spring 的配置机制,开发者可以方便地对 ActiveMQ 进行配置和管理,降低开发成本。比如,在一个基于 Spring Boot 的微服务项目中,只需要简单的配置,就可以集成 ActiveMQ 实现服务间的消息通信。
(二)分布式系统中的关键作用
- 解耦系统组件:在分布式系统中,各个组件之间通常存在复杂的依赖关系。使用 ActiveMQ 作为消息中间件,可以将这些组件之间的直接调用转换为通过消息进行通信。例如,一个电商系统中的订单服务和库存服务,订单服务在生成订单后,不是直接调用库存服务的接口来扣减库存,而是向 ActiveMQ 发送一条包含订单信息的消息,库存服务从 ActiveMQ 接收消息并进行库存处理。这样,订单服务和库存服务就实现了解耦,它们的开发、部署和升级都可以独立进行,互不影响。
- 异步处理提升性能:对于一些耗时较长的操作,如文件处理、数据分析等,可以将相关任务封装成消息发送到 ActiveMQ。系统在发送消息后可以立即返回,而不需要等待任务完成,从而提高系统的响应速度。例如,在一个日志处理系统中,应用程序将日志信息以消息的形式发送到 ActiveMQ,然后继续执行其他任务,而日志处理模块则从 ActiveMQ 中获取日志消息进行异步处理,这样可以避免因日志处理导致应用程序性能下降。
- 可靠的消息传输:ActiveMQ 提供了消息持久化机制,即使在系统故障或服务器重启的情况下,也能保证消息不会丢失。它还支持消息的确认机制,确保消息被正确接收和处理。例如,在一个金融交易系统中,每一笔交易信息都作为消息发送到 ActiveMQ,通过消息的持久化和确认机制,保证交易信息的可靠传输和处理,避免因系统故障导致交易数据丢失或不一致。
三、安装 ActiveMQ
3.1 下载
ActiveMQ 的官方下载地址为:http://activemq.apache.org/components/classic/download/ 。在该页面,你可以看到不同版本的 ActiveMQ 可供下载。根据你的操作系统,选择相应的安装包:
- Windows 版:如果你使用的是 Windows 系统,下载以.zip结尾的文件,例如apache-activemq-5.16.3-bin.zip 。这种格式的文件便于在 Windows 系统上解压和使用。
- Linux 版:对于 Linux 系统,下载以.tar.gz结尾的压缩包,如apache-activemq-5.16.3-bin.tar.gz 。这种格式是 Linux 系统中常见的压缩格式,方便在 Linux 环境下进行解压和安装操作。
3.2 安装步骤
- Windows 系统
-
- 解压文件:将下载的.zip文件解压到你希望安装 ActiveMQ 的目录,例如D:\apache-activemq-5.16.3 。解压后,你可以看到 ActiveMQ 的目录结构,其中bin目录包含了启动和停止 ActiveMQ 的脚本,conf目录存放着配置文件,lib目录包含了 ActiveMQ 运行所需的各种库文件。
-
- 配置环境变量(可选):如果希望在任意目录下都能方便地执行 ActiveMQ 的命令,可以配置环境变量。在系统环境变量中,找到Path变量,添加 ActiveMQ 的bin目录路径,如D:\apache-activemq-5.16.3\bin 。这样,在命令提示符中就可以直接使用activemq命令,而无需切换到bin目录。
-
- 启动 ActiveMQ:进入 ActiveMQ 的bin目录,找到activemq.bat文件,双击运行它,或者在命令提示符中切换到该目录后执行activemq start命令。启动成功后,你会看到命令行输出一些启动信息,并且可以在浏览器中访问http://localhost:8161/admin ,如果能看到 ActiveMQ 的管理界面,说明安装和启动成功。默认的用户名和密码都是admin 。
- Linux 系统
-
- 上传和解压:将下载的.tar.gz文件上传到 Linux 服务器的指定目录,比如/usr/local 。使用以下命令解压文件:
tar -zxvf apache-activemq-5.16.3-bin.tar.gz
解压后,会在当前目录下生成一个apache-activemq-5.16.3的目录。
2. 配置环境变量(可选):与 Windows 系统类似,如果希望在任意目录下执行 ActiveMQ 命令,可以配置环境变量。编辑.bashrc或.profile文件,在文件末尾添加以下内容:
export ACTIVEMQ_HOME=/usr/local/apache-activemq-5.16.3
export PATH=$ACTIVEMQ_HOME/bin:$PATH
然后执行source ~/.bashrc(如果修改的是.bashrc文件)或source ~/.profile(如果修改的是.profile文件)使配置生效。
3. 启动 ActiveMQ:进入 ActiveMQ 的bin目录,执行以下命令启动 ActiveMQ:
./activemq start
如果需要将启动日志输出到指定文件,可以使用以下命令:
./activemq start > /opt/activemq/logs/activemq.log
这里/opt/activemq/logs/activemq.log是自定义的日志文件路径。启动成功后,可以通过命令ps -ef|grep activemq|grep -v grep查看 ActiveMQ 进程是否正在运行,也可以使用netstat -anp|grep 61616查看 ActiveMQ 默认端口(61616)是否在监听。在浏览器中访问http://服务器IP:8161/admin ,输入默认用户名和密码(admin/admin),即可进入 ActiveMQ 的管理界面。
3.3 安装常见问题及解决
- 端口冲突:ActiveMQ 默认使用 61616 作为 JMS 服务端口,8161 作为管理控制台端口。如果这些端口被其他程序占用,ActiveMQ 将无法启动。解决方法是修改 ActiveMQ 的配置文件,更改端口号。在conf目录下的activemq.xml文件中,找到以下配置项:
<transportConnectors>
<transportConnector name="openwire" uri="tcp://0.0.0.0:61616?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/>
</transportConnectors>
将61616修改为其他未被占用的端口号。对于管理控制台端口,在conf/jetty.xml文件中,找到以下配置项:
<bean id="jettyPort" class="org.apache.activemq.web.WebConsolePort" init-method="start">
<property name="host" value="0.0.0.0"/>
<property name="port" value="8161"/>
</bean>
将8161修改为其他可用端口。
- 权限不足:在 Linux 系统中,如果以普通用户身份启动 ActiveMQ,可能会因为权限不足而无法创建某些文件或目录,导致启动失败。解决方法是使用root用户启动,或者给 ActiveMQ 的安装目录及相关文件赋予足够的权限。例如,使用以下命令给apache-activemq-5.16.3目录赋予 777 权限:
chmod -R 777 /usr/local/apache-activemq-5.16.3
- Java 环境问题:ActiveMQ 是基于 Java 开发的,需要正确安装和配置 Java 环境。如果在启动 ActiveMQ 时提示找不到 Java 命令或 Java 环境配置错误,需要检查 Java 环境变量是否正确设置。在 Linux 系统中,可以通过echo $JAVA_HOME命令查看JAVA_HOME环境变量是否设置正确;在 Windows 系统中,可以在系统环境变量中查看JAVA_HOME的设置。如果未设置或设置错误,需要重新配置 Java 环境变量,并确保java -version命令能够正确输出 Java 版本信息。
四、配置 ActiveMQ
4.1 基本配置文件解读
在 ActiveMQ 的安装目录下,conf 目录存放着至关重要的配置文件,这些文件决定了 ActiveMQ 的运行行为和特性。其中,activemq.xml 是核心配置文件,它定义了 ActiveMQ 的基本设置,如代理(broker)的名称、消息存储方式、传输连接器等。在activemq.xml中,<broker>标签是整个配置的核心,其中的brokerName属性用于指定代理的名称,这个名称在网络环境中应当是唯一的,例如:
<broker xmlns="http://activemq.apache.org/schema/core" brokerName="localhost" dataDirectory="${activemq.data}">
dataDirectory属性指定了消息持久化的数据存储目录,${activemq.data}是一个占位符,它会在 ActiveMQ 启动时被解析为实际的目录路径。
<transportConnectors>标签用于配置传输连接器,定义了 ActiveMQ 监听的网络地址和端口,以及支持的协议。常见的配置如下:
<transportConnectors>
<transportConnector name="openwire" uri="tcp://0.0.0.0:61616?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/>
<transportConnector name="amqp" uri="amqp://0.0.0.0:5672?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/>
<transportConnector name="stomp" uri="stomp://0.0.0.0:61613?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/>
<transportConnector name="mqtt" uri="mqtt://0.0.0.0:1883?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/>
<transportConnector name="ws" uri="ws://0.0.0.0:61614?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/>
</transportConnectors>
这里配置了多种协议的传输连接器,name属性为连接器命名,uri属性指定了监听的地址和端口,以及一些连接参数。例如,openwire协议默认监听在0.0.0.0:61616,表示可以接受来自任何 IP 地址的连接,maximumConnections限制了最大连接数为 1000,wireFormat.maxFrameSize设置了最大帧大小为 100MB。
jetty.xml则主要用于配置 ActiveMQ 的 Web 控制台,包括 Web 服务器的端口、上下文路径以及安全认证等设置。其中,<bean id="jettyPort" class="org.apache.activemq.web.WebConsolePort" init-method="start">定义了 Web 控制台的端口,默认值为 8161:
<bean id="jettyPort" class="org.apache.activemq.web.WebConsolePort" init-method="start">
<property name="host" value="0.0.0.0"/>
<property name="port" value="8161"/>
</bean>
<bean id="securityConstraint" class="org.eclipse.jetty.util.security.Constraint">用于配置安全约束,如是否需要认证、允许的角色等。将authenticate属性设置为true,表示需要认证才能访问 Web 控制台:
<bean id="securityConstraint" class="org.eclipse.jetty.util.security.Constraint">
<property name="name" value="BASIC"/>
<property name="roles" value="user,admin"/>
<property name="authenticate" value="true"/>
</bean>
4.2 修改默认配置
为了增强 ActiveMQ 的安全性和适用性,我们通常需要修改一些默认配置。首先是端口的修改。由于 ActiveMQ 的默认端口(JMS 服务端口 61616 和 Web 控制台端口 8161)可能会与其他应用程序冲突,或者出于安全考虑,需要将其修改为其他未被占用的端口。在activemq.xml文件中,修改transportConnectors标签下的uri属性,例如将 JMS 服务端口修改为 61626:
<transportConnectors>
<transportConnector name="openwire" uri="tcp://0.0.0.0:61626?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/>
</transportConnectors>
在jetty.xml文件中,修改jettyPort的port属性,将 Web 控制台端口修改为 8162:
<bean id="jettyPort" class="org.apache.activemq.web.WebConsolePort" init-method="start">
<property name="host" value="0.0.0.0"/>
<property name="port" value="8162"/>
</bean>
默认的用户名和密码(admin/admin)安全性较低,容易受到攻击,因此需要修改。在conf目录下的jetty-realm.properties文件中,存储着 Web 控制台的用户信息。该文件的格式为username: password [,rolename ...],例如:
admin: newPassword, admin
user: userPassword, user
将admin用户的密码修改为newPassword,并可以根据需要添加或修改其他用户及其密码和角色。同时,为了进一步增强安全性,建议设置复杂度较高的密码,包含大小写字母、数字和特殊字符的组合,避免使用简单的字典词汇或连续重复的字符。
4.3 配置示例
假设我们有一个实际的项目场景,需要将 ActiveMQ 部署在生产环境中,并且对性能和安全性有较高的要求。我们可以参考以下配置示例来调整 ActiveMQ 的配置。
在activemq.xml中,我们增加消息持久化的配置,使用 KahaDB 存储消息,以确保消息在系统故障时不会丢失:
<persistenceAdapter>
<kahaDB directory="${activemq.data}/kahadb"/>
</persistenceAdapter>
为了优化内存使用,我们设置系统内存使用的上限为 JVM 堆内存的 80%:
<systemUsage>
<systemUsage>
<memoryUsage>
<memoryUsage percentOfJvmHeap="80"/>
</memoryUsage>
<storeUsage>
<storeUsage limit="100 gb"/>
</storeUsage>
<tempUsage>
<tempUsage limit="50 gb"/>
</tempUsage>
</systemUsage>
</systemUsage>
在安全方面,我们启用 JAAS 认证插件,对客户端连接进行身份验证:
<plugins>
<jaasAuthenticationPlugin configuration="activemq"/>
<authorizationPlugin>
<map>
<authorizationMap>
<authorizationEntries>
<authorizationEntry topic=">" read="admins" write="admins" admin="admins"/>
<authorizationEntry queue=">" read="admins" write="admins" admin="admins"/>
<authorizationEntry topic="ActiveMQ.Advisory.>" read="admins" write="admins" admin="admins"/>
<authorizationEntry queue="ActiveMQ.Advisory.>" read="admins" write="admins" admin="admins"/>
</authorizationEntries>
</authorizationMap>
</map>
</authorizationPlugin>
</plugins>
同时,在conf目录下创建login.config文件,配置 JAAS 认证的相关参数:
activemq {
org.apache.activemq.jaas.PropertiesLoginModule required
debug=true
org.apache.activemq.jaas.properties.user="users.properties"
org.apache.activemq.jaas.properties.group="groups.properties";
};
并在users.properties和groups.properties文件中分别配置用户和用户组信息,以实现更细粒度的权限控制。通过这样的配置示例,我们可以根据实际需求,灵活地调整 ActiveMQ 的各项配置,使其更好地适应不同的生产环境和业务需求。
相关文章:
ActiveMQ 快速上手:安装配置与基础通信实践(一)
一、引言 在当今分布式系统和微服务架构盛行的时代,消息通信作为实现系统间解耦、异步处理和可靠传输的关键技术,显得尤为重要。ActiveMQ 作为一款广泛应用的开源消息中间件,凭借其对 JMS 规范的全面支持、丰富的特性以及出色的性能…...
究竟什么是自动化测试?
自动化测试是一种软件测试方法,旨在通过使用自动化工具和脚本来执行测试任务,以减少人工操作,提高测试效率和准确性。 以下是对自动化测试的详细介绍: 一、定义与特点 定义:自动化测试是指利用自动化工具和脚本来执…...
【LLM+Code】Github Copilot Agent/VsCode Agent 模式PromptTools详细解读
一、前言 github copilot agent mode现在和vscode是强绑定的关系, 其实是一个东西: https://github.blog/news-insights/product-news/github-copilot-the-agent-awakens/https://code.visualstudio.com/docs/copilot/chat/chat-agent-mode 二、Syste…...
IDEA将本地的JAR文件手动安装到 Maven的本地仓库
例如这是要导入的依赖: mvn install:install-file -DfileD:\aliyun-java-sdk-ding.jar -DgroupIdcom.aliyun -DartifactIdaliyun-java-sdk-ding -Dversion1.0.0 -Dpackagingjar-DfileD:\aliyun-java-sdk-ding.jar 含义:指定要安装到本地 Maven 仓库的 …...
redis集群的三种部署方式
一、主从同步 redis的主从同步工作原理简单概括为: 1、从服务器(Slave Server)向(主服务器,Master)发送sync(同步)命令 2、master启动后台存盘进程,并收集所有修改数据命令 3、master完成存盘后,传送整个数据文件到slave 4、slave接受数据文件,加载到内存中完成首次…...
【GIT】github中的仓库如何删除?
你可以按照以下步骤删除 GitHub 上的仓库(repository): 🚨 注意事项: ❗️删除仓库是不可恢复的操作,所有代码、issue、pull request、release 等内容都会被永久删除。 🧭 删除 GitHub 仓库步骤…...
CIFAR10图像分类学习笔记(三)---数据加载load_cifar10
新创建一个load_cifar10源文件 需要导入的包 import glob from torchvision import transforms from torch.utils.data import DataLoader ,Dataset import os #读取工具 from PIL import Image import numpy as np 01同样定义10个类别的标签名数组 label_name ["airpl…...
基于Matlab的车牌识别系统
1.程序简介 本模型基于MATLAB,通过编程创建GUI界面,基于Matlab的数字图像处理,对静止的车牌图像进行分割并识别,通过编写matlab程序对图像进行灰度处理、二值化、腐蚀膨胀和边缘化处理等,并定位车牌的文字,实现字符的…...
【农气项目】基于适宜度的产量预报
直接上干货(复制到开发工具即可运行的代码) 1. 适宜度模型及作物適宜度计算方法 2. 产量分离 3. 基于适宜度计算产量预报 1. 适宜度模型及作物適宜度计算方法 // 三基点温度配置private final double tempMin;private final double tempOpt;private f…...
C#中实现JSON解析器
JSON(JavaScript Object Notation)即 JavaScript 对象表示法,是一种轻量级的数据交换格式。 起源与发展 JSON 源于 JavaScript 编程语言,是 JavaScript 对象字面量语法的一个子集。但如今它已经独立于 JavaScript,成…...
Android studio进阶开发(四)--okhttp的网络通信的使用
我们之前学过了socket服务器,这次我们继续来学习网络热门编程http/https的使用与交互 1)什么是Http协议? 答:hypertext transfer protocol(超文本传输协议),TCP/IP协议的一个应用层协议&#x…...
untiy 实现点击按钮切换天空盒子
1.新建材质DaySkybox和NightSkybox 设置 Shader 为 Skybox/6 Sided 2.创建ui 切换按钮,编写天空 盒子的脚本 using UnityEngine; using UnityEngine.UI;public class SkyboxSwitcher : MonoBehaviour {public Material daySkybox; // 拖入白天的天空盒材质publi…...
Docker从0-1搭建个人云盘(支持Android iOS PC)
一、Docker位置配置【遇到再大的事,先备份MYSQL数据库,说了多少遍】 ******************************************************************************************************************************************* docker rm -f $(docker ps -a -q…...
Java Agent 注入 WebSocket 篇
Agent 如果要对其进行Agent注入的编写,需要先理解三个名字premain,agentmain,Instrumentation premain方法在 JVM 启动阶段调用,一般维持权限的时候不会使用 agentmain方法在 JVM 运行时调用 常用的 Instrumentation实例为代理…...
Linux:git和gdb/cgdb
一:在XShell上使用git 步骤1:安装git命令行 sudo yum install git 步骤2:注册git账户和仓库,并点击克隆/下载,把HTTPS复制 步骤3: 在显示屏上输入下面命令,然后按提示输入自己的用户名和邮箱…...
深度对比评测:n8n vs Coze(扣子) vs Dify - 自动化工作流工具全解析
引言 在当今数字化转型的浪潮中,自动化工作流工具已成为企业和个人提升效率的关键利器。n8n、Coze(扣子)和Dify作为三款各具特色的自动化工具,在开发者社区和商业用户中都引起了广泛关注。本文将为您带来这三款工具的深度对比评测…...
如何用国产CAD软件皇冠CAD(CrownCAD)三维建模“橡胶座椅”?
皇冠CAD(CrownCAD)以『橡胶座椅』为例讲解“曲面设计、填充曲面、投影曲线、扫描曲面、放样曲面”等三维CAD操作技巧。 在现有模型边线、草图或曲面所定义的边框内填充一曲面。 点击进入填充曲面命令,其界面如下图所示: 各界面参…...
Whisper微调及制作方言数据集
本文不生产技术,只做技术的搬运工!!! 前言 最近在进行whisper微调实验,这个网上有很多成功案例,作者随机找了一个进行了复现,但是由于微调目的是适配本地方言,数据集的采集成为了一…...
实现营销投放全流程自动化 超级汇川推出信息流智能投放产品“AI智投“
随着消费者行为模式的多样化和媒体渠道的日益分散,数字营销行业面临挑战。传统人工数据分析效率低、误差率高,大幅制约广告预算效能。针对上述痛点,近期阿里巴巴旗下超级汇川广告平台推出“AI智投”信息流智能投放产品,基于AI大模…...
shell脚本2
条件测试分类 测试特定的表达式是否成立,当条件成立时,测试语句的返回值为0,否则为其他数值 测试命令格式:[ 条件表达式 ] 文件测试 格式:[ 操作符 文件或目录 ] -d:测试是否为目录(Di…...
2025年3月电子学会青少年机器人技术(五级)等级考试试卷-理论综合
青少年机器人技术等级考试理论综合试卷(五级) 分数:100 题数:30 一、单选题(共20题,共80分) 1. 2025年初,中国科技初创公司深度求索在大模型领域迅速崛起,其开源的大模型成为全球AI领域的焦…...
E3650工具链生态再增强,IAR全面支持芯驰科技新一代旗舰智控MCU
近日,全球嵌入式软件开发解决方案领导者IAR与全场景智能车芯引领者芯驰科技正式宣布,IAR Embedded Workbench for Arm已全面支持芯驰E3650,为这一旗舰智控MCU提供开发和调试一站式服务,进一步丰富芯驰E3系列智控芯片工具链生态&am…...
Linux之安装配置Nginx
Linux系统下安装配置Nginx的详细步骤如下: 一、准备工作 系统环境:确保Linux系统已安装,并且具有网络连接(以便在线安装依赖或下载Nginx)。 安装依赖:Nginx依赖于一些开发库和工具,如gcc、pcr…...
PC接入deepseek
<template> <div class"btn"> <el-button type"primary" plain click"openAIDrawer">AI问答</el-button> </div> <!-- deepSeek --> <el-drawer v-model"deepSeekData.drawerShow" :title&quo…...
Atlas 800I A2 离线部署 DeepSeek-R1-Distill-Llama-70B
一、环境信息 1.1、硬件信息 Atlas 800I A2 1.2、环境信息 注意:这里驱动固件最好用商业版,我这里用的社区版有点小问题 操作系统:openEuler 22.03 LTS NPU驱动:Ascend-hdk-910b-npu-driver_24.1.rc3_linux-aarch64.run NPU固…...
CF每日4题
1500左右的做到还是有点吃力 2093E 1500 二分答案 题意:给定一个长度为 n 的数组,现在要把它切成 k 份,求每一份最小的MEX中的最大值。 就是找最大值,但是这个值是所有段最小的值采用二分答案,二分这个值࿰…...
vue3 实现将html内容导出为图片、pdf和word
话不多说直接开始 本文使用到的开源插件库地址 wang1xiang 1.1 下载依赖 npm install html2canvas jspdf html-docx-js-typescript file-saver --save 2.1 下载工具 npm install html2image-pdf-word --save 3.1 页面使用 <template><div><div click"…...
手机端本地服务与后端微服务的技术差异
以下是手机内部本地服务与后端微服务架构及通信协议的对比分析,结合两者的核心设计差异与技术实现特点展开: 一、架构设计对比 维度手机端本地服务后端微服务核心目标资源效率、离线优先、动态更新高并发处理、分布式事务、服务治理服务拆分粒度按功能…...
音视频之H.265/HEVC环路后处理
H.265/HEVC系列文章: 1、音视频之H.265/HEVC编码框架及编码视频格式 2、音视频之H.265码流分析及解析 3、音视频之H.265/HEVC预测编码 4、音视频之H.265/HEVC变换编码 5、音视频之H.265/HEVC量化 6、音视频之H.265/HEVC环路后处理 类似于以往的视频编码标准,H…...
RSUniVLM论文精读
一些收获: 1. 发现这篇文章的table1中,有CDChat ChangeChat Change-Agent等模型,也许用得上。等会看看有没有源代码。 摘要:RSVLMs在遥感图像理解任务中取得了很大的进展。尽管在多模态推理和多轮对话中表现良好,现有模…...
redis特性及应用场景
文章目录 什么是redis?热库redis作为热库的特性redis适用场景 什么是redis? redis在系统架构中的位置就是冷热分离架构的热数据库位置, redis就是热库, 我们一般说缓存数据库。 其他的像MySQL、SQL Server这种关系数据库、MongoDB…...
Java中正则表达式使用方法
1. 正则表达式概述 正则表达式(Regular Expression,简称 Regex)是一种用于匹配字符串的模式工具。在 Java 中,正则表达式通过 java.util.regex 包实现,主要涉及以下两个类: Pattern:表示一个编…...
CSS基础
1. CSS入门 1.1. CSS是什么 CSS是Cascading Style Sheets的缩写,翻译为层叠样式表。CSS是一种样式表语言,用来描述HTML文档的表现方式,如字体、色彩、背景色等等。我们先从一段简单的CSS代码开始。 代码1 CSS示例 p {color: red; }这段代…...
【Linux系统篇】:什么是信号以及信号是如何产生的---从基础到应用的全面解析
✨感谢您阅读本篇文章,文章内容是个人学习笔记的整理,如果哪里有误的话还请您指正噢✨ ✨ 个人主页:余辉zmh–CSDN博客 ✨ 文章所属专栏:Linux篇–CSDN博客 文章目录 一.信号概念1.生活角度的信号2.技术应用角度的信号3.补充内容前…...
SpringSecurity源码解读AbstractAuthenticationProcessingFilter
一、介绍 AbstractAuthenticationProcessingFilter 是 Spring Security 框架里的一个抽象过滤器,它在处理基于表单的认证等认证流程时起着关键作用。它继承自 GenericFilterBean,并实现了 javax.servlet.Filter 接口。此过滤器的主要功能是拦截客户端发送的认证请求,对请求…...
Python torchvision.transforms 下常用图像处理方法
torchvision.transforms 是 PyTorch 用于处理图像数据的一个模块,提供了丰富的图像变换功能。 1. transforms.Compose 的使用方法 transforms.Compose 用于将多个 transforms 操作组合起来,形成一个变换序列,然后按顺序对图像进行处理。其输…...
Zynq7020 制作boot.bin及烧录到开发板全流程解析
Zynq7020作为Xilinx推出的经典SoC芯片,其PS(Processing System)与PL(Programmable Logic)协同工作的特性使其在嵌入式开发中广泛应用。然而,初次接触Zynq的开发者在制作启动文件boot.bin及烧录时࿰…...
【办公类-89-02】20250424会议记录模版WORD自动添加空格补全下划线
背景需求 4月23日听了一个MJB的征文培训,需要写会议记录 把资料黏贴到模版后,发现每行需要有画满下划线 原来做这套资料,就是手动按空格到一行末,有空格才会出现下划线,也就是要按很多的空格(凑满一行&…...
Python-36:饭馆菜品选择问题
问题描述 小C来到了一家饭馆,这里共有 nn 道菜,第 ii 道菜的价格为 a_i。其中一些菜中含有蘑菇,s_i 代表第 ii 道菜是否含有蘑菇。如果 s_i 1,那么第 ii 道菜含有蘑菇,否则没有。 小C希望点 kk 道菜,且希…...
某大型电解铝厂电解系统谐波治理装置改造沃伦森电气
电解铝行业谐波治理解决方案——无源滤波装置优化升级,保障稳定运行 在电解铝生产过程中,谐波污染问题严重影响电网电能质量,甚至可能导致滤波装置损坏,引发群爆事故。河南登封某大型电解铝厂通过无源滤波装置智能化改造ÿ…...
基于YOLO+DeepSeek的农作物病虫害检测系统
前言 本系统是一个基于YOLODeepSeek的农作物病虫害检测系统。 可使用YOLOV1-YOLOV12的任意模型进行目标检测。可以实现检测图片、批量检测图片、视频检测、摄像头检测四种方式。 能够检测出[“苹果-黑腐病”, “苹果-健康”, “苹果-结痂”, “甜椒-细菌性斑疹”, “甜椒-健康…...
Python实现技能记录系统
Python实现技能记录系统 来自网络,有改进。 技能记录系统界面如下: 具有保存图片和显示功能——允许用户选择图片保存,选择历史记录时若有图片可预览图片。 这个程序的数据保存在数据库skills2.db中,此数据库由用Python 自带的…...
【专题刷题】二分查找(一):深度解刨二分思想和二分模板
📝前言说明: 本专栏主要记录本人的基础算法学习以及LeetCode刷题记录,按专题划分每题主要记录:(1)本人解法 本人屎山代码;(2)优质解法 优质代码;ÿ…...
基于Python+Flask的MCP SDK响应式文档展示系统设计与实现
以下是使用Python Flask HTML实现的MCP文档展示系统: # app.py from flask import Flask, render_templateapp Flask(__name__)app.route(/) def index():return render_template(index.html)app.route(/installation) def installation():return render_templa…...
Flask + ajax上传文件(一)
一、概述 本教程将教你如何使用Flask后端和AJAX前端实现文件上传功能,包含完整的代码实现和详细解释。 二、环境准备 1. 所需工具和库 Python 3.xFlask框架jQuery库Bootstrap(可选,用于美化界面)2. 安装Flask pip install flask三、项目结构 upload_project/ ├── a…...
【每天一个知识点】熵(Entropy)
“熵(Entropy)”是信息论、热力学、机器学习等多个领域的核心概念。它可以用一句话概括为: 🔑 熵表示系统的不确定性或信息混乱程度。 📚 一、信息论中的熵(Information Entropy) 在 Claude Sh…...
GIT 使用小记
全局设置 PS C:\workspace> git config --global user.name "FreeMan" PS C:\workspace> git config --global user.email "12323772wawhyuser.noreply.gitee.com" PS C:\workspace> git remote add origin https://gitee.com/wawhy/mountain.git…...
如何保证高防服务器中的系统安全?
对于高防服务器中的系统安全,企业通常会采取一系列的防护措施和策略防止网络攻击、入侵、恶意软件和其他网络安全威胁,下面是几个较为主要的安全防护措施,能够帮助企业提升高防服务器的安全性。 定期更新服务器中操作系统以及所有安装的软件&…...
【go语言】window环境从源码编译go
背景 早就听过go语言已经实现自举, 也就是使用旧版本go,来编译新版源码,得到新版本go。 步骤 1. 下载源码 git clone https://github.com/golang/go.git 2. 开始make cd go\src make.bat 3. 等待编译 卡住就按下回车 验证新版本 ……...
医学图像(DICOM数据)读取及显示(横断面、冠状面、矢状面、3D显示)为什么用ITK+VTK,单独用ITK或者VTK能实一样功能吗?
在医学图像处理中,结合使用 ITK 和 VTK 是常见的做法,因为它们各自专注于不同的核心功能。以下是逐步解释为何代码中同时使用两者,以及单独使用是否可行的分析: 1. 为什么用ITK处理DICOM数据? 1.1 ITK的DICOM处理优势…...