保姆级教程:在WSL上用AWS CLI配置MinIO临时访问凭证(含时区避坑指南)

news2026/3/27 9:14:51
在WSL中实战MinIO临时凭证从配置到避坑的全流程指南如果你正在Windows系统上使用WSL进行开发并且需要为MinIO对象存储生成临时访问凭证那么这篇文章将为你提供完整的解决方案。我们将从环境准备开始逐步深入到凭证生成、策略配置以及时区问题的处理确保你能够顺利实现本地开发环境中的临时访问控制。1. 环境准备与基础配置在开始之前确保你的WSL环境已经安装了MinIO服务并正常运行。MinIO是一个高性能的对象存储服务完全兼容Amazon S3 API这使得我们可以使用AWS CLI工具来与之交互。首先我们需要在WSL中安装AWS CLI工具。虽然MinIO不是AWS服务但它兼容S3 API因此AWS CLI成为了管理MinIO的理想工具。以下是安装步骤# 下载AWS CLI安装包 curl https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip -o awscliv2.zip # 解压下载的文件 unzip awscliv2.zip # 执行安装 sudo ./aws/install安装完成后验证AWS CLI是否安装成功aws --version提示如果你遇到权限问题可以尝试在命令前加上sudo或者确保当前用户有足够的权限执行安装操作。2. MinIO控制台配置在WSL中启动MinIO服务后你可以通过浏览器访问http://localhost:9000进入MinIO控制台。这里我们需要完成几个关键配置创建访问密钥在控制台的Identity部分创建新的访问密钥这将用于后续的AWS CLI配置设置存储桶策略定义哪些操作是被允许的例如上传、下载、列出对象等创建用户并分配策略为特定用户分配适当的权限以下是一个基本的存储桶策略示例允许用户列出存储桶内容和上传/下载对象{ Version: 2012-10-17, Statement: [ { Effect: Allow, Action: [ s3:ListBucket, s3:GetObject, s3:PutObject ], Resource: [ arn:aws:s3:::your-bucket-name, arn:aws:s3:::your-bucket-name/* ] } ] }3. 配置AWS CLI连接MinIO现在我们需要配置AWS CLI以连接到本地运行的MinIO服务。与连接真正的AWS服务不同我们需要指定自定义的终端节点(endpoint)。aws configure --profile minio-local执行上述命令后系统会提示你输入以下信息AWS Access Key ID在MinIO控制台创建的用户访问密钥AWS Secret Access Key对应的密钥Default region name可以输入任意值如us-east-1Default output format建议选择json注意这里的配置是针对MinIO的与真实的AWS服务无关。我们只是利用AWS CLI的工具链来操作MinIO。验证配置是否成功aws --profile minio-local --endpoint-url http://localhost:9000 s3 ls如果一切正常这个命令应该会列出你MinIO服务中的所有存储桶。4. 生成临时安全凭证(STS)临时安全凭证(STS)是MinIO提供的一种机制允许你生成具有有限权限和有限时间的访问凭证。这在以下场景中特别有用前端应用需要直接上传文件到存储桶而不暴露长期凭证需要为第三方应用提供临时访问权限在开发环境中模拟生产环境的权限控制生成临时凭证的基本命令结构如下aws --profile minio-local \ --endpoint-url http://localhost:9000 \ sts assume-role \ --policy {Version:2012-10-17,Statement:[{Effect:Allow,Action:[s3:PutObject],Resource:[arn:aws:s3:::your-bucket-name/*]}]} \ --role-arn arn:aws:s3:::your-bucket-name \ --role-session-name temp-session \ --duration-seconds 3600让我们分解这个命令的各个部分--profile minio-local使用我们之前配置的MinIO本地配置--endpoint-url指定MinIO服务的地址--policy可以进一步限制临时凭证的权限可选--role-arn指定策略名称--role-session-name为临时会话指定一个名称--duration-seconds凭证的有效期秒命令执行成功后你会得到类似以下的输出{ Credentials: { AccessKeyId: TEMPORARY_ACCESS_KEY, SecretAccessKey: TEMPORARY_SECRET_KEY, SessionToken: TEMPORARY_SESSION_TOKEN, Expiration: 2023-05-01T12:00:00Z } }5. 时区问题与解决方案在使用MinIO STS功能时一个常见的陷阱是时区问题。你可能会注意到凭证的过期时间(Expiration)显示的时间比预期早了8小时如果你在中国时区。这是因为MinIO默认使用UTC时间而你的本地系统可能使用的是东八区时间。解决方案有以下几种调整本地时间显示在应用程序中处理时间显示时将UTC时间转换为本地时区在生成凭证时考虑时区差异如果你需要凭证在特定本地时间过期计算对应的UTC时间在MinIO服务器配置中设置时区修改MinIO的启动参数指定时区对于开发环境最简单的处理方式是在代码中统一使用UTC时间避免时区转换带来的混淆。例如在JavaScript中// 将UTC时间转换为本地时间 const expirationUTC new Date(2023-05-01T12:00:00Z); const expirationLocal new Date(expirationUTC.getTime() (8 * 60 * 60 * 1000)); // 东八区加8小时6. 高级策略与权限控制MinIO的STS功能支持更精细化的权限控制。你可以在生成临时凭证时指定额外的策略进一步限制权限。这在以下场景中特别有用限制只能访问特定前缀的对象限制上传文件的大小或类型限制只能在特定时间段访问以下是一个更复杂的策略示例限制用户只能上传小于10MB的图片文件{ Version: 2012-10-17, Statement: [ { Effect: Allow, Action: [s3:PutObject], Resource: [arn:aws:s3:::your-bucket-name/images/*], Condition: { NumericLessThanEquals: {s3:UploadSize: 10485760}, StringLike: {s3:Content-Type: image/*} } } ] }在生成临时凭证时将这个策略作为--policy参数的值传入aws --profile minio-local \ --endpoint-url http://localhost:9000 \ sts assume-role \ --policy 上面复杂的策略JSON \ --role-arn arn:aws:s3:::your-bucket-name \ --role-session-name image-upload-session \ --duration-seconds 72007. 验证与调试技巧在开发过程中验证临时凭证是否按预期工作非常重要。以下是一些实用的验证和调试技巧使用临时凭证进行S3操作AWS_ACCESS_KEY_IDTEMPORARY_KEY \ AWS_SECRET_ACCESS_KEYTEMPORARY_SECRET \ AWS_SESSION_TOKENTEMPORARY_TOKEN \ aws --endpoint-url http://localhost:9000 s3 cp test.txt s3://your-bucket-name/检查凭证剩余有效期AWS_ACCESS_KEY_IDTEMPORARY_KEY \ AWS_SECRET_ACCESS_KEYTEMPORARY_SECRET \ AWS_SESSION_TOKENTEMPORARY_TOKEN \ aws --endpoint-url http://localhost:9000 sts get-caller-identity模拟权限不足的情况尝试执行策略中未允许的操作验证是否会被拒绝检查MinIO服务器日志在WSL中查看MinIO服务的输出日志了解详细的请求处理情况提示在开发过程中可以设置较短的凭证有效期如60秒来快速测试凭证过期行为但在生产环境中应根据实际需求设置合理的有效期。8. 实际应用场景示例让我们通过一个实际的开发场景来综合运用上述知识。假设你正在开发一个图片上传功能需要前端应用能够直接上传图片到MinIO而不暴露长期凭证。解决方案步骤后端服务生成一个具有以下限制的临时凭证只能上传到特定的uploads/前缀只允许PUT操作限制文件类型为图片有效期1小时将临时凭证安全地传递给前端应用前端使用凭证直接上传文件到MinIO后端生成凭证的示例代码Node.js环境const { execSync } require(child_process); function generateUploadToken(userId) { const policy { Version: 2012-10-17, Statement: [ { Effect: Allow, Action: [s3:PutObject], Resource: [arn:aws:s3:::user-uploads/${userId}/*], Condition: { StringLike: { s3:Content-Type: image/* } } } ] }; const command aws --profile minio-local \ --endpoint-url http://localhost:9000 \ sts assume-role \ --policy ${JSON.stringify(policy)} \ --role-arn arn:aws:s3:::user-uploads \ --role-session-name user-${userId} \ --duration-seconds 3600; const result JSON.parse(execSync(command).toString()); return { accessKey: result.Credentials.AccessKeyId, secretKey: result.Credentials.SecretAccessKey, sessionToken: result.Credentials.SessionToken, expiration: result.Credentials.Expiration }; }前端使用凭证上传的示例JavaScriptasync function uploadFile(file, credentials) { const s3 new AWS.S3({ endpoint: http://localhost:9000, accessKeyId: credentials.accessKey, secretAccessKey: credentials.secretKey, sessionToken: credentials.sessionToken, s3ForcePathStyle: true, signatureVersion: v4 }); const params { Bucket: user-uploads, Key: user123/${file.name}, Body: file, ContentType: file.type }; try { const data await s3.upload(params).promise(); console.log(Upload successful, data.Location); } catch (err) { console.error(Upload error, err); } }9. 性能优化与最佳实践在使用MinIO STS功能时遵循以下最佳实践可以提升性能和安全性凭证有效期设置开发环境1-2小时生产环境根据实际需求设置通常15分钟-12小时对于特别敏感的操作可以考虑更短的有效期权限最小化原则只授予完成任务所需的最小权限使用策略条件进一步限制访问缓存策略适当缓存临时凭证以减少STS调用但不要缓存太久避免使用过期的凭证监控与日志记录所有STS凭证的生成和使用情况设置警报监控异常的凭证使用模式错误处理准备好处理凭证过期的情况提供清晰的错误信息但不要泄露安全细节# 示例监控MinIO STS调用的简单方法 journalctl -u minio --since 1 hour ago | grep AssumeRoleWithWebIdentity10. 常见问题与解决方案在实际开发中你可能会遇到以下常见问题问题1凭证生成失败提示权限不足解决方案检查MinIO控制台中用户是否绑定了正确的策略确保--role-arn参数指定的策略存在验证使用的长期凭证是否有生成临时凭证的权限问题2生成的凭证无法执行预期操作解决方案检查生成凭证时指定的策略确保没有在二次策略中添加基础策略中不存在的权限使用sts get-caller-identity验证凭证信息问题3凭证过期时间显示不正确解决方案确认这是时区问题而非真正的过早过期在应用程序中正确处理UTC时间的显示考虑在MinIO服务器配置中设置时区问题4临时凭证在某些客户端库中无法使用解决方案确保客户端库支持SessionToken检查是否正确地传递了所有三个凭证元素(AccessKeyId, SecretAccessKey, SessionToken)验证客户端库是否兼容MinIO的STS实现# 诊断凭证问题的实用命令 AWS_ACCESS_KEY_IDTEMP_KEY AWS_SECRET_ACCESS_KEYTEMP_SECRET AWS_SESSION_TOKENTEMP_TOKEN \ aws --endpoint-url http://localhost:9000 sts get-caller-identity11. 安全注意事项在使用临时凭证时安全是首要考虑因素。以下是一些关键的安全实践保护长期凭证用于生成临时凭证的长期凭证应当妥善保管最好只在服务器端使用限制临时凭证权限遵循最小权限原则只授予必要的权限使用HTTPS在生产环境中确保MinIO服务配置了TLS加密监控异常活动设置日志和警报监控异常的凭证使用模式定期轮换长期凭证即使使用临时凭证也应定期更换生成它们的长期凭证避免在客户端存储凭证即使是临时凭证也应尽量避免在前端代码中硬编码实施IP限制在可能的情况下通过策略条件限制源IP范围{ Condition: { IpAddress: {aws:SourceIp: [192.0.2.0/24]} } }12. 与其他开发工具的集成MinIO的STS功能可以很好地与各种开发工具和框架集成。以下是一些常见的集成场景与前端框架集成React/Vue组件直接上传到MinIO通过后端服务获取临时凭证使用aws-sdk或minio-js客户端库与后端服务集成作为微服务的存储层为不同服务生成隔离的临时凭证实现多租户存储方案与CI/CD管道集成为构建过程生成临时上传凭证限制部署容器的存储权限自动化备份和日志存储与Serverless函数集成为每个函数执行生成临时凭证实现函数间的安全数据共享限制函数对存储的访问范围// 示例在Express.js中创建临时凭证端点 app.get(/upload-token, authenticateUser, (req, res) { const token generateUploadToken(req.user.id); res.json({ endpoint: https://minio.example.com, bucket: user-uploads, prefix: ${req.user.id}/, credentials: token }); });13. 扩展知识与进阶技巧对于想要更深入了解MinIO STS功能的开发者以下是一些进阶主题自定义身份提供者集成LDAP/AD身份验证使用OpenID Connect提供者实现自定义的STS端点策略变量使用策略变量实现动态权限基于用户属性的条件访问多租户策略模板性能调优优化STS令牌生成性能大规模部署的最佳实践高可用性配置审计与合规详细的访问日志记录合规性策略实施敏感操作监控# 示例使用jq处理STS输出 aws --profile minio-local --endpoint-url http://localhost:9000 sts assume-role ... | jq -r .Credentials | export AWS_ACCESS_KEY_ID\(.AccessKeyId)\nexport AWS_SECRET_ACCESS_KEY\(.SecretAccessKey)\nexport AWS_SESSION_TOKEN\(.SessionToken)14. 本地开发与生产环境的差异在将使用MinIO STS功能的应用程序从本地开发环境迁移到生产环境时需要注意以下差异端点配置开发环境通常使用localhost生产环境需要使用域名和HTTPS凭证管理开发环境可以使用简化配置生产环境需要严格的凭证轮换和权限控制监控与日志开发环境可能不需要详细日志生产环境需要全面的审计跟踪高可用性开发环境通常单节点运行生产环境应该部署MinIO集群网络配置开发环境可能没有网络限制生产环境需要配置适当的防火墙规则和安全组# 生产环境MinIO集群示例配置 export MINIO_ROOT_USERadmin export MINIO_ROOT_PASSWORDcomplex-password export MINIO_STORAGE_CLASS_STANDARDEC:4 minio server http://minio{1...4}.example.com/data{1...4}15. 资源清理与管理在开发和测试过程中及时清理不再需要的资源是一个好习惯。以下是一些管理WSL中MinIO资源的技巧删除测试用户和策略定期清理MinIO控制台中创建的用户和策略避免积累大量测试用的临时配置清理存储桶内容使用AWS CLI删除测试数据设置生命周期策略自动清理旧对象重置AWS CLI配置删除不再使用的profile清理旧的凭证缓存# 清理存储桶内容的示例命令 aws --profile minio-local --endpoint-url http://localhost:9000 s3 rm s3://test-bucket --recursive # 删除AWS CLI配置 sed -i /\[profile minio-test\]/,/^$/d ~/.aws/config sed -i /\[minio-test\]/,/^$/d ~/.aws/credentials16. 自动化与脚本编写为了提高效率可以将常见的MinIO STS操作封装成脚本。以下是一些实用的脚本示例生成临时凭证的Bash函数function minio_sts_token() { local profile$1 local bucket$2 local duration${3:-3600} local policy${4:-{Version:2012-10-17,Statement:[{Effect:Allow,Action:[s3:*],Resource:[arn:aws:s3:::$bucket,arn:aws:s3:::$bucket/*]}]}} aws --profile $profile \ --endpoint-url http://localhost:9000 \ sts assume-role \ --policy $policy \ --role-arn arn:aws:s3:::$bucket \ --role-session-name temp-session-$(date %s) \ --duration-seconds $duration }验证临时凭证的Python脚本import boto3 from botocore.client import Config def verify_token(access_key, secret_key, token): s3 boto3.client( s3, endpoint_urlhttp://localhost:9000, aws_access_key_idaccess_key, aws_secret_access_keysecret_key, aws_session_tokentoken, configConfig(signature_versions3v4) ) try: response s3.list_buckets() print(Verification successful. Accessible buckets:) for bucket in response[Buckets]: print(f - {bucket[Name]}) return True except Exception as e: print(fVerification failed: {str(e)}) return False自动清理旧凭证的脚本#!/bin/bash # 清理超过24小时的MinIO STS用户会话 MINIO_ALIASmyminio TEMP_USERS$(mc admin user list $MINIO_ALIAS | grep ^sts- | awk {print $1}) for user in $TEMP_USERS; do CREATION_TIME$(mc admin user info $MINIO_ALIAS $user | grep CreatedAt: | awk {print $2}) if [[ $(date -d $CREATION_TIME %s) -lt $(date -d 24 hours ago %s) ]]; then echo Deleting expired STS user: $user (created at $CREATION_TIME) mc admin user remove $MINIO_ALIAS $user fi done17. 版本兼容性与升级注意事项MinIO和AWS CLI工具都在不断更新保持版本兼容性很重要。以下是一些版本管理的建议AWS CLI版本MinIO保持与最新AWS S3 API的兼容性建议使用较新的AWS CLI版本(v2)MinIO版本定期更新到稳定版本注意版本变更日志中的STS相关更新测试策略在升级前测试关键STS功能准备回滚方案客户端库兼容性确保使用的SDK与MinIO版本兼容特别注意STS相关的API变化# 检查MinIO服务器版本 curl -s http://localhost:9000/minio/version | jq # 检查AWS CLI版本 aws --version18. 跨平台开发注意事项如果你的开发环境涉及多个平台Windows WSL、macOS、Linux还需要注意以下事项路径处理Windows和Unix-like系统的路径表示不同在脚本中统一使用正斜杠(/)换行符Windows使用CRLFUnix使用LF在跨平台脚本中统一使用LF环境变量不同shell的环境变量语法可能不同使用跨平台兼容的写法权限模型Windows和Linux的权限系统不同在WSL中注意文件权限问题# 跨平台兼容的环境变量设置示例 export MINIO_ACCESS_KEYminioadmin export MINIO_SECRET_KEYminioadmin minio server /data19. 性能测试与基准了解MinIO STS的性能特点对于设计可扩展的系统很重要。以下是一些性能测试的建议STS令牌生成性能测试每秒能生成多少临时凭证测量生成凭证的延迟使用临时凭证的操作性能比较临时凭证和长期凭证的操作性能差异测试不同策略复杂度对性能的影响并发测试模拟多个客户端同时使用临时凭证测试MinIO服务器在高负载下的表现# 简单的STS性能测试脚本 start$(date %s.%N) for i in {1..100}; do aws --profile minio-local --endpoint-url http://localhost:9000 sts assume-role ... /dev/null done end$(date %s.%N) echo 100 STS calls took $(echo $end - $start | bc) seconds20. 相关工具与替代方案除了AWS CLI还有其他工具可以用于管理MinIO STSMinIO客户端(mc)官方命令行工具支持STS相关操作MinIO JavaScript SDK前端集成友好支持临时凭证Terraform Provider基础设施即代码管理自动化策略和用户配置Pulumi/Crossplane现代基础设施管理工具声明式MinIO资源管理# 使用mc命令生成临时凭证示例 mc share upload --expire1h myminio/mybucket/path在实际项目中根据团队的技术栈和偏好选择合适的工具组合。AWS CLI提供了最全面的功能而MinIO自带的工具可能在某些场景下更简单易用。

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

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

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…