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

企业级 Hosts 自动化管理实战:基于 HTTP 检测的高可用域名解析方案

摘要

本文针对企业级域名解析稳定性需求,提供一套从IP 检测Hosts 更新的完整自动化解决方案。通过 HTTP 状态码检测、权威 DNS 解析、原子化文件操作等核心技术,结合多行业真实案例,详细阐述方案设计、脚本实现与生产部署,帮助企业实现 Hosts 文件的智能管理,保障核心业务网络连通性。

一、背景:企业级 Hosts 管理的核心痛点

在企业 IT 运维中,Hosts 文件作为本地域名解析的 “最后一道防线”,承担着绕过 DNS 污染、强制指定解析结果等关键任务。但传统人工维护模式存在以下痛点:

  • IP 动态变更:云服务器、API 服务的 IP 定期调整,手动更新易遗漏;
  • DNS 缓存污染:本地 / 运营商 DNS 可能返回旧 IP,导致 “能 Ping 通但服务不可用”;
  • 多环境管理复杂:开发 / 测试 / 生产环境需频繁切换域名映射,人工操作易出错;
  • 故障排查困难:Hosts 文件误修改或失效 IP 未及时清理,导致业务中断。

为解决上述问题,本文提供一套自动化 Hosts 管理方案,通过脚本实现 IP 的 “自动检测 - 更新 - 审计” 闭环。

二、核心技术方案设计

2.1 技术架构概览

方案包含三大核心模块:

  1. IP 健康检测模块:通过 HTTP/HTTPS 状态码验证 IP 有效性(比 Ping 更可靠);
  2. 权威 DNS 解析模块:强制查询公共 DNS 获取实时 IP,避免本地缓存污染;
  3. 原子化更新模块:安全修改 Hosts 文件,防止多进程操作导致的文件损坏;
  4. 日志与审计模块:记录操作全流程,满足合规性要求。

2.2 关键技术实现

2.2.1 双重健康检测:业务级校验替代简单连通性

传统方案仅通过ping检测 IP 是否可达,但 Web 服务(如企业微信 API)可能因业务逻辑(如 IP 未备案)返回 “假连通”。本方案采用HTTP 状态码 + 业务错误码双重检测:

bash

# 检测IP有效性(以企业微信API为例)
check_ip_validity() {local ip=$1local domain="qyapi.weixin.qq.com"local url="https://${domain}/cgi-bin/gettoken?corpid=YOUR_CORPID&corpsecret=YOUR_CORPSECRET"  # 替换为企业实际值# 使用curl检测HTTPS响应(-m 5:超时5秒,-s:静默模式)local response=$(curl --resolve "${domain}:443:${ip}" -m 5 -s "$url")local http_code=$(echo "$response" | jq -r '.http_code')   # HTTP状态码(企业微信返回字段)local errcode=$(echo "$response" | jq -r '.errcode')       # 业务错误码(0表示成功)if [[ "$http_code" == "200" && "$errcode" == "0" ]]; thenreturn 0  # IP有效elsereturn 1  # IP失效fi
}
2.2.2 权威 DNS 解析:绕过本地缓存获取实时 IP

通过dig命令强制查询公共 DNS 服务器(如 114.114.114.114),确保获取最新 IP:

bash

# 获取权威DNS解析结果(需安装bind-utils)
get_authoritative_ip() {local domain=$1# +short:仅输出IP,+time=2:超时2秒,+tries=3:重试3次dig +short +time=2 +tries=3 @114.114.114.114 "$domain" | \grep -E '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$' | head -n1  # 过滤非IP结果
}
2.2.3 原子化 Hosts 更新:避免文件损坏风险

直接修改/etc/hosts时,若脚本中断或多进程同时操作,可能导致文件格式错乱。本方案采用 “临时文件 + 原子替换” 模式:

bash

