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

STM32单片机使用CAN协议进行通信

CAN总线(控制器局域网总线)

理论知识

CAN总线是由BOSCH公司开发的一种简洁易用、传输速度快、易扩展、可靠性高的串行通信总线

CAN总线特征

  • 两根通信线(CAN_H、CAN_L),线路少,无需共地
  • 差分信号通信(相对的是单端信号),抗干扰能力强(意思是当有干扰时,两根线同时产生波动,但两根线的差值不变)
  • 高速CAN(ISO11898):125k~1Mbps,<40m
  • 低速CAN(ISO11519):10k~12kbps,<1km
  • 异步,无需时钟线,通信速率由设备各自约定
  • 半双工,可挂载多设备,多设备同时发送数据时通过仲裁判断先后顺序
  • 11位/29位报文ID,用于区分消息功能,同时决定优先级
  • 可配置1~8字节的有效载荷
  • 可实现广播式和请求式两种传输方式
  • 应答、CRC校验、位填充、位同步、错误处理等特性
主流通信协议对比
名称引脚双工时钟电平设备应用场景
UARTTX、RX全双工异步单端点对点两个设备互相通信
I2CSCL、SDA半双工同步单端多设备单主控外挂多个模块
SPISCK、MOSI、MISO、SS全双同步单端多设备单模块外挂多个模块(高速,可达几Mbps)
CANCAN_H、CAN_L半双工异步差分多设备多个主控互相通信

 CAN硬件电路

  • 每个设备通过CAN收发器挂载在CAN总线网络上
  • 高速CAN使用闭环网络,CAN_H和CAN_L两端添加120欧的终端电阻(第一个作用是防止回波反射,第二个作用是没有设备操作时,将两根差分线的电压收紧)
  • 低速CAN使用开环网络,CAN_H和CAN_L其中一端添加2.2千欧的终端网络(有回波反射作用)

CAN电平标准

  • CAN总线采用差分信号,即两线电压差(Vcan_h-Vcan_l)传输数据位
  • 高速CAN规定:

电压差为0V时表示逻辑1(隐性电平)

电压差为2V时表示逻辑0(显性电平)

  • 低速CAN规定:

电压差为-1.5V时表示逻辑1(隐性电平)

电压差为3V时表示逻辑0(显性电平)

CAN总线帧格式

帧类型用途
数据帧发送设备主动发送数据(广播式)
遥控帧接收设备主动请求数据(请求式)
错误帧某个设备检测出错误时向其他设备通知错误
过载帧接收设备通知其尚未做好接收准备
帧间隔用于将数据帧及遥控帧与前面的帧分离开

数据帧

总线空闲状态-->帧起始SOF(发送隐性电平1)-->仲裁段(发送11位报文ID以及RTR【隐性电平1表示数据帧,显性电平0表示遥控帧】)-->控制段(IDE:ID扩展标志位:用于区分标准格式还是扩展格式【标准格式发显性电平0,扩展格式发隐性电平1】)、r0(保留位,必须为显性电平0)、4位DLC(用于指定1~8位有效载荷)-->数据段(要发送的数据,大小与前面的DLC对应)-->CRC段(校验算法:CRC及CRC界定符)-->ACK段(收发应答:ACK槽及ACK界定符)-->帧结束(EOF)

扩展格式:SRR替代RTR,协议升级时留下的无意义位

应答的过程是发送方与接收方操纵总线的过程,发送方发完数据后释放总线,等待读取总线信息,如果读到总线被拉紧,就说明有其他设备接收到数据,并且,CAN设备是发送方发送一位,接收方接收一位的过程,两个界定符的作用是给发送方和接收方留出操纵总线的时间。

遥控帧

遥控帧无数据段,RTR为隐性电平1,其他部分与数据帧相同

CAN的遥控帧(Remote Frame)的主要作用是请求其他节点发送具有特定ID的数据帧。具体来说,当一个节点需要从另一个节点获取数据时,它可以发送一个遥控帧,而不是直接发送数据。这个遥控帧包含了请求数据的ID,但没有包含数据本身。接收到遥控帧的节点如果拥有与遥控帧ID相匹配的数据帧,就会响应并发送相应的数据帧。这种方式允许节点仅请求需要的数据,而不是不断发送可能不需要的数据,从而提高了网络的效率和减少了不必要的数据传输。

