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

DAOS系统架构-组件

在这里插入图片描述

如上图所示,一个完整的DAOS系统是由管理节点组件、客户端节点组件、服务端节点组件以及网络通信组件四个部分组成。管理节点组件通过管理网络通道(蓝色)对DAOS服务管理和监控。客户端节点组件通过数据网络通道(红色)与服务端节点组件通信实现数据读取和写入。服务端节点组件是整个DAOS系统的核心组件,用于集群数据的管理。

1.1. 服务端节点组件

在服务端,每个节点是由daos_serverdaos_engine两类组件构建,它们是运行在服务端节点上的守护进程。daos_server是DAOS控制平面的组件,负责解析配置文件,启动和监控多个daos_engine组件。daos_engine是DAOS数据平面的组件,是一个多线程进程,是由daos_server启动的。每个daos_server可以启动一个或多个daos_engine(通过配置daos_server.yml实现)。daos_engine负责处理元数据和I/O请求(通过CART网络通信中间件和调用PMDK和SPDK库直接访问本地NVMe设备)。PMDK用于直接访问存储级别的内存设备(SCM:storage-class memory)。SPDK用于直接访问NVMe SSD。

● daos_server.service - DAOS ServerLoaded: loaded (/usr/lib/systemd/system/daos_server.service; disabled; vendor preset: disabled)Active: active (running) since Thu 2025-04-10 19:07:50 CST; 18h agoMain PID: 67250 (daos_server)Tasks: 52 (limit: 1644956)Memory: 100.2GCGroup: /system.slice/daos_server.service├─67250 /usr/bin/daos_server start└─74592 /usr/bin/daos_engine -t 12 -x 2 -g daosfs00 -d /var/lib/daos/daos_server -T 4 -n /var/lib/daos/daos_control/engine0/daos_nvme.conf -I 0 -r 13312 -H 2 -s /var/lib/daos/daos_scm/0

1.2. 客户端节点组件

DAOS客户端与服务端通信主要通过DAOS Library(libdaos)。libdaos是专门为用户应用和IO中间件存储数据到DAOS container中而设计的。libdaos允许应用通过该接口与daos_engine进行通信,用来管理container和以不同的方式访问object。DAOS在libdaos之上又封装了一个libdfs库。libdfs库模拟了POSIX语义来支持文件系统应用程序。

另外,在DAOS客户端组件中,还提供了DAOS agent。它通过dRPC与libdaos通信来对应用程序进程身份验证。DAOS agent可以支持不同的身份验证框架,并使用Unix域套接字与客户端库进行通信。它还可以通过gRPC与每个DAOS server进行通信,以便向libdaos提供DAOS系统成员信息并支持pool list操作。

● daos_agent.service - DAOS AgentLoaded: loaded (/usr/lib/systemd/system/daos_agent.service; disabled; vendor preset: disabled)Active: active (running) since Tue 2025-04-08 13:17:29 CST; 3 days agoMain PID: 1467814 (daos_agent)Tasks: 27 (limit: 1644967)Memory: 26.2MCGroup: /system.slice/daos_agent.service└─1467814 /usr/bin/daos_agent

1.3. 管理节点组件

管理节点组件提供了系统管理工具(dmg)和管理API。dmg是在管理API之上设计的一个命令行工具,系统用管理员可以通过dmg命令管理和监控DAOS集群。管理API是专门为第三方存储管理框架设计的,第三方管理框架可以通过调用该API来监控DAOS集群。无论是dmg还是API,最终都是通过gRPC与daos_server组件通信。

root@node2 ~]# dmg --help
Usage:dmg [OPTIONS] <command>dmg (DAOS Management) is a tool for connecting to DAOS servers
for the purpose of issuing administrative commands to the cluster. dmg is
provided as a means for allowing administrators to securely discover and
administer DAOS components such as storage allocations, network configuration,
and access control settings, along with system wide operations.Application Options:--allow-proxy   Allow proxy configuration via environment-i, --insecure      Have dmg attempt to connect without certificates-d, --debug         Enable debug output--log-file=     Log command output to the specified file-j, --json          Enable JSON output-J, --json-logging  Enable JSON-formatted log output-o, --config-path=  Client config file pathHelp Options:-h, --help          Show this help messageAvailable commands:check           Check system healthconfig          Perform tasks related to configuration of hardware on remote servers (aliases: cfg)container       Perform tasks related to DAOS containers (aliases: cont)network         Perform tasks related to network devices attached to remote servers (aliases: net)pool            Perform tasks related to DAOS poolsserver          Perform tasks related to remote servers (aliases: srv)server-version  Print server versionstorage         Perform tasks related to storage attached to remote servers (aliases: sto)support         Perform debug tasks to help support team (aliases: supp)system          Perform distributed tasks related to DAOS system (aliases: sys)telemetry       Perform telemetry operations (aliases: telem)version         Print dmg version

