当前位置: 首页 > news >正文

Linux 部署 rocketmq centos7

mq部署方案

1、rocketmq 顺序消费记录
一个master ,一个 brocker ,多个group ,多个topic,采用集群消费模式。
注意 一个group 对应一个 topic。 生产者 和 消费者 可以有多个,但是 主题和分组 都是一对一的。这样保证了 消息在集群模式下 的 顺序存储 和消费。

Linux 部署rocketmq centos7

参考资料:
https://blog.csdn.net/YuanFudao/article/details/130307086
进入 opt目录
https://www.yisu.com/ask/32687639.html

1、设置rocketmq日志路径
1、先创建mq安装目录
1、上传压缩包
1、解压
1、配置环境变量
1、配置日志路径(日志配置文件)
1、配置数据存储文件路径(主要是store文件)
1、配置占用内存大小(那几个启动文件)
1、修改 broker.conf 内容 ip地址等
1、开放端口
开始

1、

Mq安装目录
/home/software/rocketmq-dev/
/home/software/rocketmq-dev/rocketmq5.1.4
Mq日志路径
/home/software/rocketmq-dev/logs/rocketmqlogs/

2、 配置环境变量

ls .bash_*
https://www.cnblogs.com/wucongzhou/p/12579468.html
我们现在的环境变量 。如java8 我们是配置在 用户变量这一级别的
配置在了 用户目录下 的 .bash_profile 文件里
cat .bash_profile
export JAVA_HOME=/usr/bin/java
export PATH= P A T H : PATH: PATH:JAVA_HOME
1、rocketmq 安装路径放到 linux /home目录下 在 .bash_profile文件里
rocketmq 安装目录
export ROCKETMQ_HOME=/home/software/rocketmq-dev/rocketmq5.1.4
将 rocketmq 环境变量加入到 PATH中
export PATH= R O C K E T M Q H O M E / b i n : ROCKETMQ_HOME/bin: ROCKETMQHOME/bin:PATH
客户端NameServer的地址
export NAMESRV_ADDR=10.xx.xx.xx:9876

应用更改
source .bash_profile

2、修改 mq配置文件
(1)修改 broker.conf文件
在 mq 安装目录的 conf文件夹里
在修改mq 安装目录的bin文件夹里 这个是复制 conf里的
(2)修改 启动时的内存大小
进入到 bin 的目录结构
runserver.sh runbroker.sh
参考 也可以参考自己的 Windows配置
修改runserver.sh
JAVA_OPT=“ J A V A O P T − s e r v e r − X m s 512 m − X m x 512 m − X m n 256 m − X X : M e t a s p a c e S i z e = 128 m − X X : M a x M e t a s p a c e S i z e = 320 m " J A V A O P T = " {JAVA_OPT} -server -Xms512m -Xmx512m -Xmn256m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m" JAVA_OPT=" JAVAOPTserverXms512mXmx512mXmn256mXX:MetaspaceSize=128mXX:MaxMetaspaceSize=320m"JAVAOPT="{JAVA_OPT} -XX:+UseConcMarkSweepGC -XX:+UseCMSCompactAtFullCollection -XX:CMSInitiatingOccupancyFraction=70
-XX:+CMSParallelRemarkEnabled -XX:SoftRefLRUPolicyMSPerMB=0 -XX:+CMSClassUnloadingEnabled -XX:SurvivorRatio=8 -XX:-UseParNewGC” JAVA_OPT=“ J A V A O P T − v e r b o s e : g c − X l o g g c : {JAVA_OPT} -verbose:gc -Xloggc: JAVAOPTverbose:gcXloggc:{GC_LOG_DIR}/rmq_srv_gc_%p_%t.log
-XX:+PrintGCDetails -XX:+PrintGCDateStamps” JAVA_OPT=“ J A V A O P T − X X : + U s e G C L o g F i l e R o t a t i o n − X X : N u m b e r O f G C L o g F i l e s = 5 − X X : G C L o g F i l e S i z e = 30 m " e l s e J A V A O P T = " {JAVA_OPT} -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=5 -XX:GCLogFileSize=30m" else JAVA_OPT=" JAVAOPTXX:+UseGCLogFileRotationXX:NumberOfGCLogFiles=5XX:GCLogFileSize=30m"elseJAVAOPT="{JAVA_OPT} -server -Xms512 -Xmx512m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m”