# 原子化更新Hosts文件(需root权限)
atomic_update_hosts() {local domain=$1local new_ip=$2local temp_file=$(mktemp)  # 创建临时文件# 1. 保留原有非目标域名记录grep -v "^.*\s${domain}\s*$" "$HOSTS_FILE" > "$temp_file"# 2. 添加新的IP映射(避免重复)echo "$new_ip  $domain" >> "$temp_file"# 3. 原子替换正式文件(Linux文件系统保证操作原子性)mv -f "$temp_file" "$HOSTS_FILE"chmod 644 "$HOSTS_FILE"  # 恢复文件权限
}
2.2.4 日志与审计:满足合规要求

所有操作记录写入日志文件(/var/log/hosts_manager.log),包含时间戳、IP 状态、错误信息,支持后续审计:

bash

# 日志记录函数(带时间戳)
log() {local timestamp=$(date +"%Y-%m-%d %H:%M:%S")echo "[${timestamp}] $1" >> "$LOG_FILE"
}

三、完整脚本实现(hosts-optimizer.sh)

3.1 脚本代码

bash

#!/bin/bash
# ==============================================================================
# 企业级Hosts自动化管理脚本(v2.0)
# 功能:自动检测并更新域名IP,支持HTTP/HTTPS业务级校验
# 依赖:curl、jq、dig(需root权限运行)
# 作者:XXX(您的署名)
# 最后更新:2025-05-20
# ==============================================================================# 全局配置
HOSTS_FILE="/etc/hosts"                  # Hosts文件路径
LOG_FILE="/var/log/hosts_manager.log"    # 日志路径
DNS_SERVER="114.114.114.114"            # 权威DNS服务器
CHECK_INTERVAL=300                       # 检测间隔(秒,默认5分钟)
DOMAINS=(                                # 需要管理的域名列表(格式:域名 检测URL)"qyapi.weixin.qq.com https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=YOUR_CORPID&corpsecret=YOUR_CORPSECRET""api.example.com https://api.example.com/health"
)# 初始化环境(创建日志文件、检查依赖)
init_env() {touch "$LOG_FILE"chmod 644 "$LOG_FILE"# 检查依赖工具是否安装for tool in curl jq dig; doif ! command -v "$tool" &> /dev/null; thenlog "错误:缺少依赖工具 $tool,请先安装"exit 1fidone
}# 检测IP有效性(业务级校验)
check_ip_validity() {local ip=$1local domain=$2local check_url=$3# 使用curl强制解析到目标IP并检测URLlocal response=$(curl --resolve "${domain}:443:${ip}" -m 5 -s "$check_url")local http_code=$(echo "$response" | jq -r '.http_code' 2>/dev/null)local errcode=$(echo "$response" | jq -r '.errcode' 2>/dev/null)if [[ "$http_code" == "200" && "$errcode" == "0" ]]; thenlog "IP ${ip} 对 ${domain} 有效"return 0elselog "IP ${ip} 对 ${domain} 失效(http_code=${http_code}, errcode=${errcode})"return 1fi
}# 获取权威DNS解析的IP
get_authoritative_ip() {local domain=$1dig +short +time=2 +tries=3 "@${DNS_SERVER}" "$domain" | \grep -E '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$' | head -n1
}# 原子化更新Hosts文件
atomic_update_hosts() {local domain=$1local new_ip=$2local temp_file=$(mktemp)# 保留非目标域名记录grep -v "^.*\s${domain}\s*$" "$HOSTS_FILE" > "$temp_file"echo "$new_ip  $domain" >> "$temp_file"# 原子替换并清理临时文件mv -f "$temp_file" "$HOSTS_FILE"log "成功更新Hosts:${new_ip} ${domain}"
}# 主循环:定时检测并更新
main_loop() {init_envlog "===== Hosts优化脚本启动(PID=$$) ====="while true; dofor entry in "${DOMAINS[@]}"; dolocal domain=$(echo "$entry" | awk '{print $1}')local check_url=$(echo "$entry" | awk '{print $2}')# 1. 获取权威IPlocal new_ip=$(get_authoritative_ip "$domain")if [ -z "$new_ip" ]; thenlog "警告:无法获取 ${domain} 的权威IP"continuefi# 2. 检测IP有效性if check_ip_validity "$new_ip" "$domain" "$check_url"; then# 3. 检查Hosts中是否已有该IP映射local current_ip=$(grep -v "^#" "$HOSTS_FILE" | grep " ${domain}\s*$" | awk '{print $1}')if [ "$current_ip" != "$new_ip" ]; thenatomic_update_hosts "$domain" "$new_ip"fielselog "跳过无效IP ${new_ip}(${domain})"fidonesleep "$CHECK_INTERVAL"done
}# 入口:检查root权限并启动
if [ "$(id -u)" -ne 0 ]; thenecho "错误:请以root权限运行脚本" >&2exit 1
fimain_loop

