Ubuntu下使用 python搭建服务实现从web端远程配置设备网口

1、通过文件配置Ubuntu设备网口

在Ubuntu工控机上,通过文件配置网口(网络接口)可以让网络配置在每次系统启动时自动生效。以下是常见的方法步骤:

1.1 使用 netplan 配置网口(Ubuntu 18.04 及以上版本)

  1. 编辑 netplan 配置文件:netplan 的配置文件通常位于 /etc/netplan/ 目录下,文件名通常是 01-netcfg.yaml 或者类似的 .yaml 文件。

    打开该文件进行编辑:

    sudo nano /etc/netplan/01-netcfg.yaml
    
  2. 配置网口: 在文件中添加或修改如下内容,假设你要配置的是 eth0 网口,并且希望它有静态 IP 地址:

    network:version: 2renderer: networkdethernets:<eth0>:dhcp4: noaddresses:- 192.168.1.100/24gateway4: 192.168.1.1nameservers:addresses:- 8.8.8.8- 8.8.4.4
    
    • eth0 需要配置的网口,根据实际换成自己设备的网口
    • dhcp4: no 表示关闭 DHCP。
    • addresses: 配置静态 IP 地址和子网掩码。
    • gateway4: 配置网关。
    • nameservers: 配置 DNS 服务器地址。

1.2 使用 ifupdown 配置网口(Ubuntu 16.04 及以下版本)

Ubuntu 16.04 及之前的版本使用 /etc/network/interfaces 文件来配置网口。

  1. 编辑 /etc/network/interfaces 文件: 打开该文件进行编辑:

    sudo nano /etc/network/interfaces
    
  2. 配置网口: 在文件中添加或修改如下内容,假设你要配置的是 eth0 网口:

    • 如果是静态 IP:

      auto eth0
      iface eth0 inet staticaddress 192.168.1.100netmask 255.255.255.0gateway 192.168.1.1dns-nameservers 8.8.8.8 8.8.4.4
      
    • 如果是动态 IP(通过 DHCP 获取 IP):

      auto eth0
      iface eth0 inet dhcp
      
  3. 重启网络服务: 保存文件后,使用以下命令重启网络服务使配置生效:

    sudo systemctl restart networking
    

1.3 验证配置

你可以使用 ifconfigip a 命令来检查网口的配置是否正确生效。例如:

ip a

这两种方法分别适用于不同的 Ubuntu 版本。你可以根据自己的系统版本选择合适的方式。

2、使用python搭建一个web服务

要使用 Python 搭建一个 Web 服务,允许远程修改 netplan 网络配置并在没有新的 Web 访问后一分钟内恢复原始配置,可以使用 Flask 框架和定时任务来实现。以下是详细步骤:

2.1 后端python脚本

2.1.1 项目依赖

因为python脚本编辑/etc路径下文件,脚本需要在root权限下运行,因此安装依赖首先需要获取root权限:

sudo -i

安装依赖:

首先,你需要安装 Flask 框架和 schedule 模块(用于定时任务),以及确保工控机有权限修改网络配置,。

pip3 install flask flask-cors schedule 

2.1.2 Python 代码实现

以下是一个完整的 Python 脚本示例,该脚本包含:

  • 启动一个 Flask Web 服务,用于接收网络配置修改请求。
  • 使用定时任务,在没有新的 Web 访问后 60 秒内恢复为原始配置。
