首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

lsof 查看进程打开那些文件 或者 查看文件那个进程使用

可以列出被进程所打开的文件的信息。被打开的文件可以是 1.普通的文件,2.目录 3.网络文件系统的文件,4.字符设备文件 5....(函数)共享库 6.管道,命名管道 7.符号链接 8.底层的socket字流,网络socket,unix域名socket 9.在linux里面,大部分的东西都是被当做文件的…..还有其他很多 怎样使用...列出除了某个用户外的被打开的文件信息 lsof -u ^root 备注:^这个符号在用户名之前,将会把是root用户打开的进程不让显示 10....通过某个进程号显示该进行打开的文件 lsof -p 1 11. 列出多个进程号对应的文件信息 lsof -p 123,456,789 12....列出除了某个进程号,其他进程号所打开的文件信息 lsof -p ^1 13 . 列出所有的网络连接 lsof -i 14. 列出所有tcp 网络连接信息 lsof -i tcp 15.

1.5K10
您找到你想要的搜索结果了吗?
是的
没有找到

Linux进程间通信:文件文件

前言 使用文件进行进程间通信应该是最先学会的一种IPC方式。任何编程语言中,文件IO都是很重要的知识,所以使用文件进行进程间通信就成了很自然被学会的一种手段。...假设我们要并发100个进程,这些进程约定好一个文件,这个文件初始值内容写0,每一个进程都要打开这个文件读出当前的数字,加一之后将结果写回去。...本文更加偏重的是Linux环境提供了多少种文件锁以及他们的区别是什么? flock和lockf 从底层的实现来说,Linux文件锁主要有两种:flock和lockf。...从应用的角度来说,Linux内核虽然号称具备了强制锁的能力,但其对强制性锁的实现是不可靠的,建议大家还是不要在Linux下使用强制锁。...鉴于此,我们就不在此介绍如何在Linux环境中打开所谓的强制锁支持了。我们只需知道,在Linux环境下的应用程序,flock和lockf在是锁类型方面没有本质差别,他们都是建议锁,而非强制锁。

7.4K13

linux 用户、文件权限、进程、软件管理

用户管理 口令文件 /etc/passwd 影子口令文件 /etc/shadow 组账号文件 /etc/group 组口令文件 /etc/gshadow ?...//添加 groupmod [-gn] //修改 groupdel //删除 cat /etc/passwd 查询用户列表 文件权限管理...chmod chmod 770 test.txt //如设置000权限,但root用户还是对其有权限 chmod u+r test.txt chmod u=rw test.txt 改文件所属组...必要参数: -c 当发生改变时输出调试信息 -f 不显示错误信息 -R 处理指定目录以及其子目录下的所有文件 -v 运行时显示详细的处理信息 chgrp -R dierzu text.txt //...将文件text.txt 的所属已更改为 dierzu 进程管理 查看进程 ps -elf 实时查看进程:top 杀死进程 kill pid 软件管理 RH(RedHat):yum Debian

2.1K32

linux lsof命令查看文件占用进程