3.2 脚本说明

  • 依赖要求:需安装curl(HTTP 请求)、jq(JSON 解析)、bind-utilsdig命令),CentOS/RHEL 系统可通过yum install -y curl jq bind-utils安装。
  • 配置修改:替换DOMAINS中的YOUR_CORPIDYOUR_CORPSECRET(从企业微信后台获取),添加需要管理的其他域名。
  • 运行方式:保存为/usr/local/sbin/hosts-optimizer.sh,赋予执行权限(chmod +x hosts-optimizer.sh),通过systemd注册为服务实现开机自启。

四、应用场景与真实案例

4.1 场景 1:企业微信 API 高可用保障

背景:某连锁零售企业通过企业微信 API 发送会员通知,因 DNS 缓存污染导致部分门店无法调用 API。
方案

  • 在门店终端部署脚本,每 5 分钟检测qyapi.weixin.qq.com的 IP 有效性;
  • 强制使用 114 公共 DNS 解析,避免本地缓存污染;
  • 自动剔除失效 IP,恢复后重新映射。
    效果:通知成功率从 85% 提升至 99.5%,大促期间未出现批量延迟。

4.2 场景 2:电商 CDN 节点容灾

背景:某电商大促期间,CDN 节点因流量过载导致部分区域用户无法访问静态资源。
方案

  • 脚本监控static.example.com的多个 CDN 节点 IP;
  • 检测每个 IP 的 HTTP 状态码(要求返回 200);
  • 自动注释不可用节点,保留可用 IP。
    效果:静态资源访问成功率从 92% 提升至 99.8%,故障恢复时间从 15 分钟缩短至 2 分钟。

4.3 场景 3:开发环境本地调试