修改 runbroker.sh
JAVA_OPT=“ J A V A O P T − s e r v e r − X m s 512 m − X m x 512 m " c h o o s e g c o p t i o n s J A V A O P T = " {JAVA_OPT} -server -Xms512m -Xmx512m" choose_gc_options JAVA_OPT=" JAVAOPTserverXms512mXmx512m"choosegcoptionsJAVAOPT="{JAVA_OPT} -XX:-OmitStackTraceInFastThrow”
JAVA_OPT=“ J A V A O P T − X X : + A l w a y s P r e T o u c h " J A V A O P T = " {JAVA_OPT} -XX:+AlwaysPreTouch" JAVA_OPT=" JAVAOPTXX:+AlwaysPreTouch"JAVAOPT="{JAVA_OPT} -XX:MaxDirectMemorySize=1g”
(3)
修改 mq存储文件和 日志输出位置
默认输出位置为
默认路径 /root/logs/rocketmqlogs。
Linux centos7 更改rocketmq存储文件地址
https://blog.csdn.net/m0_73570288/article/details/127275904

Windows 数据存储使用 默认路径,
Linux 使用指定路径
就是在 conf 文件夹下面 broker.conf 文件里填写 路径即
日志存储位置:
/home/software/rocketmq-dev/logs
数据文件存储位置:
/home/software/rocketmq-dev/store
在 store 里创建相应文件夹
commitlog 等文件夹
#存储路径
storePathRootDir=/home/software/rocketmq-dev/store
#commitLog存储路径
storePathCommitLog=/home/software/rocketmq-dev/store/commitlog
#消费队列存储路径
storePathConsumeQueue=/home/software/rocketmq-dev/store/consumequeue
#消息索引存储路径
storePathIndex=/home/software/rocketmq-dev/store/index
#checkpoint文件存储路径
storeCheckpoint=/home/software/rocketmq-dev/store/checkpoint
#abort文件存储路径
abortFile=/home/software/rocketmq-dev/store/abort

但是执行后 store文件和有这些文件
abort checkpoint compaction consumequeue lock
abort.bak commitlog config index timerwheel
abort.bak 、abort、lock、timerwheel、checkpoint 是文件,其余是文件夹

(3)修改日志文件输出路径,
修改 conf 目录下 6各日志的xml文件
rmq.broker.logback.xml
rmq.client.logback.xml
rmq.controller.logback.xml
rmq.namesrv.logback.xml
rmq.proxy.logback.xml
rmq.tools.logback.xml

${LOG_DIR}${file.separator}logs${file.separator}rocketmqlogs${brokerLogDir:-${file.separator}}${brokerContainerLogDir}${file.separator}broker_default.log 3、 安装 rocketmq_dashboard 目录 /home/software/rocketmq_dashboard 日志输出在此目录下 4、 测试启动 https://www.cnblogs.com/xl99/p/14294622.html?ivk_sa=1024320u 前提 bin文件夹下 复制了 conf文件夹下的broker.conf文件,因为要指定 broker的信息 也可以不放在同一目录下 不过就得写全路径 这是在同一个目录下的示例 都在bin目录 mqbroker.cmd -c your_config_file.properties