1.lsof简介 lsof(list open files)是一个列出当前系统打开文件的工具。在linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件。...:进程的名称 PID:进程标识符 USER:进程所有者 FD:文件描述符,应用程序通过文件描述符识别该文件。...例如,linux限制了进程能够打开文件的数目。通常这个数值很大,所以不会产生问题,并且在需要时,应用程序可以请求更大的值(直到某个上限)。...二、恢复删除的文件Linux计算机受到入侵时,常见的情况是日志文件被删除,以掩盖攻击者的踪迹。管理错误也可能导致意外删除重要的文件,比如在清理旧日志时,意外地删除了数据库的活动事务日志。...Aug 4 13:50:15 holmes86 kernel: Linux version 2.6.22.1-8 (root@everestbuilder.linux-ren.org) (gcc version

13.5K40

linux命令chmod 777_chmod无法访问 没有那个文件或目录

Linux的常用命令 一、关于文件权限的基本理论知识 二、关于文件权限的命令 (1)查看文件权限 (2)文件权限的基本知识 (3)关于修改权限的命令 一、关于文件权限的基本理论知识 一个Linux...①chgrp(change group的简写)命令可以更改文件的所属组,格式为: chgrp [组名][文件名] 例如:下图我们修改了test目录的所属组权限由workhah所属组改成root所属组了...---- ②chown(change owner的简写)命令可以更改文件的所有者,其格式为:chown [用户名][文件名] 例如:下图我们修改了test目录的所属者权限由workhah所属组改成root...而这些数字是为了方便更改文件的权限,Linux使用数字代替rwx,具体规则为:r 等于4,w 等于2,x 等于1,- 等于0。...在LInux系统中,一个目录的默认权限为755,一个文件的默认权权限为644。 ---- ④umask命令用于更改文件的默认权限,其格式为:umask xxx(这里的xxx代表三个数字)。

8K20

Linux下查看进程打开的文件句柄数

Linux 平台上运行的进程都会从系统资源申请一定数量的句柄,而且系统控制了进程能够申请的最大句柄数量。...用户程序如果不及时释放无用的句柄,将会引起句柄泄露,从而可能造成申请资源失败,导致系统文件句柄用光连接不能建立。本文主要介绍Linux下如何查看和修改进程打开的文件句柄数,避免这类问题的发生。...在 Linux 系统中,进程文件之间是通过“打开文件”操作建立连接,文件系统会返回文件句柄来唯一标识进程文件的连接。每当一个进程执行完毕之后,Linux 系统会将与进程相关的文件句柄自动释放。...与 Windows 系统的设置不同,Linux 系统对进程可以调用的文件句柄数做了限制,在默认情况下,每个进程可以调用的最大句柄数为 1024 个。超过了这个数值,进程则无法获得新的句柄。...因此,句柄的泄露将会对进程的功能失效造成极大的隐患。 如何修改系统最大句柄数 Linux 中,单个进程能够打开的最大文件句柄数量是可以配置的,系统默认是 1024。

53K52

Linux shell 多进程文件队列处理任务

再将过期的日期删除 存在的问题 两个for循环相当于O(n^2)的复杂度 顺序执行这么多的任务没有充分利用其服务器的资源 拉取的文件未压缩,导致网络流量浪费 任务都混杂在一个文件中,不清晰 如果任务的执行时间超过...1天,会对定时任务造成影响 想到的解决方法 将串行任务执行改成并行任务执行 任务分解到不同的文件中,用专门的处理进程处理 先压缩后拉取,然后删除掉应用服务器上的压缩文件 前期准备 由于对shell以前只是停留在偶尔用的程度...,许多知识都需要现查,因此又去学习了一遍,其中包括shell中多进程任务执行,文件监听处理,以及常用的Linux命令 Linux多任务执行 (多任务执行|http://www.cnblogs.com/xudong-bupt.../p/6079849.html) (多进程并发|http://www.cnblogs.com/stevendes1/p/6725898.html) 我第一个看到的是第一个博客,不过他写的多进程程序里有问题...& done 其他 Linux函数调用,scp,gzip,echo等命令看了下他们的man页,做起来更有信心 动手 任务分类 目前有两个任务,一是拉取日志,二是删除过期日志,因此使用两个文件队列来分别表示这两个任务

1.9K30

Linux 进程、线程、文件描述符的底层原理

Linux 中的进程其实就是一个数据结构,顺带可以理解文件描述符、重定向、管道命令的底层工作原理,最后我们从操作系统的角度看看为什么说线程和进程基本没有区别。...你编译好的那个可执行程序只是一个文件,不是进程,可执行文件必须要载入内存,包装成一个进程才能真正跑起来。...因为硬件都是由内核管理的,我们的进程需要通过「系统调用」让内核进程访问硬件资源。 PS:不要忘了,Linux 中一切都被抽象成文件,设备也是文件,可以进行读和写。...管道符其实也是异曲同工,把一个进程的输出流和另一个进程的输入流接起一条「管道」,数据就在其中传递,不得不说这种设计思想真的很巧妙: 到这里,你可能也看出「Linux 中一切皆文件」设计思路的高明了,不管是设备...为什么说 Linux 中线程和进程基本没有区别呢,因为从 Linux 内核的角度来看,并没有把线程和进程区别对待。

1.3K10

Linux 进程、线程、文件描述符的底层原理

Linux 中的进程其实就是一个数据结构,顺带可以理解文件描述符、重定向、管道命令的底层工作原理,最后我们从操作系统的角度看看为什么说线程和进程基本没有区别。...你编译好的那个可执行程序只是一个文件,不是进程,可执行文件必须要载入内存,包装成一个进程才能真正跑起来。...PS:不要忘了,Linux 中一切都被抽象成文件,设备也是文件,可以进行读和写。...到这里,你可能也看出「Linux 中一切皆文件」设计思路的高明了,不管是设备、另一个进程、socket 套接字还是真正的文件,全部都可以读写,统一装进一个简单的files数组,进程通过简单的文件描述符访问相应资源...为什么说 Linux 中线程和进程基本没有区别呢,因为从 Linux 内核的角度来看,并没有把线程和进程区别对待。

2.3K30

Linux系统初始化进程文件(带命令)

前言 本章将会讲解Linux系统初始化进程文件以及使用的命令。...一.系统初始化进程文件 1.init 进程 Linux操作系统中的进程使用数字进行标记,每个进程的身份标记号称为PID,在引导Linux操作 系统的过程中。...init进程正是维持整个Linux操作系统运行的所有进程的“始祖”,因此init进程是不允许被轻易终止的,需要切换不同的系统运行状态时,可以向lnit进程发送正确的执行参数,由init自身来完成相关操作...换言之,CentOS 7系统中 运行的第一个 init 进程是“/lib/systemd/systemd”,systernd 守护进程负责Linux 的系统和服务, systemctl用于控制Systerd...htpd,service的软连接文件

30830

Linux中查看端口被哪个进程占用、进程调用的配置文件、目录等

1.查看被占用的端口的进程,netstat/ss -antulp | grep :端口号 2.通过上面的命令就可以列出,这个端口被哪些应用程序所占用,然后找到对应的进程PID 3.根据PID查询进程...如果想详细查看这个进程,PID具体是哪一个进程,可以通过命令的方式进行查看进程的详细信息,ps -ef | grep 进程PID 或者ps -aux | grep 进程PID 通过执行上面的命令,...就可以看到这个进程的详细信息,同时也可以看到这个进程存在的目录,进程执行的文件、配置文件等信息。...4.查看进程所在目录。...通过ll /proc/进程PID/cwd命令,可以直接查看进程所在的目录,这样的话就可以快速定位到进程的目录 查找他的进程目录之后,就可以对这个应用程序进行一系列的操作,比如说重启删除等!

2.1K20

Linux CC++多进程同时写一个文件(二)

本文是这《Linux C/C++多进程同时写一个文件》系列文章的第二篇,上一篇文章演示了两个非亲缘关系的进程同时写一个文件的情形,并得出了数据只会错乱但不会覆盖的结论。..._1.c程序很简单,主要是fork后的父子进程把对应p_buf指向的静态区数据写入到文件LINUX_MUTIL_PROCESS_WRITE_1中。..._1.c * @Describe Linux C/C++多进程同时写一个文件(二) * @Author vfhky 2017-10-29 21:23 https://typecodes.com...最后通过tail -f LINUX_MUTIL_PROCESS_WRITE命令查看文件写入情况,从下图两个红色标注可以看出父进程写入4096字节(123456789)后在字符3后子进程开始4096字节(...4 结论 从上面小节的测试过程可以发现,和上文中两个非亲缘关系的进程同时写一个文件一样,两个亲缘关系的父子进程同时写一个文件时会出现数据混乱的情况,但是两个进程写入的数据没有覆盖。

15010

Linux CC++多进程同时写一个文件(三)

本文是这《Linux C/C++多进程同时写一个文件》系列文章的第三篇,上一篇文章演示了两个亲缘关系的进程(父子进程)同时写一个文件的情形,并得出了数据只会错乱但不会覆盖的结论。...这篇文章主要是在第一篇文章的基础上,加上上篇文章的分析,更深下一步地探索两个非亲缘关系的进程同时写一个文件的问题。...为了测试多进程同时写文件的情景,需要复制linux_process_fork1_7.c程序为linux_process_fork1_8.c,同时把p_buf指向改成abcdefghi,然后分别编译成两个不同的可执行文件..._7.c * @Describe Linux C/C++多进程同时写一个文件(三) * @Author vfhky 2017-10-29 22:23 https://typecodes.com...4 结论 从测试结果可以得出:两个非亲缘关系的进程同时写一个文件时,如果没有设置append同步文件偏移量,那么两个进程写入的数据会出现覆盖的情况。

17010

Linux CC++多进程同时写一个文件(一)

近期会写关于《Linux C/C++多进程同时写一个文件》的系列文章,主要是探索在Linux下非亲缘关系的多进程和具有亲缘关系的多进程同时写一个文件的问题。...为了测试多进程同时写文件的情景,需要复制linux_process_fork1_5.c程序为linux_process_fork1_6.c,同时把p_buf指向改成abcdefghi,然后分别编译成两个不同的可执行文件...最后通过tail -f LINUX_MUTIL_PROCESS_WRITE命令查看文件写入情况,从下图两个红色标注可以看出linux_process_fork1_5进程写入的123456789在字符4后插入了...这是因为这两个进程表项中指向的对应的两个文件表项对应的当前文件偏移量是不一致的,但是由于打开文件时是使用append追加的方式,使得进程指向的文件表项中的当前文件偏移量都等于当前文件中所有数据的总长度。...注意:内核write函数在写入时是原子操作,所以两个进程会有一个竞争关系,最终只会由某个进程写入数据。 5 附录 关于Linux C/C++多个亲缘关系的进程同时写同一个文件的分析请参考下一篇文章。

16710
领券