文件句柄备忘

本文涉及的产品
运维安全中心(堡垒机),免费版 6个月
运维安全中心(堡垒机),企业双擎版 50资产 7天
简介: 句柄是什么? Handle本身是一个32位的无符号整数,它用来代表一个内核对象。它并不指向实际的内核对象。 句柄不是指针,但利用句柄能够得到一段内存地址, 句柄的设计目标是防止用户随意修改内核中文件,因此用户模式下的程序永远不可能获得一个内核对象的实际地址(一般情况下)。 那么Handle的意义何在? 它实际上是作为一个索引在一个表中查找对应的内核对象的实际地址。 那么这个表在

句柄是什么?

Handle本身是一个32位的无符号整数,它用来代表一个内核对象。它并不指向实际的内核对象。
句柄不是指针,但利用句柄能够得到一段内存地址,
句柄的设计目标是防止用户随意修改内核中文件,因此用户模式下的程序永远不可能获得一个内核对象的实际地址(一般情况下)。

那么Handle的意义何在?
它实际上是作为一个索引在一个表中查找对应的内核对象的实际地址。

那么这个表在哪里呢?
每个进程都有这样的一个表,叫句柄表。
该表的第一项就是进程自己的句柄,这也是为什么你调用GetCurrentProcess()总是返回0x7FFFFFFF原因。

简单地说,Handle就是一种用来"间接"代表一个内核对象的整数值。你可以在程序中使用handle来代表你想要操作的内核对象。这里的内核对象包括:事件(Event)、线程、进程、Mutex等等。我们最常见的就是文件句柄(file handle)。

 

linux 中通常默认都只能够同时打开 1024 个文件。

通常 linux 系统中文件打开的设定分成系统级别设定及用户级别设定
常见的文件限制令系统产生下面错误
 Socket/File: Can‘t open so many files

系统级别定义方法
 /etc/sysctl.conf 或 /proc/sys/fs/file-max

用户级别定义方法
 /etc/security/limits.conf 或 ulimit 命令

 


查询进程打开文件的方法, 以当前 ssh 链接到服务器的终端作为例子, 先查询到进程号

ps aux | grep pts/0 | grep ssh | grep -v grep | awk '{print $2}'
1859

利用 lsof 查询当前进程打开的文件数量 
lsof -p 1859  | wc -l (直接查询当前进程)
59

lsof -n | grep 1859 | wc -l  (查询整个系统中打开的文件再执行过滤)
58


查询某个文件被什么进程使用中的方法

lsof -f -- /lib/security/pam_keyinit.so
COMMAND  PID USER  FD   TYPE DEVICE SIZE/OFF   NODE NAME
login   1019 root mem    REG    8,1     5740 133255 /lib/security/pam_keyinit.so
sshd    1859 root mem    REG    8,1     5740 133255 /lib/security/pam_keyinit.so
sshd    4468 root mem    REG    8,1     5740 133255 /lib/security/pam_keyinit.so


查询分区打开文件方法
[root@station11 proc]# lsof +f -- /dev/sda1 | head -5
COMMAND    PID      USER   FD   TYPE DEVICE SIZE/OFF   NODE NAME
init         1      root  cwd    DIR    8,1     4096      2 /
init         1      root  rtd    DIR    8,1     4096      2 /
init         1      root  txt    REG    8,1   145180 139646 /sbin/init
init         1      root  mem    REG    8,1   122232 162307 /lib/libgcc_s-4.4.5-20110214.so.1

目录
相关文章
|
JSON 前端开发 Java
利用Spring Boot处理JSON数据实战(包括jQuery,html,ajax)附源码 超详细
利用Spring Boot处理JSON数据实战(包括jQuery,html,ajax)附源码 超详细
471 0
|
2月前
|
API 语音技术 开发者
Python 项目打包,并上传到 PyPI,分享项目
本文介绍了如何使用 Poetry 打包并发布一个 Python 项目至 PyPI。内容包括:项目创建、配置 `pyproject.toml` 文件、构建软件包、上传至 PyPI、安装与使用。通过实例 iGTTS 展示了从开发到发布的完整流程,帮助开发者快速分享自己的 Python 工具。
|
机器学习/深度学习 算法 安全
隐私计算训练营第三讲-详解隐私计算的架构和技术要点
SecretFlow 是一个隐私保护的统一框架,用于数据分析和机器学习,支持MPC、HE、TEE等隐私计算技术。它提供设备抽象、计算图表示和基于图的ML/DL能力,适应数据水平、垂直和混合分割场景。产品层包括SecretPad(快速体验核心能力)和SecretNote(开发工具)。算法层涉及PSI、PIR、数据分析和联邦学习(水平、垂直、混合)。此外,SecretFlow还有YACL密码库和Kusica任务调度框架,Kusica提供轻量化部署、跨域通信和统一API接口。
606 0
|
9月前
|
数据采集 数据挖掘 物联网
Pandas高级数据处理:实时数据处理
本文介绍了如何使用Pandas进行实时数据处理,涵盖从基础到高级的技巧。Pandas作为Python中流行的数据处理库,提供了高效的DataFrame和Series结构,适用于金融、社交媒体和物联网等领域的数据分析。文章详细讲解了数据读取、清洗、转换及常见问题的解决方案,如内存不足、数据不一致和性能瓶颈,并提供了避免常见报错的方法,帮助读者更高效地处理实时数据。
301 15
|
8月前
|
人工智能 自然语言处理 运维
又稳又快!阿里云飞天企业版支撑多家政企云上部署DeepSeek和通义千问
又稳又快!阿里云飞天企业版支撑多家政企云上部署DeepSeek和通义千问
|
API 数据处理 Python
探秘Python并发新世界:asyncio库,让你的代码并发更优雅!
在Python编程中,随着网络应用和数据处理需求的增长,并发编程变得愈发重要。asyncio库作为Python 3.4及以上版本的标准库,以其简洁的API和强大的异步编程能力,成为提升性能和优化资源利用的关键工具。本文介绍了asyncio的基本概念、异步函数的定义与使用、并发控制和资源管理等核心功能,通过具体示例展示了如何高效地编写并发代码。
340 2
|
机器学习/深度学习 人工智能 PyTorch
【Deepin 20深度探索】一键解锁Linux深度学习潜能:从零开始安装Pytorch,驾驭AI未来从Deepin出发!
【8月更文挑战第2天】随着人工智能的迅猛发展,深度学习框架Pytorch已成为科研与工业界的必备工具。Deepin 20作为优秀的国产Linux发行版,凭借其流畅的用户体验和丰富的软件生态,为深度学习爱好者提供理想开发平台。本文引导您在Deepin 20上安装Pytorch,享受Linux下的深度学习之旅。
324 12
|
机器学习/深度学习 TensorFlow 算法框架/工具
深度学习中的图像分类:从理论到实践
【8月更文挑战第31天】 本文将带你深入了解深度学习在图像分类领域的应用。我们将从理论基础出发,逐步过渡到实际的代码实现,让你能够亲手构建一个简单的图像分类模型。无论你是初学者还是有一定基础的开发者,都能从中获得启发和收获。
|
机器学习/深度学习 人工智能 Java
Java和Python区别
Java和Python区别
618 1
Java和Python区别