背景:开发团队需频繁切换api.dev.local指向本地 / 测试 / 预发布服务器,人工修改 Hosts 易出错。
方案

  • 脚本配置api.dev.local的检测 URL(如http://api.dev.local/health);
  • 自动清理失效的旧 IP 映射;
  • 开发人员只需修改脚本中的DOMAINS配置,无需手动操作 Hosts。
    效果:开发环境切换效率提升 70%,误操作导致的故障减少 90%。

五、生产环境部署指南

5.1 注册为 systemd 服务(推荐)

bash

# 创建服务文件
cat > /etc/systemd/system/hosts-optimizer.service <<EOF
[Unit]
Description=Enterprise Hosts Optimizer Service
After=network.target[Service]
Type=simple
User=root
ExecStart=/usr/local/sbin/hosts-optimizer.sh
Restart=always
RestartSec=10
StandardOutput=file:/var/log/hosts_manager.log
StandardError=inherit[Install]
WantedBy=multi-user.target
EOF# 启动服务并设置开机自启
systemctl daemon-reload
systemctl start hosts-optimizer
systemctl enable hosts-optimizer

5.2 验证脚本运行

  • 查看日志tail -f /var/log/hosts_manager.log,确认 IP 检测与更新记录;
  • 检查 Hosts 文件cat /etc/hosts,确认目标域名已映射到最新有效 IP;
  • 模拟故障:手动修改 Hosts 为无效 IP,观察脚本是否自动替换为有效 IP。

六、总结与展望

本文提供的企业级 Hosts 自动化管理方案,通过业务级健康检测权威 DNS 解析原子化更新等核心技术,解决了传统人工维护的痛点。结合多行业案例,验证了其在提升网络连通性、降低运维成本、满足合规要求等方面的价值。未来可扩展集成邮件 / 企业微信报警、IPv6 支持、CMDB 自动同步等功能,进一步提升自动化水平。

相关文章:

企业级 Hosts 自动化管理实战:基于 HTTP 检测的高可用域名解析方案

摘要 本文针对企业级域名解析稳定性需求&#xff0c;提供一套从IP 检测到Hosts 更新的完整自动化解决方案。通过 HTTP 状态码检测、权威 DNS 解析、原子化文件操作等核心技术&#xff0c;结合多行业真实案例&#xff0c;详细阐述方案设计、脚本实现与生产部署&#xff0c;帮助…...

HTTP/HTTPS与SOCKS5协议在隧道代理中的兼容性设计解析

目录 引言 一、协议特性深度对比 1.1 协议工作模型差异 1.2 隧道代理适配难点 二、兼容性架构设计 2.1 双协议接入层设计 2.2 统一隧道内核 三、关键技术实现 3.1 协议转换引擎 3.1.1 HTTP→SOCKS5转换 3.1.2 SOCKS5→HTTP转换 3.2 连接管理策略 3.2.1 智能连接池 …...

AGI大模型(29):LangChain Model模型

1 LangChain支持的模型有三大类 大语言模型(LLM) ,也叫Text Model,这些模型将文本字符串作为输入,并返回文本字符串作为输出。聊天模型(Chat Model),主要代表Open AI的ChatGPT系列模型。这些模型通常由语言模型支持,但它们的API更加结构化。具体来说,这些模型将聊天消…...

鸿蒙开发进阶:深入解析ArkTS语言特性与开发范式

一、前言 在鸿蒙生态开发体系中&#xff0c;DevEco Studio作为核心开发工具为开发者提供了高效的集成环境。而在掌握工具使用之后&#xff0c;深入理解鸿蒙开发语言成为构建高质量应用的关键。本文将聚焦于鸿蒙系统的核心开发语言——ArkTS&#xff0c;全面解析其起源演进、声…...

数据库 1.0.1

表 数据库是一个非常大的仓库&#xff0c;里面的东西就是表&#xff0c;数据都在表里面 use yyy_company就意思是指定使用哪个仓库 show tables;就是show一下有几张表 因为主包的库是刚创建的&#xff0c;所以只有empty set&#xff08;没有表&#xff09; 创建表 创建的时候…...

Leetcode 01 java

两数之和 /* 给定一个整数数组 nums 和一个整数目标值 target&#xff0c; 请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案&#xff0c;并且你不能使用两次相同的元素。 你可以按任意顺序返回…...

30天自制操作系统day5(vram和显存)(GDT和IDT)(c语言结构体)(汇编-c)(ai辅助整理)

day5 harib02d c语言结构体的一些解释 struct BOOTINFO { char cyls, leds, vmode, reserve; short scrnx, scrny; char *vram; }; //最开始的struct命令只是把一串变量声明集中起来&#xff0c;统一叫做“struct BOOTINFO”。 //最初是1字节的变量cyls&#xff0c;接着是1字…...

Linux僵死进程以及文件操作

僵死进程 僵死进程产生的原因&#xff1a; 当子进程先于父进程结束&#xff0c;父进程没有获取子进程的退出码&#xff0c;此时子进程变成僵死进程。 如何处理僵死进程&#xff1a; &#xff08;1&#xff09;父进程先结束&#xff08;子进程会变成孤儿进程&#xff0c;孤儿…...

19 C 语言位运算、赋值、条件、逗号运算符详解:涵盖运算符优先级与复杂表达式计算过程分析

1 位运算符 位运算符是对整数的二进制表示&#xff08;补码形式&#xff09;进行逐位操作的运算符。以下是主要的位运算符及其功能描述&#xff1a; 运算符描述操作数个数副作用&按位与2无|按位或2无^按位异或2无~按位取反1无<<按位左移2无>>按位右移2无 1.1…...

ubuntu下实时检测机械硬盘和固态硬盘温度

sudo apt update sudo apt install smartmontools然后&#xff0c;使用smartctl命令查看硬盘的详细信息&#xff0c;包括温度&#xff1a; sudo smartctl -a /dev/sda实时监控硬盘温度 虽然smartctl不能直接实时显示温度&#xff0c;你可以使用watch命令结合smartctl来定期查…...

游戏开发实战(三):Python复刻「崩坏星穹铁道」嗷呜嗷呜事务所---源码级解析该小游戏背后的算法与设计模式【纯原创】

文章目录 奇美拉类摸鱼仔&#xff0c;负能量&#xff0c;真老实&#xff0c;小坏蛋&#xff0c;压力怪治愈师小团体画饼王平凡王坏脾气抗压包请假狂请假王内卷王受气包跑路侠看乐子背锅侠抢功劳急先锋说怪话帮倒忙小夸夸工作狂职业经理严酷恶魔职场清流 开始工作吧小奇美拉没想…...

DeepSpeed简介及加速模型训练

DeepSpeed是由微软开发的开源深度学习优化框架&#xff0c;专注于大规模模型的高效训练与推理。其核心目标是通过系统级优化技术降低显存占用、提升计算效率&#xff0c;并支持千亿级参数的模型训练。 官网链接&#xff1a;deepspeed 训练代码下载&#xff1a;git代码 一、De…...

AIGC降重工具

使用 PyQt5 和 Python-docx 实现AIGC降重工具 在日常工作中&#xff0c;文档处理是一个常见的任务&#xff0c;尤其是对于需要批量处理文档内容的场景。今天&#xff0c;我将分享一个使用 PyQt5 和 Python-docx 库实现的简单文档处理工具。这个工具可以帮助用户选择文档文件&a…...

PYTHON训练营DAY31

项目拆分 src/data/load_data.py # -*- coding: utf-8 -*- import sys import io # 设置标准输出为 UTF-8 编码 sys.stdout io.TextIOWrapper(sys.stdout.buffer, encodingutf-8) import pandas as pddef load_data(file_path: str) -> pd.DataFrame:"""加…...

使用VGG-16模型来对海贼王中的角色进行图像分类

动漫角色识别是计算机视觉的典型应用场景&#xff0c;可用于周边商品分类、动画制作辅助等。 这个案例是一个经典的深度学习应用&#xff0c;用于图像分类任务&#xff0c;它使用了一个自定义的VGG-16模型来对《海贼王》中的七个角色进行分类&#xff0c;演示如何将经典CNN模型…...

AI-02a5a7.神经网络-与学习相关的技巧-正则化

过拟合 过拟合指的是只能拟合训练数据&#xff0c;但不能很好地拟合不包含在训练数据中的其他数据的状态。 在机器学习的问题中&#xff0c;过拟合是很常见的问题。 而机器学习的目标是提高泛化能力&#xff0c;即便是没有包含在训练数据里的未观测数据&#xff0c;也希望模…...

C# 常用密码加密与解密技术完全指南

目录 密码安全的核心概念 加密 vs 哈希&#xff1a;何时使用&#xff1f; 密钥管理的重要性 常见攻击手段&#xff08;中间人攻击、彩虹表&#xff09; 基础加密技术 对称加密&#xff08;AES&#xff09; 非对称加密&#xff08;RSA&#xff09; 哈希算法&#xff08;SH…...

C++ QT 与 win32 窗口可以互操作

MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow) {ui->setupUi(this);this->setWindowTitle("天下第一剑"); // HWND hwnd FindWindow(L"天下第一剑",L"天下第一剑"); // qDebug()<<…...

MySQL--day4--排序与分页

&#xff08;以下内容全部来自上述课程&#xff09; 1. 排序数据 1.1 排序基本使用 #1.排序 #如果没有使用排序操作&#xff0c;默认情况下查询返回的数据是按照添加数据的顺序显示的 SELECT * FROM employees;# 练习:按照salary从高到低的顺序显示员工信息 # 使用 ORDER …...

文件操作和IO—初识文件

认识文件 狭义上的文件&#xff08;file&#xff09;&#xff0c;是针对硬盘这种持久化存储的IO设备&#xff0c;当我们想要进行数据保存的时候&#xff0c;往往不是保存成一个整体&#xff0c;而是独立成一个个的单位进行保存&#xff0c;这个独立的单位就被抽象成文件的概念…...

P2670 [NOIP 2015 普及组] 扫雷游戏

P2670 [NOIP 2015 普及组] 扫雷游戏 - 洛谷 #include<bits/stdc.h> using namespace std; int n,m; char a[105][105]; int main(){cin>>n>>m;for(int i1;i<n;i){for(int j1;j<m;j){cin>>a[i][j];}}for(int i1;i<n;i){for(int j1;j<m;j){…...

HomeAssistant开源的智能家居docker快速部署实践笔记(CentOS7)

1. SGCC_Electricity 应用介绍 SGCC_Electricity 是一个用于将国家电网&#xff08;State Grid Corporation of China&#xff0c;简称 SGCC&#xff09;的电费和用电量数据接入 Home Assistant 的自定义集成组件。通过该应用&#xff0c;用户可以实时追踪家庭用电量情况&…...

02 基本介绍及Pod基础排错

01 yaml文件里的字段错误 # 多打了一个i导致的报错 [rootmaster01 yaml]# cat 01-pod.yaml apiVersion: v1 kind: Pod metadata:name: likexy spec:contaiiners:- name: aaaimage: registry.cn-hangzhou.aliyuncs.com/yinzhengjie-k8s/apps:v1 [rootmaster01 yaml]# kubectl …...

9 定时任务与周期性调度

一、定时任务核心机制 1.1 基础调度配置 # celery.py from celery import Celery from celery.schedules import crontabapp Celery(proj) app.conf.beat_schedule {daily-report: {task: report.generate,schedule: crontab(hour3, minute30), # 每天3:30执行args: (),op…...

macOS 效率工具对比分析:Raycast、Alfred、uTools、Spotlight

macOS 效率工具对比分析&#xff1a;Raycast、Alfred、uTools、Spotlight 对比分析四款常见 macOS 高效工具&#xff0c;涵盖功能、插件生态、开发者支持、适用人群等维度&#xff0c;帮助你选择最适合自己的效率助手。 &#x1f50d; 一、基本介绍 工具名简介SpotlightmacOS …...

接口测试速成指南:基础知识+工具使用全解析

你是否也有这样的经历&#xff1a;项目初期接口文档混乱&#xff0c;测试人员无从下手&#xff1b;开发说接口OK&#xff0c;测试却频繁遇坑&#xff1f;别怕&#xff0c;接口测试并没你想得那么难&#xff01; “接口测试怎么做&#xff1f;用什么工具&#xff1f;”面试官一…...

SpringSecurity基础入门

一个身份认证、授权、防御常见攻击的框架。 spring security 中文网&#xff1a;Spring Security中文网 自定义配置 基于内存的用户认证 实现步骤如下&#xff1a; 在配置类中创建security的配置类&#xff1a; Configuration //声明当前类为配置类 EnableWebSecurity //…...

MySQL的安装及相关操作

目录 一. 数据库产生的背景 二. 数据库操作系统的组成 2.1 数据库(Database) 2.2 数据库管理系统(DBMS, Database Management System) 2.3 应用程序(Application) 三. 数据库的分类 3.1 关系数据库 3.2 非关系数据库 四. MySQL安装 4.1yum安装 1. Ubuntu ​2. cent…...

【Code】Foundations 2017- Catalogue, List of Tables, List of Figures

Foundations 2017 目录 | Catalogue表格目录 | List of Tables图表目录 | List of Figures 目录 | Catalogue 英文原文中文翻译词汇学习&#xff08;音标和解释&#xff09;1. General1. 总则1.1 Scope1.1 范围1.2 Glossary1.2 术语表Glossary [ˈɡlɒsəri] 术语表&#xff…...

【TCGA-CRC】TCGA数据读取

写在前面 参考已有的帖子写的&#xff0c;但是临床数据和UCSC的不同。有知道的小伙伴欢迎指正。 rm(list ls()); gc() test1 data.table::fread("./00_Rawdata/GDCdata/TCGA-COAD/Transcriptome_Profiling/Gene_Expression_Quantification/00ae9ab8-6eaa-4085-af72-26…...

BYUCTF 2025

几周没会的比赛了&#xff0c;都是一题游。这周的BYU还不错&#xff0c;难度适中&#xff0c;只是时间有点短。周末时间不够。 Crypto Many Primes from Crypto.Util.number import bytes_to_long, getPrime import randomflag open("flag.txt").read().encode()…...

【Linux】初见,基础指令(续)

前言&#xff1a; 上文讲解了部分指令&#xff0c;本文我们来讲解剩下的指令【Linux】初见&#xff0c;基础指令-CSDN博客 cat指令 语法&#xff1a;cat 选项 文件 功能&#xff1a;打印文件中的内容 选项&#xff1a; -b 对非空行输出进行编号 -n 对输出的说有行进行编号…...

《MambaLLIE:基于隐式Retinex感知的低光照增强框架与全局-局部状态空间建模》学习笔记

Paper:2405.16105 Github:GitHub - wengjiangwei/MambaLLIE 目录 摘要 一、介绍 二、相关工作 2.1 低光图像增强 2.2 视觉空间状态模型 三、方法 3.1 预备知识 3.2 整体流程 3.3 全局优先-局部次之状态空间块 四、实验 4.1 基准数据集与实施细节 4.2 对比实验 4…...

计算机图形学Games101笔记--几何

第二部分&#xff1a;几何 几何介绍 光栅化解决如何渲染&#xff0c;几何研究模型如何存储在GPU的内存中。几何主要分为两种&#xff1a;隐式几何和显式几何。 **隐士几何&#xff1a;**用点之间的关系存储&#xff0c;如球的计算公式。更一般的可以用f(x,y,z)。我们可以令f…...

Web开发-Python应用Flask框架Jinja模版绑定路由参数传递页面解析SSTI注入

知识点&#xff1a; 1、安全开发-Python-Flask&Jinja2 2、安全开发-Python-路由传参&SSTI注入 演示案例-WEB开发-Python-Flask框架&Jinja2模版&路由传参&SSTI注入 0、Pycharm 配置Python解析 新建Flask项目 1、路由传参 app.route(/) app.route(/<id…...

聚焦开放智能,抢占技术高地 | 2025 高通边缘智能创新应用大赛第五场公开课来袭!

随着2025高通边缘智能创新应用大赛的推进&#xff0c;越来越多的参赛者关注如何借助高性能硬件突破技术瓶颈、打造差异化作品。 5月27日晚8点&#xff0c;大赛将开启初赛阶段的第五场专题公开课——由美格软件研究院院长李书杰领衔&#xff0c;深入解析高通平台的底层架构与参…...

NMOS和PMOS的区别

1 区分NMOS和PMOS&#xff1a;衬底箭头指向G级的是NMOS&#xff0c;衬底箭头背向G级的是PMOS 2 区分D和S级&#xff1a;针对NMOS&#xff0c;体二极管的正方向为S级&#xff1b;针对PMOS&#xff0c;体二极管正的方向为D级 3 区分电流方向&#xff1a;针对NMOS&#xff0c;电…...

Paillier加密方案的原理、实现与应用(vs)

一、实验目的 1、掌握NTL的基本配置和方法&#xff08;以下是以visualstudio为例&#xff09; 2、掌握Paillier加密方案的原理与实现 ①钥匙生成&#xff1a;首先&#xff0c;生成一把钥匙&#xff0c;包括钥匙和私钥匙。钥匙由两个大素数(p,q)的乘积n和一个整数g组成&#…...

Metal入门,使用Metal绘制3D图形

这次是使用Metal绘制一个立方体&#xff0c;并且添加旋转效果&#xff0c;绘制正方形的步骤很简单&#xff0c;我们绘制一个正方形就相当于绘制两个三角形&#xff0c;那么绘制一个正方体&#xff0c;我们很容易想到需要绘制他六个面&#xff0c;很显然&#xff0c;我们也需要把…...

Java 04 API

API 简介 一些已经写好的应用程序编程接口Object toString 默认返回的是当前对象在堆内存中的地址值信息&#xff1a;类的全类名十六进制哈希值返回该对象的返回值 class A{ } //返回的是地址哦 String sA.toString(); //细节&#xff1a;使用打印语句&#xff0c;打印对象…...

基于Gitee 的开发分支版本管理规范

一、版本管理规范概述 目的&#xff1a;规范代码分支管理和版本发布流程&#xff0c;提高团队协作效率&#xff0c;确保代码质量和版本可追溯性。适用范围&#xff1a;基于 Gitee 平台开发的所有项目。分支策略&#xff1a;采用 Git Flow 模型的变体&#xff0c;主要分支包括 …...

HOW - 结合 AI 进行 Tailwind 样式开发

文章目录 情况 1&#xff1a;使用 Tailwind CSS 与手写传统 CSS 的开发效率对比情况 2&#xff1a;AI Tailwind 自动生成 UI 的效率如何&#xff1f;总结 在 WHAT - Tailwind 样式方案&#xff08;不写任何自定义样式&#xff09; 中我们已经简单介绍过 Tailwind。今天主要认识…...

系统数据对接-从获取到处理的全流程

在后端架构的复杂生态中&#xff0c;子系统间或与外部系统的对接是常态&#xff0c;其核心要义在于实现数据的精准传输。本文聚焦于数据传输后的运算逻辑与异常处理机制&#xff0c;旨在为后端开发者提供深度见解。 一、数据获取机制&#xff1a;触发式与定时任务的权衡 &…...

Java 09Stream流与File类

Stream流与File类 Stream流 简化集合和数组的操作&#xff0c;startWith(“张”) 第一个为这个返回true String1.获取Stream对象 单列集合 双列集合 先获得键值对 在遍历数组 零散的数据 Stream<Integer> arrStream.of(1,2,34,3); stream.forEach(sss); 即可2.中间…...

《光与影:33号远征队》栩栩如生的角色动画是如何创建的?

《光与影&#xff1a;33号远征队》是一款由Sandfall Interactive公司开发的回合制RPG游戏&#xff0c;背景是一个黑暗的幻想世界。游戏因其独特的艺术风格和引人注目的叙事赢得了无数赞誉&#xff0c;成为今年大热游戏中的一匹黑马。 在该游戏制作中Sandfall依靠包括Xsens在内的…...

GESP2024年12月认证C++二级( 第三部分编程题(1)寻找数字)

参考程序&#xff08;枚举&#xff09;&#xff1a; #include <iostream> //#include <cmath> using namespace std;int main() {int t;cin >> t;while (t--) {long long a;cin >> a;bool found false;// 枚举 b for (long long b 1; b * b * b * b…...

《探索具身智能机器人视觉-运动映射模型的创新训练路径》

视觉 - 运动映射模型作为实现智能交互与精准行动的核心&#xff0c;吸引着全球科研人员与技术爱好者的目光。这一模型就像机器人的 “神经中枢”&#xff0c;连接着视觉感知与肢体运动&#xff0c;使机器人能够在复杂的现实环境中灵活应对各种任务。 传统的视觉 - 运动映射模型…...

Python打卡DAY31

今日的示例代码包含2个部分 notebook文件夹内的ipynb文件&#xff0c;介绍下今天的思路项目文件夹中其他部分&#xff1a;拆分后的信贷项目&#xff0c;学习下如何拆分的&#xff0c;未来你看到的很多大项目都是类似的拆分方法 知识点回顾 规范的文件命名规范的文件夹管理机器学…...

【SPIN】PROMELA远程引用与控制流验证(SPIN学习系列--5)

PROMELA语言提供了两种强大的机制用于验证并发系统&#xff1a;远程引用(remote references)和进程变量引用。这些机制使得在不引入额外状态变量的情况下&#xff0c;能够精确描述系统状态和属性。 远程引用(Remote References) 远程引用允许你直接引用进程中的控制位置(labe…...

GMSL:汽车里的音视频传输

参考链接&#xff1a; blog.csdn.net/weixin_50875614/article/details/119995651 blog.csdn.net/syjie19900426/article/details/145269782 SerDes 应用场景 WHAT GMSL是什么 GMSL(Gigabit Multimedia Serial Links),中文名称为千兆多媒体串行链路,是Maxim公司推出的一种…...