探索linux文件系统结构的漫漫长路

2023-10-18 17:59

本文主要是介绍探索linux文件系统结构的漫漫长路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

linux系统的文件系统结构


  • linux系统的文件结构大,且复杂。其内核源码到2.0版本之后就已经非常庞大,远远不可能完全彻底了解。而且这个系统提供的目录检索方式是cd …这样的command的方式,因此要了解且对比了解非常的困难。
    这样的话,有至少三种方式来通过command方式来学习。
    • 可以通过开多个终端模拟器来对比,因为是同一个应用,因此ubuntu可以用快捷键Ctrl+`来进行应用内部切换。
    • 可以通过开多个terminal的方式,进行无图形化界面的查看。如果装有图形化界面,默认可以用Ctrl+Alt+F1来切换,同理,可以试试Ctrl+Alt+F2,F3,F4…。这样在不同的终端来进行对比查看。
    • 可以通过主机-服务器通讯的方式来在其他操作系统上查看。最常见的比如开启ssh,在装有Xshell等软件的windows电脑上访问,来达到查看文件的目的。
linux的分区,格式化,分区设备文件名,挂载
硬盘需要分区。

硬盘是用来存放数据的,os作为其中最重要的数据之一,也需要硬盘来存放。
linux习惯的分区中,必须分别为 /swap 分区单独分配一个分区。swap是linus自己引入linux最早期内核中的,因此linux系统必须有这个分区。这个分区在今天内存越来越大的时候也仍然有用。
它的思想是把硬盘的一部分空间当做内存。比如播放一个视频。视频的数据肯定要调入内存。如果我们电影看到一半,我们就可以把内存中我们看的前一半先放到硬盘–虚拟内存,这样就大大节省了内存的空间。

分区搭配有:

<= 4个主分区 | 1个扩展分区 + 3个主分区
分区号:1,2,3,4给主分区和扩展分区使用。
5,…给逻辑分区使用。
主分区,扩展分区中的逻辑分区可以正确格式化。
linux系统中每个分区最小存储单元为4KB。
装不满4KB,多余的空间不再利用。

分区设备文件名。

我们把每个分区格式化为一个个inode节点。
分区设备文件名,hda–ide硬盘接口的第1块硬盘,hdd–ide硬盘接口的第2块硬盘。IDE硬盘接口已基本被淘汰,它的速率是133MB/s。
sd是SCSI/SATA/USB。SATA分为SATA1,2,3。

挂载。

/boot挂载到一块儿单独分区。500MB足够。用来保存启动信息而不进行写入。
/
swap


以上为必须挂载的分区。/boot是建议挂载,理由见它后面。


探索篇

我无意中发现了linux下一个好用的命令whereis。whereis gnome便可以找到 gnome 的所有路径。

探索原理

linux kernal是众多人协同开发的,而参与大型项目的都会有一个主要的设计思路。因此我们得出结论,linux基本目录有规可循。
Linux发行版是由社区,公司维护的,皆在使linux系统物业有专攻。


服务器版追求稳定,软件不是最新的,但一定是可以用的。
带有桌面版是给追求用linux作为日常娱乐工作的电脑的用户使用的。
最小化安装版是给那些熟悉linux内核,可以自定义系统的人使用的。


因此我就想到,gnome其实就是在最小安装版linux的基础上加了至少一项那就是gnome软件。
简单来说,如果Windows愿意给linux做图形化界面,我们将来也可以用上linux内核,Windows桌面的操作系统。


Linux文件本没有贵贱,可是人们想区分,就加上了后缀名


在linux下有一个vim的命令,如果没有装请安装它。
vim可以查看所有文件。在windows上最痛苦的莫过于想查看文件却被锁死在后缀名上。
vim可以查看一切文件。无论是二进制的文件,还是编好码的文件。
因此就给linux起一个后缀名的池。

linux后缀名池

.sh --shell脚本文件,是可以执行的一系列shell命令的集合。

linux内存管理

标准的段页式结构,一个文件夹占4K,我可以理解为创建了一个C的结构叫dir,dir是中有一个指针,然后它的大小为4K。

for i in range(1024):print("第"+str(i)+"次打印")#写一个字符到文件中with open('1.txt','ab') as f:f.write(bytes('a'.encode('utf-8')))

这段代码的意思是写一个字符–一个ascil码字符是1B,也就是8bit。可以看到写后创建了一个1.txt,大小是1024,那么就说明linux系统每个单元是1B。


linux的进程管理

ps -e 列出所有进程
kill 进程号 终止进程


linux的shell编程

1.shell脚本如何运行
  1. chmod 755 XXX.sh
  2. bash XXX.sh

linux基本命令的其他用法

  1. cat -A XXX
    列出文件的所有内容,包括隐藏字符。
    linux中回车识别为$
    Windows中回车识别为^M$
    为了把文件从windows迁移到Linux,需要执行命令dos2unix XXX。
  2. history
    history用来显示保存在硬盘中的历史命令。
    history -c表示清除内存中也就是还没有保存的历史命令。
    history -w表示写入到~/.bash_history这个文件中。即写入到硬盘中。
    关于是否清空的问题。如果我们都不清空,那么方便管理员来查看问题。如果我们都清空,那么黑客攻击我们也习惯性的清空,我们会得不到任何东西。如果我们不清空但黑客清空,我们会知道黑客攻击了我们的服务器。所有给的建议是不要清空历史命令。
    默认记录的历史命令上限为1000.可以在/etc/profile找到histsize修改。
命令执行的顺序
  1. 用 相对路径 或 绝对路径 的命令第一优先。
  2. 用alias的命令第二优先。
    1. 如何定义别名
      vim /root.bashrc
      系统定义了一些默认的别名,使其永久生效
      在这里插入图片描述
    2. 如何删除别名
      unalias + 别名 可以删除别名。

bash的快捷键

Ctrl C :强制终止
Ctrl L :清屏幕
Ctrl U:清除光标之前命令 和 剪切
Ctrl K:清除光标之后命令 和 剪切
Ctrl Y:剪切
Ctrl R:查找命令在历史命令中
Ctrl D:终止当前终端
Ctrl A:快速定位到命令开头

标准输入输出设备

早期的计算机没有多少外设,因此
标准的输出设备:显示器
标准的输入设备:键盘
0 标准输入
1 标准输出
2 标准错误输出 – 2果然是最不讨喜的数字

设备文件描述符设备文件名
标准的输入设备0/dev/stdin
标准的输出设备1/dev/stdout
标准错误输出2/dev/stderr
标准输出重定向
标准输出输出重定向符号输出方向
命令->shell命令->file命令>>file(追加)&&命令>file(覆盖)changed
标准错误输出重定向
标准错误输出标准错误输出重定向符号输出方向
错误命令->shell错误命令->file错误命令 2>>file(追加)&&错误命令 2>file(覆盖)changed

命令 > 文件 2>&1 把正确或错误都保存到文件中
命令 >> 文件 2>&1 把正确或错误都追加到文件中

命令 &> 文件 把正确或错误都保存到文件中
命令 &>> 文件 把正确或错误都追加到文件中
命令>>文件1 2>>文件2 把正确追加到文件1中,把错误追加到文件2中。

这篇关于探索linux文件系统结构的漫漫长路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/234263

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级