位填充 

位填充规则:发送方每发送5个相同电平后,自动追加一个相反电平的填充位接收方检测到填充位时,会自动移除填充位,恢复原始数据。

位填充作用:

  • 增加波形的定时信息,利于接收方执行“再同步”,防止波形长时间无变化,导致接收方不能精确掌握数据采样时机
  • 将正常数据流与“错误帧”和“过载帧”区分开,标志“错误帧”和“过载帧”的特异性(错误帧和过载帧回发送6个相同电平)
  • 保持CAN总线早发送正常数据流时的活跃状态,防止被误认为总线空闲

位时序

 为了灵活调整每个采样点的位置,使采样点对齐数据中心附近,CAN总线对每一个数据位的时长进行了更细的划分,分为同步段(SS)、传播时间段(PTS)、相对缓冲段1(PBS1)和相位缓冲段2(PBS2),每个段又由若干个最小时间单位(Tq)构成

硬同步

  • 每个设备都有一个位时序计时周期,当每个设备(发送方)率先发送报文,其他所有设备(接收方)收到SOF的下降沿时,接收方会将自己的位时序计时周期拨到SS段的位置,与发送方的位时序计时周期保持同步
  • 硬同步只在帧的第一个下降沿(SOF下降沿)有效
  • 经过硬同步后,若发送方和接收方的时钟没有误差,则后续所有数据位的采样点必须都会对齐数据位中心附近

再同步

  • 若发送方或接收方的时钟有误差,随着误差积累,数据位边沿逐渐偏离SS段,则此时接收方根据再同步补偿宽度值(SJW)通过加长PBS1段,或缩短PBS2段,以调整同步
  • 再同步可以发生在第一个下降沿之后的每个数据位跳变边沿

总线仲裁

CAN基本结构

STM32有CAN外设,微控制器做为CAN控制器,其内部结构如上图所示,发送和接收控制器相当于管家,控制CAN的发送和接收,发送邮箱是发送缓冲区,发送接收控制器可以根据先来后到或者ID优先级两种方式进行选择发送报文,通过CAN_TX发送到外面的CAN收发器,CAN收发器将TTL电平转换为差分电平CAN_H和CAN_L,传输到CAN总线上,发送接收控制器从CAN_RX引脚接收CAN总线发来的数据电平,先经过14个过滤器筛选,通过过滤器的报文再存放到接收FIFO(先入先出寄存器,队列)中,等待CPU读取处理。

代码

标准格式、扩展格式、数据帧、遥控帧

MyCAN.h

#ifndef __MYCAN_H
#define __MYCAN_H
#include "stdint.h"void MyCAN_Init(void);
void MyCAN_Transmit(CanTxMsg *TxMessage);
uint8_t MyCAN_ReceiveFlag(void);
void MyCAN_Receive(CanRxMsg *RxMessage);#endif

MyCAN.c