1.4. 网络通信组件

在整个DAOS系统中,DAOS使用了3类通信渠道:gRPC、dRPC和CART。

gRPC为DAOS管理提供了一个双向安全通道,通常使用out-of-band TCP/IP网络,用于管理通信。它依赖TLS/SSL来对administrator和server进行身份验证。

dRPC是一种基于Unix域套接字构建的通信通道,用于进程间通信。主要用应用于DAOS agent与DAOS libdaos应用进程的身份认证,DAOS server与DAOS engine之间的协议序列化。

CART是用户空间的函数库,主要用于客户端与服务端的数据传输。通常采用低延时高带宽的网络,比如RDMA。CART是在Mercury和libfabric上构建的。CART库用于libdaos和daos_engine实例之间的所有通信。

相关文章:

DAOS系统架构-组件

如上图所示&#xff0c;一个完整的DAOS系统是由管理节点组件、客户端节点组件、服务端节点组件以及网络通信组件四个部分组成。管理节点组件通过管理网络通道&#xff08;蓝色&#xff09;对DAOS服务管理和监控。客户端节点组件通过数据网络通道&#xff08;红色&#xff09;与…...

论文精读:MSCA-Net:多尺度上下文聚合网络在红外小目标检测中的突破

论文地址:https://arxiv.org/pdf/2503.17193 目录 一、论文结构解析 二、三大创新点详解 1. 多尺度增强检测注意力(MSEDA) 2. 位置卷积块注意力模块(PCBAM) 3. 通道聚合模块(CAB) 三、实验结果对比 定量分析(表I关键数据) 定性对比 四、应用场景展望 五、总…...

LangGraph 使用指南

安装配置 安装依赖 LangGraph 可以通过 pip 安装&#xff1a; pip install langgraph如果您想使用最新的功能和改进&#xff0c;可以从源代码安装&#xff1a; pip install githttps://github.com/langchain-ai/langgraph.git环境配置 LangGraph 与 LangChain 共享许多配置…...

C++指针(四)万字图文详解!

个人主页&#xff1a;PingdiGuo_guo 收录专栏&#xff1a;C干货专栏 前言 相关文章&#xff1a;C指针&#xff08;一&#xff09;、C指针&#xff08;二&#xff09;、C指针&#xff08;三&#xff09; 本篇博客是介绍函数指针、函数指针数组、回调函数、指针函数的。 点赞破六…...

【AI提示词】长期主义助手提供规划支持

提示说明 长期主义是一种关注长期利益和持续学习的思维模式&#xff0c;帮助个人和组织在快速变化的环境中保持耐心和系统性思考。 提示词 # Role: Long-termist Assistant## Profile - language: 中文 - description: 长期主义是一种关注长期利益和持续学习的思维模式&…...

JavaScript逆向工程:如何判断对称加密与非对称加密

在现代Web应用安全分析中&#xff0c;加密算法的识别是JavaScript逆向工程的关键环节。本文将详细介绍如何在逆向工程中判断JavaScript代码使用的是对称加密还是非对称加密。 一、加密算法基础概念 1. 对称加密 (Symmetric Encryption) 特点&#xff1a;加密和解密使用相同的…...

制造企业如何通过实现数据统一?

随着生产规模的扩大、供应链的复杂化以及市场需求的快速变化&#xff0c;企业内部的数据管理问题日益凸显。数据孤岛、数据冗余、数据不一致等问题不仅降低了运营效率&#xff0c;还可能导致决策失误。那么&#xff0c;制造企业如何才能打破这些壁垒&#xff0c;实现数据的统一…...

ICRA-2025 | 视觉预测助力机器人自主导航!NavigateDiff:视觉引导的零样本导航助理