#!/usr/bin/env python3
import os
import time
import shutil
import threading
from flask import Flask, request, jsonify
from flask_cors import CORS
import schedule
import subprocess
import reapp = Flask(__name__)
CORS(app)  # 启用 CORS 允许跨域请求
# 全局变量,用来保存最后一次修改时间
last_access_time = time.time()# 保存原始的 netplan 配置文件路径
netplan_file = "/etc/netplan/01-network-manager-all.yaml"
backup_file = "/etc/netplan/01-network-manager-all.yaml.bak"change_config = False
revisit = False# 备份原始配置
def backup_netplan():# if not os.path.exists(backup_file):shutil.copy(netplan_file, backup_file)print("Netplan configuration backed up.")# 定时器:在 60 秒后没有新的请求访问时恢复配置
def restore_config_if_needed():global last_access_timeglobal change_configglobal revisitif not change_config:returnif revisit:backup_netplan()print("Netplan configuration already in effect.")change_config = Falserevisit = False# 计算当前时间距离上次访问的时间差time_since_last_access = time.time() - last_access_timeif time_since_last_access > 60:# 恢复原始配置if os.path.exists(backup_file):shutil.copy(backup_file, netplan_file)change_config = False# 应用 netplan 配置os.system("sudo netplan apply")print("Netplan configuration restored to original.")# 启动一个独立线程来定时检查恢复配置
def schedule_checker():while True:schedule.run_pending()time.sleep(1)def get_current_ip():"""获取系统当前设置的 IP 地址"""try:# 通过 ip 命令获取网口 eth0 的 IP 地址result = subprocess.run(['ip', 'addr', 'show', 'enp2s0'], stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True)output = result.stdout# 使用正则表达式查找 IP 地址ip_match = re.search(r'inet\\s(\\d+\\.\\d+\\.\\d+\\.\\d+)', output)if ip_match:return ip_match.group(1)  # 返回第一个匹配的 IP 地址else:return "No IP address found"except Exception as e:return str(e)@app.route('/current_ip', methods=['GET'])
def current_ip():"""API 返回当前的 IP 地址"""global revisitrevisit = Trueip_address = get_current_ip()print("received new current_ip request")return jsonify({"ip_address": ip_address})# 修改 netplan 配置的路由
@app.route('/update_netplan', methods=['POST'])
def update_netplan():global last_access_timeglobal change_configglobal revisitlast_access_time = time.time()# 获取新的 netplan 配置信息new_config = request.json.get("config")if new_config:# 写入新的配置到 netplan 文件with open(netplan_file, "w") as f:f.write(new_config)change_config = Truerevisit = False# 应用 netplan 配置os.system("sudo netplan apply")return jsonify({"message": "Netplan configuration updated successfully."}), 200else:return jsonify({"error": "Invalid configuration."}), 400@app.route('/ping', methods=['GET'])
def ping():"""用于接收前端的访问请求,更新最后一次访问时间"""global last_access_timelast_access_time = time.time()  # 更新最后访问时间print("ping received.")return jsonify({"message": "Ping received, reset timeout."}), 200# 主程序入口
if __name__ == '__main__':# 启动时备份原始配置backup_netplan()# 每隔 10 秒检查一次是否需要恢复配置schedule.every(10).seconds.do(restore_config_if_needed)# 启动http服务器,以便远程访问前端服务os.system("python3 -m http.server 8000 &")# 启动定时任务线程threading.Thread(target=schedule_checker, daemon=True).start()# 启动 Flask Web 服务app.run(host='0.0.0.0', port=5000)

2.1.3 功能说明

  1. 备份原始配置: 在脚本启动时,会自动备份当前的 netplan 配置文件到 /etc/netplan/01-netcfg.yaml.bak

  2. 修改 netplan 配置: 提供了一个 /update_netplan API,用户可以通过 POST 请求发送新的 netplan 配置信息。修改后的配置会立即写入 /etc/netplan/01-netcfg.yaml 并通过 netplan apply 命令生效。

  3. 超时恢复配置:

    我们可以利用 Flask 的路由来记录前端的访问时间,并通过一个后台线程定期检查是否有新访问。如果超时则恢复原来的 netplan 配置。 该脚本每隔 10 秒检查一次最后的 Web 请求时间。如果超过 60 秒没有新的 Web 请求,则会自动恢复原始的 netplan 配置文件并重新应用。

  4. 定时任务: 使用 schedulethreading 来定期执行恢复操作,保证主程序可以继续处理 Web 请求。

2.1.4 使用说明

1. 启动 Web 服务:

运行该 Python 脚本后,Web 服务会在 0.0.0.0:5000 上启动,允许外部访问。

2. 修改网络配置:

通过以下 curl 请求或使用其他 API 客户端向服务发送请求来修改 netplan 配置:

	curl -X POST http://<your-ip>:5000/update_netplan -H "Content-Type: application/json" -d '{"config": "network:\\n  version: 2\\n  renderer: networkd\\n  ethernets:\\n    eth0:\\n      addresses:\\n        - 192.168.1.101/24\\n      gateway4: 192.168.1.1\\n      nameservers:\\n        addresses:\\n          - 8.8.8.8\\n          - 8.8.4.4\\n"}'

其中 config 字段的内容就是新的 netplan YAML 配置。

3. 自动恢复:

如果 60 秒内没有新请求访问,脚本会自动恢复到启动时备份的原始网络配置。

2.1.5 权限与安全性

  • 由于修改网络配置需要超级用户权限,你可能需要使用 sudo 来运行该脚本,或者将相关操作(如 netplan apply)设为无需密码执行的命令。
  • 建议在实际部署中对 Web 服务添加身份认证,确保外部访问的安全性。