#include "stm32f10x.h"                  // Device headervoid MyCAN_Init(void)
{RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);RCC_APB1PeriphClockCmd(RCC_APB1Periph_CAN1,ENABLE);GPIO_InitTypeDef GPIO_InitStructure;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA,&GPIO_InitStructure);GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;GPIO_Init(GPIOA,&GPIO_InitStructure);CAN_InitTypeDef CAN_InitStructure;CAN_InitStructure.CAN_Mode = CAN_Mode_Normal;//环回模式CAN_InitStructure.CAN_Prescaler = 48;     //波特率 = 36M/48/(1+BS1Tq数+BS2Tq数)=125KCAN_InitStructure.CAN_BS1 = CAN_BS1_2tq;CAN_InitStructure.CAN_BS2 = CAN_BS2_3tq;CAN_InitStructure.CAN_SJW = CAN_SJW_2tq;CAN_InitStructure.CAN_NART = DISABLE;    //自动重传CAN_InitStructure.CAN_TXFP = DISABLE;    //发送邮箱优先级,ENABLE先请求先发送,DISABLE,ID号小的先发送CAN_InitStructure.CAN_RFLM = DISABLE;    //FIFO锁定,ENABLE,FIFO溢出时,新报文丢弃,DISABLE,最后收到的报文被新报文覆盖CAN_InitStructure.CAN_AWUM = DISABLE;    //自动唤醒,ENABLE,自动,DISABLE,手动CAN_InitStructure.CAN_TTCM = DISABLE;    //时间触发通信模式CAN_InitStructure.CAN_ABOM = DISABLE;	 //离线自动恢复,ENABLE自动恢复,DISABLE手动恢复CAN_Init(CAN1,&CAN_InitStructure);CAN_FilterInitTypeDef CAN_FilterInitStructure;CAN_FilterInitStructure.CAN_FilterNumber = 0;CAN_FilterInitStructure.CAN_FilterIdHigh = 0x0000;CAN_FilterInitStructure.CAN_FilterIdLow = 0x0000;CAN_FilterInitStructure.CAN_FilterMaskIdHigh = 0x0000;CAN_FilterInitStructure.CAN_FilterMaskIdLow = 0x0000;    //全通模式CAN_FilterInitStructure.CAN_FilterScale = CAN_FilterScale_32bit;  //过滤器位宽:32位CAN_FilterInitStructure.CAN_FilterMode = CAN_FilterMode_IdMask;   //过滤器模式:屏蔽模式CAN_FilterInitStructure.CAN_FilterFIFOAssignment = CAN_Filter_FIFO0;  //配置过滤器关联,进FIFO0排队还是进FIFO1排队CAN_FilterInitStructure.CAN_FilterActivation = ENABLE;  //激活过滤器开关CAN_FilterInit(&CAN_FilterInitStructure);
}void MyCAN_Transmit(CanTxMsg *TxMessage)
{uint8_t TransmitMailbox = CAN_Transmit(CAN1,TxMessage);uint32_t Timeout = 0;while(CAN_TransmitStatus(CAN1,TransmitMailbox)!=CAN_TxStatus_Ok) //超时退出{Timeout ++;if(Timeout > 100000)break;}
}uint8_t MyCAN_ReceiveFlag(void)
{if(CAN_MessagePending(CAN1,CAN_FIFO0)>0)  //检查FIFO里是否有报文{return 1;}return 0;
}void MyCAN_Receive(CanRxMsg *RxMessage)
{CAN_Receive(CAN1,CAN_FIFO0,RxMessage);
}

main.c

#include "stm32f10x.h"                  // Device header
#include "Delay.h"
#include "OLED.h"
#include "MyCAN.h"
#include "Key.h"CanTxMsg TxMsgArray[] = {
/*	StdId 	  ExtId        IDE			  RTR	  DLC		Data[8]		*/{0x555,0x00000000,CAN_Id_Standard,CAN_RTR_Data,4,{0x11,0x22,0x33,0x44}},{0x000,0x12345678,CAN_Id_Extended,CAN_RTR_Data,4,{0xAA,0xBB,0xCC,0xDD}},{0x666,0x00000000,CAN_Id_Standard,CAN_RTR_Remote,0,{0x00,0x00,0x00,0x00}},{0x000,0x0789ABCD,CAN_Id_Extended,CAN_RTR_Remote,4,{0x00,0x00,0x00,0x00}},	
};CanRxMsg RxMsg;u8 pTMsgArray = 0;int main()
{u8 keyNum = 0;OLED_Init();MyCAN_Init();Key_Init();OLED_ShowString(1,1,"Rx :");OLED_ShowString(2,1,"RxID:");OLED_ShowString(3,1,"Leng:");OLED_ShowString(4,1,"Data:");while(1){keyNum = Key_GetNum();if(keyNum==1){			MyCAN_Transmit(&TxMsgArray[pTMsgArray]);pTMsgArray++;pTMsgArray%=sizeof(TxMsgArray)/sizeof(CanTxMsg);}if(MyCAN_ReceiveFlag()){MyCAN_Receive(&RxMsg);if(RxMsg.IDE == CAN_Id_Standard){OLED_ShowString(1,6,"Std");OLED_ShowHexNum(2,6,RxMsg.StdId,8);}else if(RxMsg.IDE == CAN_Id_Extended){OLED_ShowString(1,6,"Ext");OLED_ShowHexNum(2,6,RxMsg.ExtId,8);}if(RxMsg.RTR == CAN_RTR_Data){OLED_ShowString(1,10,"Data  ");OLED_ShowHexNum(3,6,RxMsg.DLC,1);OLED_ShowHexNum(4,6, RxMsg.Data[0],2);OLED_ShowHexNum(4,9, RxMsg.Data[1],2);OLED_ShowHexNum(4,12,RxMsg.Data[2],2);OLED_ShowHexNum(4,15,RxMsg.Data[3],2);				}else if(RxMsg.RTR == CAN_RTR_Remote){OLED_ShowString(1,10,"Remote");OLED_ShowHexNum(3,6,RxMsg.DLC,1);OLED_ShowHexNum(4,6, 0x00,2);OLED_ShowHexNum(4,9, 0x00,2);OLED_ShowHexNum(4,12,0x00,2);OLED_ShowHexNum(4,15,0x00,2);					}}}
}