论文&#xff1a;Yiran Qin 1 , 2 ^{1,2} 1,2, Ao Sun 2 ^{2} 2, Yuze Hong 2 ^{2} 2, Benyou Wang 2 ^{2} 2, Ruimao Zhang 1 ^{1} 1单位&#xff1a; 1 ^{1} 1中山大学&#xff0c; 2 ^{2} 2香港中文大学深圳校区论文标题&#xff1a;NavigateDiff: Visual Predictors are Ze…...

Java 与 LibreOffice 集成开发指南

1. 引言 Java 与 LibreOffice 的集成开发为开发者提供了一种强大的工具&#xff0c;用于实现文档自动化处理、文档转换、内容编辑等任务。通过 Java 调用 LibreOffice 提供的 API&#xff0c;可以实现跨平台的文档处理功能&#xff0c;满足各种业务需求。本文将详细介绍如何使…...

如果单表数据量大,只能考虑分库分表吗

程序员最怕啥?不是需求改八遍,也不是半夜报警电话,而是数据库突然卡成PPT!尤其是当单表数据冲到几千万行,查询慢得像老牛拉车,这时候团队第一反应往往是:“赶紧分库分表!” 但兄弟,分库分表可不是什么温柔小姐姐,它更像是个浑身带刺的仙人掌——你以为抱上就能解决问…...

3.3.1 spdlog异步日志

文章目录 3.3.1 spdlog异步日志1. spdlog1. 日志作用2 .同步日志和异步日志区别 2. spdlog是什么下载命令&#xff1a;2. spdlog为什么高效3. spdlog特征5. spdlog输出控制6. 处理流程7. 文件io8.问题 2. 如何创建logger3. 如何创建sink4. 如何自定义格式化5. 如何创建异步日志…...

【Web功能测试】注册与登录功能测试用例设计深度解析

1 注册功能测试用例设计 1.1 明确需求与测试范围 必填字段&#xff1a;手机号、验证码、密码 手机号规则&#xff1a;11位手机号 密码规则&#xff1a;6-16位&#xff0c;需包含大小写字母必须同时存在&#xff0c;数字或符号存在其一 协议勾选 提交后跳转登录页或显示成功…...

netstat 查看端口占用、杀死进程

文章目录 查看端口占用强制杀死 报错信息使用 lsof 查看端口占用 netstat -tanlp强制杀死 在安全的情况下&#xff0c;用下面命令杀死端口占用的进程 sudo kill $(sudo lsof -t -i:3128)报错信息 部署程序时&#xff0c;会出现这样的报错&#xff1a; Error response from…...

Windows 11 PowerShell重定向文本文件的编码问题

目录 问题的由来 编码导致的问题 解决办法 VSCode进行转换 记事本进行转换 直接指定输出的文本编码 总结 问题的由来 在我的嵌入式系统的课程中有一个裸机开发的实验&#xff0c;其中需要把图片等文件转换为C语言数组保存在程序中。课程中&#xff0c;我推荐了CodePlea的…...

蓝桥杯冲刺:一维差分

系列文章目录 蓝桥杯系列&#xff1a;一维差分 文章目录 系列文章目录前言一、一维差分&#xff1a; 差分数组的意义&#xff1a; 二、差分的性质&#xff1a; 差分和前缀和的关系 三、一维差分代码实现&#xff1a;四、典型真题&#xff08;利用一维差分来实现&#xff09; 这…...

理解企业内部信息集成

目录 1. 技术平台集成 2. 数据集成 3. 应用集成 4. 业务过程集成 5. 应用集成与企业内部信息集成的区别 企业内部信息集成是将分散的技术、数据、应用和业务流程整合为一个协同的整体&#xff0c;以提高效率、减少冗余和增强决策能力。 企业内部信息集成一般可以分为4个方…...

论文学习:《利用图注意力网络增强单细胞多组学数据的整合》

原文标题&#xff1a;Enhanced Integration ofSingle-Cell Multi-Omics Data Using Graph Attention Networks 原文链接&#xff1a;https://pubs.acs.org/doi/abs/10.1021/acssynbio.4c00864 跨不同组学层的数据集成面临的挑战&#xff1a;高维度、异质性和稀疏性。 变分自编码…...

HumanDil-Ox-LDL:保存:2-8℃保存,避免强光直射,不可冻存