这样,你就可以通过 Web 服务远程修改 netplan 配置,并在无活动时自动恢复配置。

2.1.6 解决 CORS 问题:

  1. 安装 Flask-CORS 库:

    pip3 install flask-cors
    
  2. 在 Flask 应用中启用 CORS: 修改 Flask 代码,添加 CORS 支持:

    python
    复制代码
    from flask import Flask, request, jsonify
    from flask_cors import CORSapp = Flask(__name__)
    CORS(app)  # 启用 CORS 允许跨域请求@app.route('/update_netplan', methods=['POST'])
    def update_netplan():global last_access_timelast_access_time = time.time()new_config = request.json.get("config")if new_config:with open("/etc/netplan/01-netcfg.yaml", "w") as f:f.write(new_config)os.system("sudo netplan apply")return jsonify({"message": "Netplan configuration updated successfully."}), 200else:return jsonify({"error": "Invalid configuration."}), 400
    

2.2 创建 Python 脚本的 systemd 服务

2.2.1:保存 Python 脚本

将你的 Python 脚本保存到某个目录,例如 /opt/netplan_service/,并命名为 netplan_service.py

确保该目录和文件的权限设置正确,允许脚本执行:

sudo mkdir -p /opt/netplan_service
sudo cp netplan_service.py /opt/netplan_service/
sudo chmod +x /opt/netplan_service/netplan_service.py

2.2.2:创建 systemd 服务文件

创建一个新的 systemd 服务单元文件,使得脚本可以在系统启动时以 root 权限运行。

  1. 使用 nano 编辑器创建一个名为 netplan_service.service 的服务文件:

    sudo nano /etc/systemd/system/netplan_service.service
    
  2. 在文件中添加以下内容:

    [Unit]
    Description=Netplan Configuration Web Service
    After=network.target[Service]
    ExecStart=/usr/bin/python3 /opt/netplan_service/netplan_service.py
    WorkingDirectory=/opt/netplan_service
    Restart=always
    User=root
    Environment=PYTHONUNBUFFERED=1[Install]
    WantedBy=multi-user.target
    

    说明:

    • ExecStart 指定了 Python 脚本的启动路径,确保使用 Python 3 解释器。
    • WorkingDirectory 指定服务运行的工作目录。
    • Restart=always 确保服务在失败后自动重启。
    • User=root 确保脚本以 root 权限运行。
    • WantedBy=multi-user.target 使服务在系统启动的多用户模式下自动启动。

2.2.3:重新加载 systemd 守护进程

在创建或修改 systemd 服务文件后,需要重新加载 systemd 守护进程以使其识别新服务:

sudo systemctl daemon-reload

2.2.4:启用并启动服务

  1. 启用服务(使其开机自启):

    sudo systemctl enable netplan_service.service
    
  2. 启动服务

    sudo systemctl start netplan_service.service
    
  3. 检查服务状态: 使用以下命令检查服务是否正常启动:

    sudo systemctl status netplan_service.service
    

如果服务启动正常,你会看到类似这样的输出:

● netplan_service.service - Netplan Configuration Web ServiceLoaded: loaded (/etc/systemd/system/netplan_service.service; enabled; vendor preset: enabled)Active: active (running) since Tue 2024-09-19 10:00:00 UTC; 5s agoMain PID: 1234 (python3)Tasks: 1 (limit: 2345)CGroup: /system.slice/netplan_service.service└─1234 /usr/bin/python3 /opt/netplan_service/netplan_service.py

2.2.5 验证服务是否开机自启

为了确保服务在每次开机时自动运行,可以重启你的工控机,并检查服务状态:

susdo reboot

重启后,使用以下命令再次检查服务状态:

sudo systemctl status netplan_service.service

如果显示服务为 active (running),说明服务已成功开机自启。

2.2.6 安全性注意事项

由于该服务需要 root 权限来修改网络配置,因此:

  • 确保只有受信任的用户能够访问和修改 /etc/systemd/system/netplan_service.service 和 Python 脚本。
  • 如果你担心远程 Web 访问的安全性,建议在 Web 服务上启用身份验证机制,或者通过防火墙限制外部访问。

通过这种方式,Python 脚本会在系统启动时自动运行,并具备 root 权限,从而能够修改 netplan 配置并恢复网络配置。

2.3 前端配置