过滤器的使用

(1)16位列表模式

	/*一共有14个过滤器,可配置多个*/CAN_FilterInitStructure.CAN_FilterNumber = 0;
//	CAN_FilterInitStructure.CAN_FilterIdHigh = (0x234<<5)|0x10;   //RTR在第五位,|0x10就能接收遥控帧CAN_FilterInitStructure.CAN_FilterIdHigh = 0x234<<5;CAN_FilterInitStructure.CAN_FilterIdLow = 0x345<<5;CAN_FilterInitStructure.CAN_FilterMaskIdHigh = 0x567<<5;CAN_FilterInitStructure.CAN_FilterMaskIdLow = 0x000<<5;  CAN_FilterInitStructure.CAN_FilterScale = CAN_FilterScale_16bit;  //过滤器位宽:16位CAN_FilterInitStructure.CAN_FilterMode = CAN_FilterMode_IdList;   //过滤器模式:列表CAN_FilterInitStructure.CAN_FilterFIFOAssignment = CAN_Filter_FIFO0;  //配置过滤器关联,进FIFO0排队还是进FIFO1排队CAN_FilterInitStructure.CAN_FilterActivation = ENABLE;  //激活过滤器开关CAN_FilterInit(&CAN_FilterInitStructure);CAN_FilterInitStructure.CAN_FilterNumber = 1;CAN_FilterInitStructure.CAN_FilterIdHigh = 0x123<<5;CAN_FilterInitStructure.CAN_FilterIdLow = 0x678<<5;CAN_FilterInitStructure.CAN_FilterMaskIdHigh = 0x000<<5;CAN_FilterInitStructure.CAN_FilterMaskIdLow = 0x000<<5;  CAN_FilterInitStructure.CAN_FilterScale = CAN_FilterScale_16bit;  CAN_FilterInitStructure.CAN_FilterMode = CAN_FilterMode_IdList;   CAN_FilterInitStructure.CAN_FilterFIFOAssignment = CAN_Filter_FIFO0;  //配置过滤器关联,进FIFO0排队还是进FIFO1排队CAN_FilterInitStructure.CAN_FilterActivation = ENABLE;  //激活过滤器开关CAN_FilterInit(&CAN_FilterInitStructure);

 (2)16屏蔽模式

	CAN_FilterInitTypeDef CAN_FilterInitStructure;/*一共有14个过滤器,可配置多个*/CAN_FilterInitStructure.CAN_FilterNumber = 0;CAN_FilterInitStructure.CAN_FilterIdHigh = 0x200<<5;      //第一组IDCAN_FilterInitStructure.CAN_FilterMaskIdHigh = (0x700<<5)|0x10|0x8;  //对应的屏蔽位CAN_FilterInitStructure.CAN_FilterIdLow = 0x320<<5;		  //第二组IDCAN_FilterInitStructure.CAN_FilterMaskIdLow = (0x7F0<<5)|0x10|0x8;    //对应的屏蔽位CAN_FilterInitStructure.CAN_FilterScale = CAN_FilterScale_16bit;  //过滤器位宽:16位CAN_FilterInitStructure.CAN_FilterMode = CAN_FilterMode_IdMask;   //过滤器模式:屏蔽CAN_FilterInitStructure.CAN_FilterFIFOAssignment = CAN_Filter_FIFO0;  //配置过滤器关联,进FIFO0排队还是进FIFO1排队CAN_FilterInitStructure.CAN_FilterActivation = ENABLE;  //激活过滤器开关CAN_FilterInit(&CAN_FilterInitStructure);