化学试剂的基本介绍&#xff1a; /// 英文名称&#xff1a;HumanDil-Oxidized LowDensityLipoprotein /// 中文名称&#xff1a;人源红色荧光标记氧化型低密度脂蛋白 /// 浓度&#xff1a;1.0-4.0 mg/ml /// 外观&#xff1a;乳状液体 /// 缓冲液组分&#xff1a;PBS&…...

基于3d相机的点云物体检测与路径规划

&#x1f9e9; 代码结构和解释&#xff1a; 点云预处理 (preprocess_point_cloud)&#xff1a; 使用 Voxel 下采样 来减少点云数据量&#xff0c;去除不必要的噪声。 使用 统计滤波器 去除离群点&#xff0c;以提高后续拟合的精度。 V型焊缝路径拟合 (fit_weld_path_v)&…...

日语学习-日语知识点小记-构建基础-JLPT-N4阶段(2):んです

日语学习-日语知识点小记-构建基础-JLPT-N4阶段(2):んです 1、前言(1)情况说明(2)工程师的信仰2、知识点(1)~んです & ~の(2)意味(いみ)&形(かたち)&使い方(つかいかた)(3)そうなんですか & そうなんだ。(4)何をしているんですか & 何を…...

yolov8在windows系统的C++版本的onnxruntime部署方法

1.各个软件的的环境需要保持在统一的版本。 onnxruntime需要和cuda的版本对应上,版本号:onnxruntime-win-x64-gpu-1.18.1 ,链接: NVIDIA - CUDA | onnxruntime cuda:本机显卡支持的版本,cuda11.7,链接:CUDA Toolkit Archive | NVIDIA Developer cudnn:需要对应到cud…...

AD软件的系统设置

设置 1.自动保存&#xff08;DATA -> backup&#xff09; 2.原理图-复制元器件递增位号 3.原理图-用斜线表示负信号 4.PCB-选择移动重叠的元器件 5.PCB-十字光标全屏大小 6.PCB-选择部分连接网络的走线全亮/显示多个网络的颜色&#xff08;TP&#xff09; 7.PCB-DRC报错的图…...

算法---子序列[动态规划解决](最长递增子序列)

最长递增子序列 说白了&#xff0c;要用到双层循环&#xff01; 用双层循环中的dp[i] class Solution { public:int lengthOfLIS(vector<int>& nums) {vector<int> dp(nums.size(),1);for(int i 0;i<nums.size();i){for(int j0;j<i;j){if(nums[i]>num…...

快速幂(模板)

快速幂 取余运算性质&#xff1a;(a*b*c)%d (a%d * b%d * c%d)%d ; #include <iostream> using namespace std; int main() {long long b,p,k;//b(底数)p(指数)k(取模数)cin>>b>>p>>k;long long ret1;b%k;//防止底数过大//模版&#xff0c;记&#xf…...

蓝桥杯 好数【暴力、基础知识】

题目&#xff1a; AC代码&#xff1a; #include<bits/stdc.h> using namespace std; int ans0; int n; bool check(int x){int cnt1;while(x!0){int tx%10;if(cnt%21){ if(t%20) return false; //奇数位置是偶数} if(cnt%20){if(t%21) return false; //偶数位是奇数}cnt…...

【Kubernetes】Kubernetes中如何实现灰度发布

Kubernetes中实现灰度发布 一、基于Ingress-nginx的流量切分&#xff08;适用中小规模&#xff09; 权重分流 在Ingress资源中通过nginx.ingress.kubernetes.io/canary-weight注解设置新版本流量比例apiVersion: networking.k8s.io/v1 kind: Ingress metadata:annotations:ng…...

【Reinforcement Learning For Quadruped Control】1

强化学习&#xff08;RL&#xff09;是一种机器学习范式&#xff0c;代理通过与环境的互动来学习做出决策。强化学习的核心概念围绕以下几个方面展开&#xff1a;a) 代理agent&#xff0c;做出决策&#xff1b;b) 环境environment&#xff0c;响应代理的决策&#xff1b;c) 状态…...

工程企业如何实现四算联动?预算-核算-决算系统解析

在工程行业&#xff0c;项目管理的高效性直接决定了企业的盈利能力和市场竞争力。尤其是在EPC&#xff08;工程总承包&#xff09;模式下&#xff0c;工程企业面临着复杂的业务场景和多维度的成本管控需求。如何通过“四算联动”&#xff08;概算、预算、核算、决算&#xff09…...

【SpringBoot】处理actuator风险漏洞