为了搭建一个能够发送类似 curl -X POST http://<your-ip>:5000/update_netplan 的前端界面,你可以使用 HTML 和 JavaScript 来构建一个简单的 Web 界面,允许用户通过表单提交新的 netplan 配置。你可以使用 JavaScript 的 fetch API 发送 POST 请求。 我们可以使用textarea 为两个独立的输入框,一个用于配置 addresses,另一个用于配置 gateway4,并在提交时动态生成完整的 netplan 配置文件。

在后端获取ip地址,并在前端显示 要在前端显示当前系统的 IP 地址,你可以通过后端 Flask 提供一个新的接口,获取当前的 netplan 配置或系统的 IP 地址,并将其返回给前端。前端加载时,发送请求获取并显示当前的 IP 地址。

2.3.1 前端界面实现

以下是一个简单的前端页面代码,前端可以显示当前系统的 IP 地址,用户可以输入新的 netplan 配置,并通过点击按钮发送 POST 请求

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Netplan Configuration</title><style>body {font-family: Arial, sans-serif;padding: 20px;}.container {max-width: 600px;margin: 0 auto;}label {font-size: 16px;margin-top: 10px;}input {width: 100%;padding: 10px;margin-top: 5px;font-size: 16px;}button {margin-top: 10px;padding: 10px;font-size: 16px;background-color: #007bff;color: white;border: none;cursor: pointer;}button:hover {background-color: #0056b3;}.response {margin-top: 20px;padding: 10px;background-color: #f1f1f1;border: 1px solid #ccc;}.current-ip {margin-bottom: 20px;font-size: 18px;color: #333;}</style>
</head>
<body><div class="container"><h1>Netplan Configuration</h1><!-- 显示当前 IP 地址 --><div class="current-ip"><strong>Current IP Address: </strong><span id="current-ip">Loading...</span></div><form id="netplan-form"><label for="ip-address">Enter IP Address (CIDR notation):</label><br><input type="text" id="ip-address" placeholder="e.g. 192.168.1.101/24" required><br><label for="gateway">Enter Gateway Address:</label><br><input type="text" id="gateway" placeholder="e.g. 192.168.1.1" required><br><button type="submit">Submit Configuration</button></form><div class="response" id="response-message"></div></div><script>document.getElementById('netplan-form').addEventListener('submit', function(e) {e.preventDefault(); // 阻止表单默认提交行为const ipAddress = document.getElementById('ip-address').value;const gateway = document.getElementById('gateway').value;// 创建 netplan 配置的 YAML 内容const netplanConfig = `
network:version: 2renderer: NetworkManagerethernets:enp2s0:dhcp4: noaddresses:- ${ipAddress}gateway4: ${gateway}nameservers:addresses:- 8.8.8.8- 8.8.4.4
`;// 发送 POST 请求到后端fetch('http://<your-ip>:5000/update_netplan', {method: 'POST',headers: {'Content-Type': 'application/json'},body: JSON.stringify({config: netplanConfig})}).then(response => response.json()).then(data => {document.getElementById('response-message').innerText = JSON.stringify(data);}).catch(error => {document.getElementById('response-message').innerText = "Error: " + error;});});// 加载时获取当前 IP 地址并显示window.onload = function() {fetch('http://<your-ip>:5000/current_ip').then(response => response.json()).then(data => {document.getElementById('current-ip').innerText = data.ip_address;}).catch(error => {document.getElementById('current-ip').innerText = "Error: " + error;});}// 定时每隔 30 秒发送 ping 请求setInterval(function() {fetch('http://<your-ip>:5000/ping').then(response => response.json()).then(data => console.log(data)).catch(error => console.error("Ping failed:", error));}, 30000);  // 每 30 秒发送一次请求</script>
</body>
</html>

界面大概长这样

2.3.2 代码解释

  1. IP地址和网关输入

    • input 标签分别用于输入 addresses(IP地址)和 gateway4(网关)。
    • 表单提交时会从这两个输入框中获取用户输入的 IP 地址和网关。
  2. 动态生成 netplan 配置

    • 在 JavaScript 里,根据用户输入,动态生成符合 netplan 配置文件格式的 YAML 字符串。

    • 生成的 YAML 字符串类似于:

      yaml
      复制代码
      network:version: 2renderer: networkdethernets:eth0:addresses:- 192.168.1.101/24gateway4: 192.168.1.1nameservers:addresses:- 8.8.8.8- 8.8.4.4
      
  3. POST 请求

    • fetch 函数会发送一个 POST 请求,将生成的配置文件通过 JSON 格式传递给后端 Flask 服务。
    • 请求的内容是 config 字段,该字段包含用户输入生成的 YAML 文件。

2.3.3 部署说明

  1. 修改 <your-ip>
    • 将 JavaScript 中的 http://<your-ip>:5000/update_netplan 中的 <your-ip> 替换为实际工控机的 IP 地址或域名。
  2. 安全性
    • 通过防火墙限制外部访问或为表单页面增加身份验证,确保只有授权用户可以访问和配置网络设置。

通过这个方法,前端界面仅允许用户配置 IP 地址和网关,同时提供用户友好的界面进行提交,后端将自动生成完整的 netplan 配置并应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/54651.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue学习记录之六(组件实战及BEM框架了解)

一、BEM BEM是一种前端开发中常用的命名约定&#xff0c;主要用于CSS和HTML的结构化和模块化。BEM是Block、Element、Modifier的缩写。 Block&#xff08;块&#xff09;&#xff1a;独立的功能性页面组件&#xff0c;可以是一个简单的按钮&#xff0c;一个复杂的导航条&…

【Python 数据分析学习】Matplotlib 的基础和应用

题目 1 Matplotlib 主要特性2 Matplotlib 基础知识2.1 导入模块2.2 图形构成2.2.1 图形&#xff08;Figure&#xff09;2.2.2 轴 &#xff08;Axes&#xff09;2.2.3 轴线&#xff08;axis&#xff09; 2.5 中文设置2.5.1 借助rcParams修改字体实现设置2.5.2 增加一个fontprope…

基于PHP+MySQL组合开发地方门户分类信息网站源码系统 带完整的安装代码包以及搭建部署教程

系统概述 随着互联网技术的飞速发展&#xff0c;地方门户分类信息网站逐渐成为城市生活不可或缺的一部分。它们涵盖了房产、招聘、二手交易、生活服务等多个领域&#xff0c;为当地居民提供了全方位的信息服务。为了满足这一市场需求&#xff0c;我们开发了这款基于PHPMySQL的…

uniapp监听滚动实现顶部透明度变化

效果如图&#xff1a; 实现思路&#xff1a; 1、使用onPageScroll监听页面滚动&#xff0c;改变导航条的透明度&#xff1b; 2、关于顶部图片的高度&#xff1a; 如果是小程序&#xff1a;使用getMenuButtonBoundingClientRect获取胶囊顶部距离和胶囊高度&#xff1b; 如果…

如何利用 Kafka,实时挖掘企业数据的价值?

首先&#xff0c;问读者老爷们一个简单的问题&#xff0c;如果你需要为你的数据选择一个同时具备高吞吐 、数据持久化、可扩展的数据传递系统&#xff0c;你会选择什么样的工具或架构呢&#xff1f; 答案非常显而易见&#xff0c;那就是 Kafka&#xff0c;不妨再次套用一个被反…

使用Java基于GeoTools读取Shapefile矢量数据属性信息-以某市POI数据为例

前言 在之前的博客中&#xff0c;我们讲过在GDAL中如何读取空间数据的属性和数据信息&#xff0c;也简单的讲过如何在GeoTools中读取Shapefile文件的属性信息和数据信息。对于空间矢量数据库&#xff0c;就像我们传统的二维数据库的表字段和表数据的关系&#xff0c;在研究表数…

14 vue3之内置组件trastion全系列

前置知识 Vue 提供了 transition 的封装组件&#xff0c;在下列情形中&#xff0c;可以给任何元素和组件添加进入/离开过渡: 条件渲染 (使用 v-if)条件展示 (使用 v-show)动态组件组件根节点 自定义 transition 过度效果&#xff0c;你需要对transition组件的name属性自定义。…

jupyter安装与使用——Ubuntu服务器

jupyter安装与使用——Ubuntu服务器 一、安装miniconda3/anaconda31. 下载miniconda32. 安装miniconda33. 切换到bin文件夹4. 输入pwd获取路径5. 打开用户环境编辑页面6. 重新加载用户环境变量7. 初始化conda8.验证是否安装成功9.conda配置 二、安装jupyter2.1 conda安装2.2 配…

国货之光|暴雨携信创新品亮相第八届丝博会

9月20日&#xff0c;第八届丝绸之路国际博览会暨中国东西部合作与投资贸易洽谈会&#xff08;以下简称“丝博会”&#xff09;在西安举行。 本届丝博会以“深化互联互通拓展经贸合作”为主题&#xff0c;会期为9月20日至24日&#xff0c;在西安国际会展中心设置国际交流展、省际…

研一奖学金计划2024/9/23有感

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、需要认真上课的1.应用数理统计&#xff08;开卷考试&#xff09;2.最优化方法&#xff08;开卷考试&#xff09;3.跨文化交际&#xff08;主题演讲20课堂讨…

[系统设计总结] - Proximity Service算法介绍

问题描述 Proximity Service广泛应用于各种地图相关的服务中比如外卖&#xff0c;大众点评&#xff0c;Uber打车&#xff0c;Google地图中&#xff0c;其中比较关键的是我们根据用户的位置来快速找到附近的餐厅&#xff0c;司机&#xff0c;外卖员也就是就近查询算法。 主流的…

小程序面板开发教程|开发照明 Matter 面板步骤(一)

一. 前置知识 前言 出于对 Matter 标准协议及第三方设备接入的可拓展性等方面考虑&#xff0c;照明 Matter 模型面板的功能点定义会与照明的 DP 模型有所不同&#xff0c;因此本文会着重介绍照明 Matter 面板的功能点定义及与 DP 模型的区别&#xff0c;以方便面板小程序开发…

Qt-QLabel 添加图片并设置 GIF 图动态效果

Qt-QLabel 添加图片并设置 GIF 图动态效果 一、添加图片资源并设置图片 选择标签&#xff0c;拖拉到界面上&#xff0c;然后选择器属性 picmap   选择设置&#xff0c;在这里添加图片资源   点击左边的加号符号按钮添加前缀&#xff0c;并设置前缀名&#xff0c;如果已经…

uniapp+renderJS+google map开发安卓版APP非小程序

背景需求 需要在uniapp中接入google地图,研究了一番,都没有找到合适的,现在说一下教程。 效果图 前期工作 这两点缺一不可,否则你啥也看不到。 1、电脑安装L-O-U梯 用于访问G-OO-G-LE的API或者创建google map key。 2、手机安装L-O-U梯 用于显示google地图。我就是手…

数据篇| 关于Selenium反爬杂谈

友情提示:本章节只做相关技术讨论, 爬虫触犯法律责任与作者无关。 LLM虽然如火如荼进行着, 但是没有数据支撑, 都是纸上谈兵, 人工智能的三辆马车:算法-数据-算力,缺一不可。之前写过关于LLM微调文章《微调入门篇:大模型微调的理论学习》、《微调实操一: 增量预训练(Pretrai…

USB 电缆中的信号线 DP、DM 的缩写由来

经常在一些芯片的规格书中看到 USB 的信号对是以 DP 和 DM 命名&#xff1a; 我在想&#xff0c;这些规格书是不是写错了&#xff0c;把 N 写成 M 了&#xff1f;DM 中的 M 到底是什么的缩写&#xff1f; 于是我找了一些资料&#xff0c;终于在《Universal Serial Bus Cables …

xilinx hbm ip运用

AXI-HBM是一个集成的IP核&#xff0c;该核提供高达16个AXI3从PORT的HBM接口&#xff0c;每个使用他自己的独立的时钟。HBM2 GEN存储器也支持&#xff0c;HBM相对传统DDR的方案&#xff0c;带宽得到极大的提高 特征 AXI3从端口存储器接口 -16个独立的256bit存储器接口 -可选的…

Why Is Prompt Tuning for Vision-Language Models Robust to Noisy Labels?

文章汇总 本文的作者针对了提示学习的结构设计进行了分析&#xff0c;发现了一些规律&#xff1a; 1)固定的类名令牌为模型的优化提供了强正则化&#xff0c;减少了由噪声样本引起的梯度。 2)从多样化和通用的web数据中学习到的强大的预训练图像文本嵌入为图像分类提供了强大…

FreeRTOS学习——接口宏portmacro.h

FreeRTOS学习——接口宏portmacro.h&#xff0c;仅用于记录自己阅读与学习源码 FreeRTOS Kernel V10.5.1 portmacro版本&#xff1a;GCC/ARM_CM7 portmacro.h是什么 portmacro.h头文件&#xff0c;用于定义与特定硬件平台相关的数据类型和常量。 在移植过程中&#xff0c;…

stm32 keil有一些别人的工程在你这打开为什么会乱码?如何解决的

因为别人编辑代码使用的编辑器和你的不一样&#xff0c;要更正可以调一下自己的翻译器编码格式 也可以直接换掉文件的格式&#xff0c; 用记事本打开文件&#xff0c;然后点会另存为&#xff0c;下面有个编码格式选择&#xff0c;换成你自己的就行