(3)32位列表模式

	/*一共有14个过滤器,可配置多个*/CAN_FilterInitStructure.CAN_FilterNumber = 0;uint32_t ID1 = 0x123<<21;CAN_FilterInitStructure.CAN_FilterIdHigh = ID1>>16;CAN_FilterInitStructure.CAN_FilterIdLow =ID1;uint32_t ID2 = (0x12345678u<<3)|0x4;CAN_FilterInitStructure.CAN_FilterMaskIdHigh = ID2>>16;CAN_FilterInitStructure.CAN_FilterMaskIdLow = ID2;  CAN_FilterInitStructure.CAN_FilterScale = CAN_FilterScale_32bit;  //过滤器位宽:16位CAN_FilterInitStructure.CAN_FilterMode = CAN_FilterMode_IdList;   //过滤器模式:列表CAN_FilterInitStructure.CAN_FilterFIFOAssignment = CAN_Filter_FIFO0;  //配置过滤器关联,进FIFO0排队还是进FIFO1排队CAN_FilterInitStructure.CAN_FilterActivation = ENABLE;  //激活过滤器开关CAN_FilterInit(&CAN_FilterInitStructure);

(4)32位屏蔽模式

	/*一共有14个过滤器,可配置多个*/CAN_FilterInitStructure.CAN_FilterNumber = 0;uint32_t ID = (0x12345600u<<3)|0x4;CAN_FilterInitStructure.CAN_FilterIdHigh = ID>>16;CAN_FilterInitStructure.CAN_FilterIdLow =ID;uint32_t Mask = (0x1FFFFF00u<<3)|0x4|0x2;CAN_FilterInitStructure.CAN_FilterMaskIdHigh = Mask>>16;CAN_FilterInitStructure.CAN_FilterMaskIdLow = Mask;  CAN_FilterInitStructure.CAN_FilterScale = CAN_FilterScale_32bit;  //过滤器位宽:16位CAN_FilterInitStructure.CAN_FilterMode = CAN_FilterMode_IdMask;   //过滤器模式:列表CAN_FilterInitStructure.CAN_FilterFIFOAssignment = CAN_Filter_FIFO0;  //配置过滤器关联,进FIFO0排队还是进FIFO1排队CAN_FilterInitStructure.CAN_FilterActivation = ENABLE;  //激活过滤器开关CAN_FilterInit(&CAN_FilterInitStructure);

(5)只接收遥控帧

	/*一共有14个过滤器,可配置多个*/CAN_FilterInitStructure.CAN_FilterNumber = 0;uint32_t ID = 0x2;CAN_FilterInitStructure.CAN_FilterIdHigh = ID>>16;CAN_FilterInitStructure.CAN_FilterIdLow =ID;uint32_t Mask = 0x2;CAN_FilterInitStructure.CAN_FilterMaskIdHigh = Mask>>16;CAN_FilterInitStructure.CAN_FilterMaskIdLow = Mask;  CAN_FilterInitStructure.CAN_FilterScale = CAN_FilterScale_32bit;  //过滤器位宽:16位CAN_FilterInitStructure.CAN_FilterMode = CAN_FilterMode_IdMask;   //过滤器模式:列表CAN_FilterInitStructure.CAN_FilterFIFOAssignment = CAN_Filter_FIFO0;  //配置过滤器关联,进FIFO0排队还是进FIFO1排队CAN_FilterInitStructure.CAN_FilterActivation = ENABLE;  //激活过滤器开关CAN_FilterInit(&CAN_FilterInitStructure);