最近给系统做渗透测试&#xff0c;扫描出了一个actuator风险漏洞&#xff0c;属于高危级别&#xff0c;通过actuator接口可以拿到用户敏感信息。这个问题处理起来倒也简单&#xff0c;禁用actuator或者限制访问就可以了 # 禁用actuator接口配置 management:server:port: -1# 限…...

MACOS15版本安装 python mysqlclient 以连接mysql 8.0

MACOS14/15 版本安装 python mysqlclient 以连接mysql 8.0 主要用于macos django4 mysql8.0 开发项目 准备材料 macos > 13.0 python > 3.10.0 &#xff08;不强制&#xff09; mysql > 8.0 安装步骤 安装 brew 使用国内源安装brew /bin/zsh -c "$(curl -f…...

KV Cache大模型推理加速功能

KV Cache KV Cache是大模型标配的推理加速功能&#xff0c;也是推理过程中&#xff0c;显存资源巨大开销的元凶之一。在模型推理时&#xff0c;KV Cache在显存占用量可达30%以上。 目前大部分针对KV Cache的优化工作&#xff0c;主要集中在工程上。比如著名的VLLM&#xff0c…...

Windows下安装WSL2下的Ubuntu、docker容器的IP地址(上)

既然容器支持多个应用&#xff0c;那么容易想到应该有对应的ip地址和端口&#xff0c;这样才能和Ubuntu主机进行通讯&#xff0c;ubuntu访问外网也应该有ip能连接到外网才行&#xff0c;要搞清楚这些ip地址的关系才行。 前面两篇文章中说了怎么实现windows和wsl2下的ubuntu的文…...

vue实现中英文切换

第一步&#xff1a;安装插件vue-i18n&#xff0c;npm install vue-i18n 第二步&#xff1a;在src下新建locales文件夹&#xff0c;并在locales下新建index.js、EN.js、CN.js文件 第三步&#xff1a;在EN.js和CN.js文件下配置你想要的字段&#xff0c;例如&#xff1a; //CN.js…...

探索 Vue 3 中 vue-router 的 router.resolve () API

一、router.resolve() 是什么 router.resolve() 就好比是一个精准的 “导航参谋”。当我们在 Vue 3 应用里需要明确某个路由地址对应的详细信息时&#xff0c;它就能派上用场。我们给它传入路由信息&#xff0c;像路径、参数等&#xff0c;它会解析出对应的路由对象&#xff0…...

Excel 插件推荐:提升Excel能力的效率神器!

一、Excel玩家的觉醒时刻 在财务部的深夜加班现场&#xff0c;李师傅的咖啡杯上凝结着第3圈水渍。眼前的Excel窗口堆叠如俄罗斯方块&#xff1a;重复值删除进度15%、VLOOKUP公式报错3处、合并单元格序号乱成毛线团…这场景是否也戳中了你的痛点&#xff1f; 每个Excel高手都经…...

leetcode_383. 赎金信_java

383. 赎金信https://leetcode.cn/problems/ransom-note/ 1、题目 给你两个字符串&#xff1a;ransomNote 和 magazine &#xff0c;判断 ransomNote 能不能由 magazine 里面的字符构成。 如果可以&#xff0c;返回 true &#xff1b;否则返回 false 。 magazine 中的每个字…...

应用安全系列之四十五:日志伪造(Log_Forging)之三

1、简介 针对Java的日志系统有多种&#xff0c;本文主要描述如何通过修改配置文件来解决logback和log4j的日志伪造问题。 2、logback 2.1、系统提供的解决方案 在logback.xml中配置编码器自动转义特殊字符&#xff1a; 复制 <configuration><appender name"C…...

FTPClient开发遇到的坑

1. 生成文件夹乱序 这里用分隔符把路径划分开&#xff0c;意在一层一层创建目录 这里可能会出现乱序 正确的代码 先换一下分隔符 再一次生成所有路径 2.ftpClient 需要指定被动模式才能绕开端口限制 有些 服务器没有打开指定端口&#xff0c;上传文件会出现 425 Canno…...

leetcode0155. 最小栈-medium

1 题目&#xff1a;最小栈 官方标定难度&#xff1a;中 设计一个支持 push &#xff0c;pop &#xff0c;top 操作&#xff0c;并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。 void push(int val) 将元素val推入堆栈。 void pop() 删…...

操作系统 3.6-内存换出