(1)启动namesrv
cd /home/software/rocketmq-dev/rocketmq5.1.4/bin 执行
nohup sh mqnamesrv &
出现忽略输入并把输出追加到"nohup.out" 直接回车即可
查看是否启动成功
tail nohup.out
看到 The Name Server boot success… 则为启动成功
Pid = 3819411
(2)启动broker
nohup sh mqbroker -n xx.xx.xx.xx:9876 autoCreateTopicEnable=true -c broker.conf &
查看是否成功 输出如下成功了
tail nohup.out
The broker[localhost.localdomain, xx.xx.xx.xx:9876 boot success. serializeType=JSON and name server is xx.xx.xx.xx:9876

5、查看是否启动成功
使用jps查看 服务是否启动

6、
启动 rocketmq_dashboard
jar包所在目录
cd /home/software/rocketmq_dashboard
执行 ./startup.sh
执行成功输出 Application started with PID: 3859794
可能会提示权限不够 就执行下面命令
chmod +x startup.sh

脚本内容startup.sh
#!/bin/bash
#定义jar文件的名称
JAR_FILE=rocketmq-dashboard-1.0.0.jar
# 启动jar文件
nohup java -Dfile.encoding=utf-8 -jar $JAR_FILE --rocketmq.config.namesrvAddr=xx.xx.xx.xx:9876 > dashboard-consol.log 2>&1 &
echo “Application started with PID: $!”

7、
关闭 rocketmq
./mqshutdown broker
./mqshutdown namesrv

https://www.cnblogs.com/jifeng/p/10175124.html

六、遇到问题
1、使用控制面板 查询 消息 无返回值
面板日志显示
DESC: The stats <TOPIC_PUT_NUMS> not exist
就是因为 你还没有像broker创建数据 ,有数据后 就不会报错了

后续完善:
在 broker conf 文件里 添加 listenPort = 10911
面板启动时 指定

另一个问题
发送消息到 rocketmq 服务端失败
Caused by: org.apache.rocketmq.client.exception.MQBrokerException: CODE:service not available now. It may be caused by one of the following reasons: the broker’s disk is full [CL: 0.92 CQ: 0.92 INDEX: 0.92], messages are put to the slave, message store has been shut down, etc. BROKER: xx.xx.xx.xx:10911
解决办法:
https://github.com/apache/rocketmq/issues/3750
https://blog.csdn.net/muriyue6/article/details/130607492
在 conf 文件夹下 broker.conf文件最后面添加如下属性
diskMaxUsedSpaceRatio=99
在 runserver.sh 、runbroker.sh 中 扩大内存

7、
目前 mq的 broker.conf文件的内容为
broker.conf
brokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
listenPort = 10911
namesrvAddr = xx.xx.xx.xx:9876
brokerIP1 = xx.xx.xx.xx
diskMaxUsedSpaceRatio=99
#存储路径
storePathRootDir=/home/software/rocketmq-dev/store
#commitLog存储路径
storePathCommitLog=/home/software/rocketmq-dev/store/commitlog
#消费队列存储路径
storePathConsumeQueue=/home/software/rocketmq-dev/store/consumequeue
#消息索引存储路径
storePathIndex=/home/software/rocketmq-dev/store/index
#checkpoint文件存储路径
storeCheckpoint=/home/software/rocketmq-dev/store/checkpoint
#abort文件存储路径
abortFile=/home/software/rocketmq-dev/store/abort

1
2024.7.14遇到问题记录
因为linux的盘符使用 占满 只剩 430k了 ,已经超过 99%了。
所以线上向mq 服务端发消息失败。
后来是因为 我们的文件服务器 有人一次性上传了 5各G左右的文件导致。

2
记录异常 rocketmq的 异常事故
生产服务器上 有一个 rocketmq的 server 和 brocker ip= 10.82.xxx.1
测试服务器 也部署了一套rocketmq的 server 和brocker ip=10.82.xxx.2
我在测试服务器上 启动 server 然后 要启动 brocker
执行命令
nohup sh mqbroker -n 10.82.xxx.2:9876 autoCreateTopicEnable=true -c broker.conf &
但是不小心 将 这里的 ip指向了 生产服务器的ip
nohup sh mqbroker -n 10.82.xxx.1:9876 autoCreateTopicEnable=true -c broker.conf &
导致 生产上 通过控制台 查看 发现 集群那里显示的 brocker 竟然是 测试环境的 ip地址。
然后 就发生了 生产环境的 consumer 在不断地消费 测试环境上的 历史的 消息。导致数据库 入库了很多 错误的数据库。
最后 解决方式 就是 将 生产的 rocketmq 的 store文件夹都删除,然后重新创建了 一个空的 store 文件夹 ,重新启动 rocketmq 服务 server 和 brocker 。这下就好了。
因为目前并没有 恢复历史数据。 好在我们每天凌晨12点会备份 昨天的 store文件。

只删除 store文件中 如下文件即可
abort abort.bak checkpoint commitlog compaction config consumequeue index lock timerwheel

里面的完全删除 commitlog 、完全删除 consumequeue 、完全删除index
部分删除 config中的 四个文件
consumerOffset.json delayOffset.json
consumerOffset.json.bak delayOffset.json.bak
2、由于我们的mq 目前是 单线程处理任务消息的,处理不及时 也会导致 后面的消息 堆积。

RocketMQ 客户端突然不消费了,部分不消费,部分队列不消费
3、另一个可能的原因 由于某个任务业务处理时间过长 导致线程一直没有返回 block,线程一直处于 runnable状态.
可以看下消费进度,看看哪里的问题。看topic消费时间、看Brocker
看 死信队列中的 任务有哪些。

4、当一个消息 消费失败,会被放到死信队列中

6、
解耦合 消息处理 和 业务处理 拆成两个线程分别处理

相关文章:

Linux 部署 rocketmq centos7

mq部署方案 1、rocketmq 顺序消费记录 一个master &#xff0c;一个 brocker &#xff0c;多个group &#xff0c;多个topic&#xff0c;采用集群消费模式。 注意 一个group 对应一个 topic。 生产者 和 消费者 可以有多个&#xff0c;但是 主题和分组 都是一对一的。这样保证…...

02_MySQL安装及配置

文章目录 一、下载二、安装及配置2.1、选择安装类型2.2、检查需要的依赖2.3、安装2.4、配置2.4.1、配置类型和网络2.4.2、配置账户和角色2.4.3、配置Windows服务2.4.4、让配置生效 2.5、验证是否安装成功 三、卸载3.1、运行MySQL安装工具3.2、卸载及清理3.3、卸载之后的检查工作…...

银行的压力测试如何进行?

为什么要进行压力风险测试&#xff1f; 压力风险测试的最终目的是测试银行在极度恶劣的市场环境中是否有足够的资本维持运转。 题主链接中的一级资本充足率(Tier 1 capital ratio) 亦即衡量标准&#xff0c;这个数字越大&#xff0c;表明银行资本约充裕&#xff0c;可以在停止…...

7、Linux C 进程通信

一、无名管道&#xff08;pipe&#xff09; 1. 函数介绍 #include <unistd.h> ​ int pipe(int pfd[2]); 参数&#xff1a;pfd是一个包含两个整数的数组&#xff0c;pfd[0]为读描述符&#xff0c;pfd[1]为写描述符。 返回值&#xff1a;成功时返回0&#xff0c;失败时…...

Android Framework 层 Hook 技术详解

目录 Hook 技术概述 什么是 Hook 技术? Hook 技术的核心原理 Hook 技术的进化与创新 Hook 技术的魅力与局限 Android Framework 层结构 Framework 层在 Android 中的位置 Framework 层的核心组件 为什么 Framework 层适合 Hook? 常用 Hook 方法 方法替换:换个 “芯…...

java接口中 使用@RequestParam和@RequestPart区别

1. 介绍 这两个注解都是spring注解。 RequestParam通常用于获取请求参数&#xff0c;这些参数可以是URL中的查询参数&#xff0c;也可以是表单数据中的字段。而RequestPart则是用于处理多部分&#xff08;multipart&#xff09;请求中的部分&#xff0c;特别是当上传文件或处理…...

CentOS-7.0系统基础操作

配置ip地址 编辑网卡文件&#xff1a; vi etc/sysconfig/network-scripts/ifcfg-ens33 在网卡文件里参照如下设置&#xff1a; BOOTPROTO"static" IPADDR192.168.61.233 GATEWAY192.168.61.2 NETMASK255.255.255.0 ONBOOT"yes" 防火墙管理 开启防火墙&am…...

全星研发管理APQP软件系统:驱动汽车产品研发全周期,打造高效合规的质量管理引擎

全星研发管理APQP软件系统&#xff1a;驱动汽车产品研发全周期&#xff0c;打造高效合规的质量管理引擎 在汽车、电子、医疗器械等高度依赖质量管理的行业中&#xff0c;APQP&#xff08;先期产品质量策划&#xff09;作为国际通用的产品开发管理框架&#xff0c;是确保产品从…...

Maven 的下载与安装

背景 为什么要建立本地Maven &#xff0c;idea 默认的maven 仓库是放在系统盘的&#xff0c;依赖每次都存在系统盘用就了C盘就爆炸了&#xff0c;所有我们可以在本地其他盘安装maven 建立仓库。 idea 默认的依赖拉取地址是maven 官网&#xff0c;我们建立本地仓库&#xff0c…...

26考研——排序_插入排序(8)

408答疑 文章目录 二、插入排序基本概念插入排序方法直接插入排序算法描述示例性能分析 折半插入排序改进点算法步骤性能分析 希尔排序相关概念示例分析希尔排序的效率效率分析空间复杂度时间复杂度 九、参考资料鲍鱼科技课件26王道考研书 二、插入排序 基本概念 定义&#x…...

Mem0 Prompt优化

在使用mem0的时候&#xff0c;系统中自带的提取事件的Prompt&#xff0c; 效果很差&#xff0c;我们可以按照我们的需求修改 from datetime import datetime, timedeltacustom_fact_extraction_prompt f"""你是一位个人信息整理专家&#xff0c;专注于准确存…...

C++ STL常用算法之常用算术生成算法

常用算术生成算法 学习目标: 掌握常用的算术生成算法 注意: 算术生成算法属于小型算法&#xff0c;使用时包含的头文件为 #include <numeric> 算法简介: accumulate // 计算容器元素累计总和 fill // 向容器中添加元素 accumulate 功能描述: 计算区间内容器元素…...

Kubernetes Webhook必要知识点:原理、配置与实践

#作者&#xff1a;邓伟 文章目录 1. 什么是 Kubernetes Webhook&#xff1f;2. Webhook 的工作原理2.1 准入控制器&#xff08;Admission Controller&#xff09;2.2 Webhook 类型 3. Webhook 的配置3.1 Webhook 配置文件3.2 配置字段说明 4. Webhook 的开发与部署4.1 开发 We…...

IGS 转 STL 全攻略:迪威模型在线转码助力 3D 建模

在 3D 建模与制造业领域&#xff0c;不同文件格式之间的转换是经常面临的重要任务。IGS 和 STL 作为其中两种常用格式&#xff0c;前者凭借出色的曲面表达能力&#xff0c;在 CAD 领域广泛应用&#xff1b;后者凭借简单的三角网格结构&#xff0c;成为 3D 打印、快速成型的行业…...

【Bug】记录2025年遇到的Bug以及修复方案

--------------------------------------------------------分割线 2025.3.25-------------------------------------------------------windows环境下通过命令行终端&#xff08;必须是命令行下&#xff0c;直接赋值传递&#xff0c;代码正常&#xff09;的形式传递字符串时&a…...

Unity UGUI - 六大基础组件

目录 一、Canvas上 1. Canvas&#xff1a;复制渲染子UI控件 2. ✨Canvas Scaler✨&#xff1a;画布分辨率自适应 3. Graphics Raycaster&#xff1a;射线事件响应 4. ✨Rect Transform✨&#xff1a;UI位置锚点对齐 二、Event System上 5. Event System 6. Standalone …...

TCP网络编程与多进程并发实践

一、引言 在网络编程中&#xff0c;TCP&#xff08;传输控制协议&#xff09;是一种面向连接的、可靠的、基于字节流的传输层通信协议。而多进程并发则是一种提高服务器处理能力的有效手段&#xff0c;允许服务器同时处理多个客户端的请求。本文将详细介绍如何使用 TCP 协议进…...

IM腾讯Trtc与vod云点播:实现合流录制并上传,根据参数返回视频地址

全文目录,一步到位 1.前言简介1.1 专栏传送门1.1.1 文档传送门 2. java基础使用2.1 准备工作2.1.1 云控制台获取(密钥和密钥secret)2.1.2 找到trtc控制台2.1.3 vod云点播控制台 2.2 使用准备的数据进行操作2.2.0 引入依赖2.2.1 创建TrtcUtils工具类2.2.2 TrtcReqDTO 录制请求dt…...

HTTP协议手写服务器

目录 一、请求的是Web根目录 二、GET方法通过URL传参 三、根据资源类型对应出Content-Type值 四、Http代码 项目完整源代码&#xff1a;Http 周不才/cpp_linux study - 码云 - 开源中国 一、请求的是Web根目录 如果URL中请求的资源是Web根目录&#xff0c;则自动跳转到主…...

Uni-app入门到精通:subPackages节点为小程序的分包加载配置

subPackages节点用于为小程序的分包加载配置。因小程序有体积和资源加载限制&#xff0c;各小程序平台提供了分包方式&#xff0c;以加快小程序的下载和启动速度。主包用于放置默认启动页面、babBar页面&#xff0c;以及一些所有分包都会用到的公共资源或JS脚本&#xff1b;而分…...

DeepSeek本地部署(linux)

一、下载并安装Ollama 1.下载Ollama Ollama官网:Ollama 点击"Download",会跳转至下载页面。 1.1在线下载安装 可复制此命令到Linux服务器进行在线下载,如下载速度过慢,可选择离线下载安装。 curl -fsSL https://ollama.com/install.sh | sh1.2离线下载安装 …...

工具——(常用的软件)视频编辑器

软件工具 1、视频编辑器&#xff1a;filmora 9 2、图标无损放大&#xff1a;oCam 或者 Adobe Illustrator CS6 3、图片编辑&#xff1a;Photoshop CS6 4、截图置顶工具&#xff1a;Snipaste 或者 PixPin 5、抢票&#xff1a;Bypass 6、文本日志工具&#xff1a;N…...

Kafka 多线程开发消费者实例

目前&#xff0c;计算机的硬件条件已经大大改善&#xff0c;即使是在普通的笔记本电脑上&#xff0c;多核都已经是标配了&#xff0c;更不用说专业的服务器了。如果跑在强劲服务器机器上的应用程序依然是单线程架构&#xff0c;那实在是有点暴殄天物了。不过&#xff0c;Kafka …...

org.apache.maven.surefire:surefire-junit-platform:jar:2.22.2 Maven打包失败

org.apache.maven.surefire:surefire-junit-platform:jar:2.22.2 解决办法 勾上这个&#xff0c;打包时跳过测试代码...

在Ubuntu中固定USB设备的串口号

获取设备信息 lsusb # 记录设备的Vendor ID和Product ID&#xff08;例如&#xff1a;ID 0403:6001&#xff09;# 获取详细属性&#xff08;替换X和Y为实际设备号&#xff09; udevadm info -a /dev/ttyUSBX 结果一般如下 创建udev规则文件 sudo gedit /etc/udev/rules.d/us…...

Java后端开发: 如何安装搭建Java开发环境《安装JDK》和 检测JDK版本

文章目录 一、JDK的安装1、 打开 Oracle 官方网址2、点击产品 二、检测JDK是否安装成功以及JDK版本的查看1. 打开命令行窗口检测是否安装成功查看 JDK 版本 一、JDK的安装 1、 打开 Oracle 官方网址 Oracle官网地址:https://www.oracle.com/cn/ 2、点击产品 打开下载的JDK文件…...

AudioFlinger与AudioPoliceManager初始化流程

AF/APF启动流程 在启动AudioSeriver服务的过程中会对启动AF/APF。main_audioserver.cpp有如下代码&#xff1a; AudioFlinger::instantiate();AudioPolicyService::instantiate();AF初始化流程 1.AudioFlinger::instantiate() 1.1 AudioFlinger构造函数 void AudioFlinger:…...

Keepalive+LVS+Nginx+NFS高可用架构

KeepaliveLVSNginxNFS高可用架构 1. NFS 业务服务器&#xff08;192.168.98.138&#xff09;2. Web服务集群&#xff08;搭建RS服务器&#xff09;开机自启动自动挂载配置nginx&#xff08;为了区分Web1与Web2访问的文件内容&#xff09; 3. LVS主机&#xff08;Keepalivedlvs&…...

SpringBoot分布式项目订单管理实战:Mybatis最佳实践全解

一、架构设计与技术选型 典型分布式订单系统架构&#xff1a; [网关层] → [订单服务] ←→ [分布式缓存]↑ ↓ [用户服务] [支付服务]↓ ↓ [MySQL集群] ← [分库分表中间件]技术栈组合&#xff1a; Spring Boot 3.xMybatis-Plus 3.5.xShardingSpher…...

ctfshow WEB web8

首先确定注入点&#xff0c;输入以下payload使SQL恒成立 ?id-1/**/or/**/true 再输入一下payload 使SQL恒不成立 ?id-1/**/or/**/false 由于SQL恒不成立, 数据库查询不到任何数据, 从而导致页面空显示 由以上返回结果可知&#xff0c;该页面存在SQL注入&#xff0c;注入点…...

当AI代写作业成为常态:重构智能时代的教育范式

2023年春季,某重点高中教师发现全班35%的作文呈现相似AI生成特征;同年国际数学竞赛中,参赛选手使用AI解题引发伦理争议。当GPT-4在SAT考试中取得1520分,当Claude3能撰写专业学术论文,教育领域正面临百年未有之大变革。这场技术革命倒逼我们重新思考:在AI能完成知识性任务…...

基于杜鹃鸟鲶鱼优化(Cuckoo Catfish Optimizer,CCO)算法的多个无人机协同路径规划(可以自定义无人机数量及起始点),MATLAB代码

一、杜鹃鸟鲶鱼优化算法 杜鹃鸟鲶鱼优化&#xff08;Cuckoo Catfish Optimizer&#xff0c;CCO&#xff09;算法模拟了杜鹃鸟鲶鱼的搜索、捕食和寄生慈鲷行为。该算法的早期迭代侧重于执行多维包络搜索策略和压缩空间策略&#xff0c;并结合辅助搜索策略来有效限制慈鳔的逃逸空…...

Ubuntu 22.04.5 LTS 设置时间同步 ntp

提示&#xff1a;文章为操作记录&#xff0c;以备下次使用 文章目录 前言一、设置ntp1.1替换国内源1.2 更新源&安装1.3 验证 前言 设置时间同步&#xff0c;环境版本 # cat /etc/os-release PRETTY_NAME"Ubuntu 22.04.5 LTS" NAME"Ubuntu" VERSION_…...

搭建前端环境和后端环境

搭建前端环境 ①、安装vscode&#xff0c;并安装相应的插件工具 ②、安装node.js&#xff0c;可以选择当前版本&#xff0c;或者其他版本 ③、创建工作区 创建一个空文件夹&#xff0c;然后通过vscode工具打开&#xff0c;保存为后缀名为.code-workspace ④、从gitee…...

【VirtualBox 安装 Ubuntu 22.04】

网上教程良莠不齐&#xff0c;有一个CSDN的教程虽然很全面&#xff0c;但是截图冗余&#xff0c;看蒙了给我&#xff0c;这里记录一个整洁的教程链接。以备后患。 下载安装全流程 UP还在记录生活&#xff0c;看的我好羡慕&#xff0c;呜呜。 [VirtualBox网络配置超全详解]&am…...

好用的Markdown阅读编辑器Typora破解记录

Typora破解 一、下载Typora二、安装Typora三、破解Typora &#x1f600; 记录一下Typora破解记录&#xff0c;怕不常用忘记咯&#xff0c;感觉自己现在的脑子就像我的肠子一样&#xff0c;刚装进去就么得了。。。&#x1f614; Typroa算是用起来很舒服的Markdown阅读器了吧&am…...

系统与网络安全------Windows系统安全(1)

资料整理于网络资料、书本资料、AI&#xff0c;仅供个人学习参考。 用户账号基础 本地用户账号基础 用户账号概述 用户账号用来记录用户的用户名和口令、隶属的组等信息 每个用户账号包含唯一的登录名和对应的密码 不同的用户身份拥有不同的权限 操作系统根据SID识别不同…...

使用 Docker Compose 在单节点部署多容器

Docker Compose 是什么 Docker Compose 是一个用于运行多容器应用的工具, 通过一个docker-compose.yml文件, 配置应用的服务、网络和卷&#xff0c;然后使用简单的命令启动或停止所有服务 为什么需要 Docker Compose 当你有一个包含多个相互依赖的容器应用时&#xff0c;手动…...

CSS中的em,rem,vm,vh详解

一&#xff1a;em 和 rem 是两种相对单位&#xff0c;它们常用于 CSS 中来设置尺寸、字体大小、间距等&#xff0c;主要用于更灵活和响应式的布局设计。它们与像素&#xff08;px&#xff09;不同&#xff0c;不是固定的&#xff0c;而是相对于其他元素的尺寸来计算的。 1. em …...

MQTT之重复消息(5、TCP重连和MQTT重连)

目录 1. TCP 协议层的重传&#xff08;原生机制&#xff09; 2. 触发 TCP 重传的具体场景 3、TCP 重传的关键参数&#xff08;了解&#xff09; 第一、重传超时(RTO - Retransmission Timeout) 第二、重传次数 第三、累计时间 vs 本次 RTO 的区别 第四.常见问题解答 第…...

Ground Truth(真实标注数据):机器学习中的“真相”基准

Ground Truth&#xff1a;机器学习中的“真相”基准 文章目录 Ground Truth&#xff1a;机器学习中的“真相”基准引言什么是Ground Truth&#xff1f;Ground Truth的重要性1. 模型训练的基础2. 模型评估的标准3. 模型改进的指导 获取Ground Truth的方法1. 人工标注2. 众包标注…...

Android学习总结之通信篇

一、Binder跨进程通信的底层实现细节&#xff08;挂科率35%&#xff09; 高频问题&#xff1a;“Binder如何实现一次跨进程方法调用&#xff1f;”   候选人常见错误&#xff1a;   仅回答“通过Binder驱动传输数据”&#xff0c;缺乏对内存映射和线程调度的描述混淆Binde…...

自动化发布工具CI/CD实践Jenkins部署与配置教程

1. 前言背景 其实一直想把jenkins 的笔记整理下&#xff0c;介于公司这次升级jenkins2.0 &#xff0c;根据自己部署的一些经验&#xff0c;我把它整理成笔记。 之前我们的jenkins1.0 时代 还一直停留在 free style 或者 maven 风格的项目&#xff0c;随着项目的日益增多&#x…...

kubernet在prometheus+alertmanager+grafana框架下新增部署loki模块

整个框架拓扑图 #mermaid-svg-OK7jgNZ2I7II8nJx {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-OK7jgNZ2I7II8nJx .error-icon{fill:#552222;}#mermaid-svg-OK7jgNZ2I7II8nJx .error-text{fill:#552222;stroke:#552…...

Ubuntu下UEFI安全启动安装Nvdia驱动

简介 众所周知&#xff0c;Ubuntu默认使用Nouveau开源驱动&#xff0c;其性能受限&#xff0c;因此我们需要安装Nvidia专用驱动。 安装专用驱动的一般方法非常简单&#xff0c;只需要sudo ubuntu-drivers devices && sudo ubuntu-drivers autoinstall即可&#xff0c…...

Java多线程与高并发专题—— CyclicBarrier 和 CountDownLatch 有什么异同?

引入 上一篇我们了解CountDownLatch的原理和常见用法&#xff0c;在CountDownLatch的源码注释中&#xff0c;有提到&#xff1a; 另一种典型用法是将一个问题分解为 N 个部分&#xff0c;用一个Runnable描述每个部分&#xff0c;该Runnable执行相应部分的任务并对闭锁进行倒计…...

【深度学习】不管理论,入门从手写数字识别开始

1. 环境安装 学习深度学习&#xff0c;开发语言是Python。Python开发工具有很多。其中 anaconda vscode的Python开发环境很好用&#xff0c;建议使用这个组合。 编写手写数字识别测试代码&#xff0c;需要在使用Anaconda安装以下4个库&#xff1a; NumpyScipymatplotlibsci…...

Docker使用ubuntu

1. 更换源 sudo nano /etc/docker/daemon.json //daemon.conf查找最新可用的源1、2&#xff0c;手动查找会不断更新&#xff01; 1.1 添加DNS sudo nano /etc/resolv.confnameserver 8.8.8.8 nameserver 8.8.4.4 2. 修改配置文件后重新加载 sudo systemctl daemon-relo…...

Windows 系统下多功能免费 PDF 编辑工具详解

IceCream PDF Editor是一款极为实用且操作简便的PDF文件编辑工具&#xff0c;它完美适配Windows操作系统。其用户界面设计得十分直观&#xff0c;哪怕是初次接触的用户也能快速上手。更为重要的是&#xff0c;该软件具备丰富多样的强大功能&#xff0c;能全方位满足各类PDF编辑…...

影响HTTP网络请求的因素

影响 HTTP 网络请求的因素 1. 带宽 2. 延迟 浏览器阻塞&#xff1a;浏览器会因为一些原因阻塞请求&#xff0c;浏览器对于同一个域名&#xff0c;同时只能有4个连接&#xff08;这个根据浏览器内核不同可能会有所差异&#xff09;&#xff0c;超过浏览器最大连接数限制&…...