相关文章:

STM32单片机使用CAN协议进行通信

CAN总线&#xff08;控制器局域网总线&#xff09; 理论知识 CAN总线是由BOSCH公司开发的一种简洁易用、传输速度快、易扩展、可靠性高的串行通信总线 CAN总线特征 两根通信线&#xff08;CAN_H、CAN_L&#xff09;&#xff0c;线路少&#xff0c;无需共地差分信号通信&…...

Docker 入门:如何使用 Docker 容器化 AI 项目(二)

四、将 AI 项目容器化&#xff1a;示例实践 - 完整的图像分类与 API 服务 让我们通过一个更完整的 AI 项目示例&#xff0c;展示如何将 AI 项目容器化。我们以一个基于 TensorFlow 的图像分类模型为例&#xff0c;演示如何将训练、推理、以及 API 服务过程容器化。 4.1 创建 …...

MVVM、MVC、MVP 的区别

MVVM&#xff08;Model-View-ViewModel&#xff09;、MVC&#xff08;Model-View-Controller&#xff09;和MVP&#xff08;Model-View-Presenter&#xff09;是三种常见的软件架构模式&#xff0c;它们在客户端应用开发中被广泛使用。每种模式都有其特定的设计理念和应用场景&…...

【Verilog】期末复习

数字逻辑电路分为哪两类&#xff1f;它们各自的特点是什么&#xff1f; 组合逻辑电路&#xff1a;任意时刻的输出仅仅取决于该时刻的输入&#xff0c;而与电路原来的状态无关 没有记忆功能&#xff0c;只有从输入到输出的通路&#xff0c;没有从输出到输入的回路 时序逻辑电路&…...

C#都可以找哪些工作?

在国内学习C#&#xff0c;可以找的工作主要是以下4个&#xff1a; 1、游戏开发 需要学习C#编程、Unity引擎操作、游戏设计和3D图形处理等。 2、PC桌面应用开发 需要学习C#编程、WinForm框架/WPF框架、MVVM设计模式和UI/UX设计等。 3、Web开发 需要学习C#编程、ASP.NET框架…...

机器学习Python使用scikit-learn工具包详细介绍

一、简介 Scikit-learn是一个开源的机器学习库&#xff0c;用于Python编程语言。它建立在NumPy、SciPy和matplotlib这些科学计算库之上&#xff0c;提供了简单有效的数据挖掘和数据分析工具。Scikit-learn库包含了许多用于分类、回归、聚类和降维的算法&#xff0c;包括支持向量…...

蓝桥杯真题 - 扫雷 - 题解

题目链接&#xff1a;https://www.lanqiao.cn/problems/549/learning/ 个人评价&#xff1a;难度 1 星&#xff08;满星&#xff1a;5&#xff09; 前置知识&#xff1a;无 整体思路 按题意模拟&#xff1b;为了减少不必要的“数组越界”判断&#xff0c;让数组下标从 1 1 1…...

vue3项目结合Echarts实现甘特图(可拖拽、选中等操作)

效果图&#xff1a; 图一&#xff1a;选中操作 图二&#xff1a;上下左右拖拽操作 本案例在echarts​​​​​​​示例机场航班甘特图的基础上修改​​​​​​​ 封装ganttEcharts组件&#xff0c;测试数据 airport-schedule.jsonganttEcharts代码: 直接复制粘贴可测​​​​…...

Log4j2 插件的简单使用