换出算法总览 页面置换算法 FIFO&#xff08;先进先出&#xff09;&#xff1a; 最简单的页面置换算法&#xff0c;淘汰最早进入内存的页面。 优点&#xff1a;实现简单。 缺点&#xff1a;可能会导致Belady异常&#xff0c;即增加内存反而降低性能。如果刚换入的页面马上又要…...

Python中的数值运算函数及math库详解

文章目录 Python中的数值运算函数及math库详解一、内置数值运算函数1. 基本数值运算函数2. 类型转换函数3. 进制转换函数 二、math库中的数学常数三、math库常用数学函数1. 数论与表示函数2. 幂函数与对数函数3. 三角函数4. 角度转换5. 双曲函数6. 特殊函数 四、实际应用示例1.…...

安卓开发提示Android Gradle plugin错误

The project is using an incompatible version (AGP 8.9.1) of the Android Gradle plugin. Latest supported version is AGP 8.8.0-alpha05 See Android Studio & AGP compatibility options. 改模块级 build.gradle&#xff08;如果有独立配置&#xff09;&#xff1a;…...

《Uniapp-Vue 3-TS 实战开发》一键授权登录

在使用 UniApp 结合 Vue 3 和 TypeScript 开发时,实现一键授权登录功能通常涉及到调用微信小程序的授权接口(如 wx.getUserProfile 或 wx.login)来获取用户信息和登录凭证,然后将这些信息发送到后端进行验证和处理。以下是一个完整的实现示例,展示如何在 UniApp 中实现一键…...

Windows 图形显示驱动开发-WDDM 1.2功能_WDDM 1.2 和 Windows 8

简介 WDDM 是随 Windows Vista 一起引入的&#xff0c;以取代 Windows XP 或 Windows 2000 显示驱动程序模型 (XDDM) 。 随着 Windows Vista 中的引入&#xff0c;WDDM 体系结构提供了启用新功能的功能&#xff0c;例如桌面组合、增强的容错、视频内存管理器、GPU 计划程序、D…...

155.最小栈

1.题目解析 题目是让我们设计一个栈&#xff0c;它于STL库中栈的区别是支持检索到了最小元素的栈但是需要时间复杂度为常数&#xff0c;我们很容易想到的是记录最小值。但是如果中途删除的话最小值可能失效&#xff0c;所以我们选择用2个栈来实现。 2.算法原理 我们创建2个栈…...

[C语言笔记]10、字符串

前言&#xff1a; C语言的相关知识点的笔记均在下面的专栏链接中&#xff0c;欢迎订阅&#xff01; c语言笔记_1zero10的博客-CSDN博客 10-1字符数组与字符串 1、字符数组就是一个数组&#xff0c;数组的每一个元素都是一个字符 首先利用字符数组&#xff0c;回顾以前学过…...

Windows系统备份和还原点

一、简介 系统的还原点存储了当前系统的主要状态&#xff0c;包括一些关键的配置信息和参数&#xff08;包括注册表、系统服务设置、设备驱动程序设置等&#xff09;。将此时的状态进行备份&#xff0c;在系统发生故障时&#xff0c;可以还原到此还原点的状态中&#xff0c;这…...

内联汇编知识点earlyclobber=

arm64内联汇编格式&#xff1a; asm volatile ("汇编指令1\n\t""汇编指令2\n\t""汇编指令3": 输出操作数列表: 输入操作数列表: 可能被修改的寄存器列表 );示例1&#xff1a;简单的寄存器操作 uint64_t add_numbers(uint64_t a, uint64_t b) {…...

修改ESP32CAM的示例CameraWebServer里的camera_index.h的方法

在这里&#xff0c;默认你已经会使用Arduino IDE或者PlatformIO通过烧录底座对ESP32CAM&#xff08;如下图&#xff09;进行烧录&#xff0c;并能通过浏览器对其进行访问。 我们访问到下图的界面时&#xff0c;不禁有个疑问&#xff0c;这个界面是如何生成的&#xff0c;如果我…...

Python学习笔记(二)(字符串)

文章目录 编写简单的程序一、标识符 (Identifiers)及关键字命名规则&#xff1a;命名惯例&#xff1a;关键字 二、变量与赋值 (Variables & Assignment)变量定义&#xff1a;多重赋值&#xff1a;变量交换&#xff1a;&#xff08;很方便哟&#xff09; 三、输入与输出 (In…...