代码: TestPlugin.java package com.chenjiacheng.webapp.plugins;import org.apache.logging.log4j.core.LogEvent; import org.apache.logging.log4j.core.config.plugins.Plugin; import org.apache.logging.log4j.core.lookup.StrLookup;/*** Created by chenjiacheng on …...

Linux之RPM和YUM命令

一、RPM命令 1、介绍 RPM(RedHat Package Manager).,RedHat软件包管理工具&#xff0c;类似windows里面的setup,exe是Liux这系列操作系统里而的打包安装工具。 RPMI包的名称格式&#xff1a; Apache-1.3.23-11.i386.rpm “apache’” 软件名称“1.3.23-11” 软件的版本号&am…...

读取硬件板子上的数据

SSCOM工具&#xff0c;先要安装一个插件 这样就可以读到设备数据...

Cesium 实例化潜入潜出

Cesium 实例化潜入潜出 1、WebGL Instance 的原理 狭义的的WebGL 中说使用 Instance, 一般指使用 glDrawArraysInstanced 用于实例化渲染的函数。它允许在一次绘制调用中渲染多个相同的几何体实例&#xff0c;而无需为每个实例发起单独的绘制调用。 Three.js 就是使用这种方…...

java引入jedis并且关于开放redis端口问题

博主主页: 码农派大星. 数据结构专栏:Java数据结构 数据库专栏:数据库 JavaEE专栏:JavaEE 软件测试专栏:软件测试 关注博主带你了解更多知识 目录 1. 引入jedis ​编辑 2. 关于java客户端开放redis端口问题 3. 连接redis服务器 redis服务器在官网公开了使用的协议: resp…...

【人工智能】用Python实现情感分析:从简单词典到深度学习方法的演进

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 情感分析是自然语言处理(NLP)中的一个重要任务,其目的是通过分析文本内容,识别出其中的情感极性,如正面、负面或中性。随着技术的不断…...

关系型数据库的完整性和一致性

完整性 1.实体完整性 - 每一个实体都是独一无二的&#xff0c;没有冗余 --主键/唯一索引 2.参照完整性 - 外键 3.域完整性 - 存储的数据都是有效的数据 --数据类型/数据长度/非空约束/检查约束/ 检查约束&#xff1a; alter table tb_score add constraint ck_score_scmar…...

设计模式の命令访问者迭代器模式

文章目录 前言一、命令模式二、访问者模式三、迭代器模式 前言 本篇是关于设计模式中命令模式、访问者模式、以及迭代器模式的学习笔记。 一、命令模式 命令模式是一种行为型设计模式&#xff0c;其核心目的在于将命令的发送者和接受者解耦&#xff0c;提供一个中间层对命令进行…...

信息系统项目管理 -冲突管理

信息系统项目管理题 冲突管理&#xff1a; 项目管理信息系统包括&#xff08;&#xff09;软件&#xff0c;用于监督资源的使用情况&#xff0c;协助确保合适的资源适时、适地的用于合适活动。 A资源管理或进度计划 BCRM系统 C采购系统或智能分析 DBOM系统 答案&#xff1a;A …...

Gmsh有限元网格剖分(Python)---点、直线、平面的移动

Gmsh有限元网格剖分(Python)—点、直线、平面的移动和旋转 最近在学习有限元的网格剖分算法&#xff0c;主要还是要参考老外的开源Gmsh库进行&#xff0c;写一些博客记录下学习过程&#xff0c;方便以后回忆嘞。 Gmsh的官方英文文档可以参考&#xff1a;gmsh.pdf 但咋就说&a…...

山景BP1048增加AT指令,实现单片机串口控制播放音乐(一)

1、设计目的 山景提供的SDK是蓝牙音箱demo&#xff0c;用户使用ADC按键或者IR遥控器&#xff0c;进行人机交互。然而现实很多场景&#xff0c;需要和单片机通信&#xff0c;不管是ADC按键或者IR接口都不适合和单片机通信。这里设计个AT指令用来和BP1048通信。AT指令如下图所示…...

SMMU软件指南SMMU编程之全局错误和最小配置

安全之安全(security)博客目录导读 目录 一、全局错误 二、最小配置 一、全局错误 与编程接口相关的全局错误会报告到适当的 SMMU_(*_)GERROR 寄存器&#xff0c;而不是通过基于内存的事件队列。这些错误通常是严重的&#xff0c;例如导致 SMMU 停止向前推进。例如&#xf…...

电脑插入多块移动硬盘后经常出现卡顿和蓝屏

当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时&#xff0c;可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案&#xff1a; 1. 检查电源供电问题 问题原因&#xff1a;多块移动硬盘同时运行可能导致USB接口供电不足&#x…...

屋顶变身“发电站” ,中天合创屋面分布式光伏发电项目顺利并网!

5月28日&#xff0c;中天合创屋面分布式光伏发电项目顺利并网发电&#xff0c;该项目位于内蒙古自治区鄂尔多斯市乌审旗&#xff0c;项目利用中天合创聚乙烯、聚丙烯仓库屋面作为场地建设光伏电站&#xff0c;总装机容量为9.96MWp。 项目投运后&#xff0c;每年可节约标煤3670…...

智能仓储的未来:自动化、AI与数据分析如何重塑物流中心

当仓库学会“思考”&#xff0c;物流的终极形态正在诞生 想象这样的场景&#xff1a; 凌晨3点&#xff0c;某物流中心灯火通明却空无一人。AGV机器人集群根据实时订单动态规划路径&#xff1b;AI视觉系统在0.1秒内扫描包裹信息&#xff1b;数字孪生平台正模拟次日峰值流量压力…...

dify打造数据可视化图表

一、概述 在日常工作和学习中&#xff0c;我们经常需要和数据打交道。无论是分析报告、项目展示&#xff0c;还是简单的数据洞察&#xff0c;一个清晰直观的图表&#xff0c;往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server&#xff0c;由蚂蚁集团 AntV 团队…...

Java + Spring Boot + Mybatis 实现批量插入

在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法&#xff1a;使用 MyBatis 的 <foreach> 标签和批处理模式&#xff08;ExecutorType.BATCH&#xff09;。 方法一&#xff1a;使用 XML 的 <foreach> 标签&#xff…...

MinIO Docker 部署:仅开放一个端口

MinIO Docker 部署:仅开放一个端口 在实际的服务器部署中,出于安全和管理的考虑,我们可能只能开放一个端口。MinIO 是一个高性能的对象存储服务,支持 Docker 部署,但默认情况下它需要两个端口:一个是 API 端口(用于存储和访问数据),另一个是控制台端口(用于管理界面…...

LCTF液晶可调谐滤波器在多光谱相机捕捉无人机目标检测中的作用

中达瑞和自2005年成立以来&#xff0c;一直在光谱成像领域深度钻研和发展&#xff0c;始终致力于研发高性能、高可靠性的光谱成像相机&#xff0c;为科研院校提供更优的产品和服务。在《低空背景下无人机目标的光谱特征研究及目标检测应用》这篇论文中提到中达瑞和 LCTF 作为多…...

Matlab实现任意伪彩色图像可视化显示

Matlab实现任意伪彩色图像可视化显示 1、灰度原始图像2、RGB彩色原始图像 在科研研究中&#xff0c;如何展示好看的实验结果图像非常重要&#xff01;&#xff01;&#xff01; 1、灰度原始图像 灰度图像每个像素点只有一个数值&#xff0c;代表该点的​​亮度&#xff08;或…...

【java面试】微服务篇

【java面试】微服务篇 一、总体框架二、Springcloud&#xff08;一&#xff09;Springcloud五大组件&#xff08;二&#xff09;服务注册和发现1、Eureka2、Nacos &#xff08;三&#xff09;负载均衡1、Ribbon负载均衡流程2、Ribbon负载均衡策略3、自定义负载均衡策略4、总结 …...

Django RBAC项目后端实战 - 03 DRF权限控制实现

项目背景 在上一篇文章中&#xff0c;我们完成了JWT认证系统的集成。本篇文章将实现基于Redis的RBAC权限控制系统&#xff0c;为系统提供细粒度的权限控制。 开发目标 实现基于Redis的权限缓存机制开发DRF权限控制类实现权限管理API配置权限白名单 前置配置 在开始开发权限…...