IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:UNIX

共 30 篇相关文章

IT 累计浏览 3,415

Linux上的Shebang符号(#!)

这篇讲的是Linux和Unix系统里那个常见的符号“#!”。作者从它的名字“Shebang”说起,解释了这个名称其实来源于“SHArp”(#)和“bang”(!)的组合,还提到了Unix之父丹尼斯·里奇本人对命名的回忆,为这个技术细节增添了历史趣味。 文章的重点在于阐述这个符号的实际用途:它是脚本第一行的解释器指令,告诉系统该用哪个程序来执行这个文件。作者清晰地列出了几种常见情况:比如没有#!行时默认使用当前Shell;如果指定的解释器路径不存在或没有执行权限,系统会报出具体的错误信息;值得注意的是,#!后面必须写绝对路径,它不会去$PATH里自动查找。这些细节对于脚本编写和调试很有帮助。 最后,文章通过一个简单的“hello world”脚本示例,演示了从编写#!行、赋予执行权限到直接运行的完整过程,让抽象的概念变得具体可操作。对于刚接触Shell脚本或偶尔使用但想弄明白原理的开发者来说,这是一篇不错的速查小指南。

IT 累计浏览 14,829

调试工具之GDB

这是一篇关于调试利器GDB的实用指南。不同于常见的C/C++调试教程,这篇文章特别展示了如何用GDB调试PHP脚本,视角相当独特。 文章从GDB的安装讲起,涵盖了yum、rpm包以及从源码编译这几种常见方式。核心部分围绕一个具体的PHP示例展开,详细演示了启动GDB、设置参数、执行脚本的完整流程。其中亮点是两种高级断点设置方法:可以通过“文件名:行号”精确定位,比如“basic_functions.c:4439”,直接跳到PHP内置函数`sleep`在内核C代码中的实现点;也可以仅用函数名“zif_sleep”来设置断点,这在没有源码行号时尤为方便。文章还介绍了通过`help`命令自助查询GDB的庞大指令集。 作者通过这个实例,清晰地展现了GDB强大的通用调试能力。它不仅是C程序的调试器,更是一个能深入任何用C语言编写(或内嵌C)的运行时环境的强大工具。对于需要调试PHP内核、扩展或性能问题的开发者来说,这篇文章提供了一个极具价值的实践起点。

IT 累计浏览 2,565

vfork 挂掉的一个问题

这篇讲的是 vfork 系统调用中一个经典的“坑”:为什么在子进程中使用 `return` 会导致程序崩溃,而用 `exit()` 却不会?作者从知乎上的一个实际提问出发,澄清了一些可能误导人的回答。 文章首先梳理了 fork 与 vfork 的根本区别——fork 会复制父进程内存,而 vfork 则让父子进程共享同一内存空间。vfork 的设计初衷是为了在创建子进程后立即执行 exec 时提高效率。关键点在于,vfork 保证子进程先运行,直到它调用 `exit()` 或 `exec()` 后,父进程才继续。 崩溃的根源正在于此:因为父子进程共享栈空间,如果在子进程的 main 函数中使用 `return`,它会像正常函数返回一样修改栈(弹栈、释放局部变量),这相当于破坏了父进程正在使用的栈。当父进程稍后恢复执行时,栈已被改写,导致不可预知的行为或直接崩溃。而 `exit()` 是直接终止进程,不会去操作和释放共享的函数栈,因此父进程能安全恢复。 文章最后也指出,现代操作系统已通过“写时拷贝”技术大幅优化了 fork,使得 vfork 的性能优势不再明显,Linux 手册也不鼓励使用它,除非对性能有极致要求。理解这个底层机制,有助于我们避免这类隐蔽的陷阱。

IT 累计浏览 3,443

贝尔实验室的历史

这篇讲的是那个诞生了Unix、C语言和晶体管的传奇实验室——贝尔实验室的完整身世。 作者从自己学习Go语言时产生的困惑出发:电话发明者贝尔和实验室到底是什么关系?实验室在AT&T、朗讯、阿朗等不同名字间辗转,其本质是什么?文章沿着电话发明者亚历山大·贝尔1876年创立贝尔电话公司这条线索,一路梳理了其后继者AT&T公司的发展,并重点追踪了隶属于AT&T的贝尔实验室如何成为“科技圣地”,最终在产业变革中被拆分重组的历史脉络。 它理清了从贝尔个人发明到庞大研发机构,再到被并购拆分的完整演变路径。对于想弄明白“贝尔实验室”这个闪耀又复杂的名字背后究竟是一段怎样的公司史与科技史的读者,这篇梳理提供了一个清晰的时间线与故事框架。

IT 累计浏览 4,362

推荐几本 Unix/Linux 经典书

这是一份从入门到内核的 Unix/Linux 经典书单。作者结合自身阅读经验,为不同阶段的学习者梳理了那些历经时间考验的“案头必备”。他认为,在信息爆炸的今天,与其浪费时间在平庸的书籍上,不如直接啃透经典。 对于初学者,文章推荐了《Running Linux》和《Linux in a Nutshell》作为起步。而系统管理方面,两部“大部头”——《UNIX and Linux System Administration Handbook》与《Essential System Administration》被形容为该领域的百科全书。网络原理则首推《TCP/IP Illustrated, Volume 1》,无论职位是运维还是开发,理解底层协议都至关重要。 进入编程领域,从 Kernighan 与 Pike 合著、体现 Unix 哲学的《The UNIX Programming Environment》,到 Richard Stevens 的《APUE》和《Unix Network Programming》这两部巨著,构成了进阶路径。最后,针对渴望深入内核的读者,《Operating Systems: Design and Implementation》与《Understanding the Linux Kernel》是绕不开的经典,尽管后者被坦言“学习过程痛苦”,但能帮助构建完整的内核图景。 作者的核心观点是:阅读这些英文经典,不仅能更高效地掌握技术,更是为职业生涯打下坚实基础。这些书是真正能放在手边反复翻阅的伙伴。

IT 累计浏览 6,901

Linux知识:为什么要用字符~来表示home目录

这篇讲的是Linux和Unix系统里一个常见却很少有人深究的细节:为什么用波浪号“~”来表示用户的home目录。答案其实藏在一段计算机硬件的历史里——这个用法直接沿袭自1970年代流行的Lear-Siegler ADM-3A终端机。 文章指出,在这种老式终端上,波浪号“~”键与“Home”键(将光标移至行首)被设计在同一个物理按键上。当Unix系统的开发者需要为home目录找一个便捷的符号表示时,这个现成的、含义紧密相关的按键自然就成了首选。因此,今天我们敲下的“cd ~”,其根源竟是一次跨越数十年的硬件设计传承。文章还配上了该终端机及其键盘布局的实物照片,让这段冷知识变得直观可感。了解这个小小的起源,能让我们对命令行中看似“理所当然”的设计多一分会心一笑的理解。

IT 累计浏览 4,584

Unix考古记:一个“遗失”的shell

这篇讲的是Unix历史上第一个被广泛传播的shell——Thompson Shell,它由Ken Thompson编写,却常常被后来的Bourne Shell的光芒所掩盖。作者从Unix V6时代的尘封文档和源代码出发,带我们重新认识了这个只有900行C代码、却奠定了现代shell基因的“鼻祖”。 文章的价值在于,它清晰地展示了Thompson Shell如何将管道线、I/O重定向、通配符扩展和后台执行这些影响深远的概念工程化实现。尽管它在1977年就被Bourne Shell取代,但它所确立的命令语言结构和解释器可移植性原则,直接塑造了我们今天习以为常的命令行交互方式。 更妙的是,文章深入其解释器源码,剖析了预处理、词法扫描等步骤。你会发现,这个简陋的解释器原理竟与编译器一脉相承,对于想理解Shell或编译原理的读者来说,这份“活化石”级别的代码解析提供了难得的直观视角。

IT 累计浏览 4,489

编程珠玑番外篇之番外篇-N 答 UNIX 痛恨者王垠

这篇讨论 UNIX 与 Windows 设计哲学之争的文章,从王垠批评 UNIX 的观点出发,深入剖析了两者的核心差异。作者指出,UNIX 的图形系统(如 X Window)与操作系统内核的松耦合,反而为针对不同设备(如移动平台)定制高效 GUI 提供了灵活性,而微软 NT 内核与 UI 的深度绑定,则导致其在跨平台时面临复杂的兼顾问题,迭代缓慢。 文章进一步探讨了工具设计的复杂性根源。以 TeX 为例,作者认为其“复杂”源于要解决排版领域本身的精确控制问题,而非设计失败。这揭示了一个重要观点:工具设计的简单或复杂,应取决于其要封装的“领域模型”的固有难度,而非简单地追求操作极简。将 Unix 工具比作“魔鬼棋”的类比,可能忽略了这一层因果关系。 最后,作者提出了一个有趣的角度:真正的 Unix 用户恰恰是其“痛恨者”,因为深刻理解其缺陷是高效使用它的前提。这种基于开放环境竞争、不断吸收优秀设计的演进模式,而非某种“宗教”,才是 Unix 家族最终胜出的关键。

IT 累计浏览 3,898

Linux/Unix的精巧约定两例及其简析:目录权限和文本行数

这篇技术文章深入浅出地拆解了Linux/Unix系统中两个看似复杂但设计精巧的约定,首先是关于目录权限的“执行”位。 作者指出,许多初学者对目录的执行权限感到困惑。实际上,它的核心含义是“穿越”:要操作目录下的任何文件(读、写、执行),或者对目录本身进行写操作(如增删文件),前提必须是拥有该目录的执行权限。这与普通文件的“执行”意义截然不同。 文章进一步揭示了其中的递归逻辑:要访问一个深层路径,需要从根目录开始,路径上每一个目录都拥有执行权限。作者用访问 `/home/foo/readme.txt` 的例子做了清晰推导,强调了根目录(/)的执行权限是访问起点的关键,这体现了Unix哲学中层层递进、权责明确的设计美感。 此外,文章还分析了另一个关于统计文本行数的约定。作者旨在说明,这些约定初看可能反直觉,但其内部逻辑统一且简洁,理解后能让人体会到系统设计的严谨性。对于想真正弄懂Linux文件权限底层逻辑的读者,这篇文章提供了非常清晰的视角。

IT 累计浏览 4,913

用Unix的设计思想来应对多变的需求

这篇文章的核心观点挺有意思的:作者认为无论Unix设计、面向对象还是其他架构模式,本质上都在做一件事——解耦。 作者从Unix设计哲学出发,探讨如何让软件设计更好地应对频繁变更的需求。文章提到,需求变更本身难以完全避免,但好的设计可以极大减轻它带来的痛苦。关键在于让模块之间的依赖尽可能少。这不仅呼应了Unix“做一件事并做好它”、“组合小工具”的经典思想,也点明了许多现代架构模式的共同内核。 文中还串联了之前相关的讨论与推荐阅读,比如《The Art of Unix Programming》和《一些软件设计的原则》,让整个思考的脉络更加完整。作者强调,技术手段无法解决所有不合理的需求,但可以通过扎实的解耦设计,让系统更具弹性,让开发者更从容。对于常与需求变更打交道的开发和架构人员来说,这提供了一个回归本源的思考视角。

IT 累计浏览 5,012

《Linux/Unix 设计思想》的翻译细节讨论

这篇讲的是一位技术译者从《Unix 编程艺术》转向新译本《Linux/Unix 设计思想》时的阅读反思。作者在五一假期通读新书后,并未直接展开对设计思想的讨论,而是将焦点转向了翻译实践本身——作为一个深耕技术翻译领域的图灵译者,他以专业视角剖析了这本书在翻译过程中存在的具体细节问题。 文中对比了经典原著与当前译本的处理方式,揭示了技术翻译中容易被忽视的难点:如何在准确传达原意的同时,兼顾中文读者的阅读习惯。作者从译者身份出发,探讨了术语统一、句式转换、文化适配等实际挑战,这些观察源于真实的翻译经验,而非单纯的理论评价。 这种从一线实践出发的细节讨论,不仅为同行提供了有价值的参考案例,也让普通读者意识到一本技术书籍背后严谨的转换工作。它提醒我们,优秀的技术传播既需要深厚的领域知识,也离不开对语言细节的执着打磨。

IT 累计浏览 2,219

保持简单----纪念丹尼斯o里奇(Dennis Ritchie)

这篇文章是作者受财新网之邀,为纪念刚离世的计算机大师丹尼斯·里奇所写。文章没有罗列其作为C语言和Unix创造者的丰功伟绩,而是抓住了里奇一生所践行的核心编程哲学——“保持简单”。 作者从里奇那些看似简洁甚至“简陋”的设计入手,阐述了这种简单并非简陋,而是一种深刻的洞察力与工程上的克制。文中探讨了里奇如何用最少的元素构建出强大而灵活的系统,以及这种哲学如何深刻影响了整个现代软件世界的根基。它提醒我们,在追求功能与炫技的时代,真正的智慧往往体现在对复杂性的有效驯服与舍弃上。 这篇文章更像是一次对技术初心的回望,让读者在缅怀大师的同时,重新思考自己编码与设计时的根本立场。

IT 累计浏览 4,451

UNIX 痛恨者手册读后笔记

这篇讲的是技术圈一本相当奇特的书——《UNIX 痫恨者手册》的读后感。作者从这本由对 UNIX 深恶痛绝的邮件组讨论汇编而成的书出发,梳理了书中抱怨的历史背景与现实意义。文章指出,以今天的眼光看,书中约一半批评已非 UNIX 特有问题,但另一半则生动展现了早期 UNIX 系统的原始面貌,也反衬出 Linux 等继承者在文件系统、安全性与稳定性上的长足进步。 更深层地,作者将这本书视为三种设计哲学交锋的案例:追求优雅与统一的 MIT 哲学(以 LISP 机器为代表),注重友好一致体验的 GUI 系统哲学,以及 UNIX 那种基于松散标准、如积木般可组合的开放式哲学。这种从“吐槽”中提炼出的技术演化脉络与设计思辨,或许比单纯的技术批评更能引发对操作系统设计本质的思考。

IT 累计浏览 3,529

Shell Tips: Unix 时间到字面

这篇讲的是在日常数据处理中,一个非常具体但又常常困扰人的小问题:如何快速将Unix时间戳转换成可读的日期时间格式。作者从自身处理报表数据的工作场景出发,面对交换文件里满屏的Unix时间数字,为了核对正确性,迫切需要一种高效的转换方法。 文章的核心就是分享一个实用的Shell技巧。它对比了Unix时间戳(一个从1970年开始的秒数,机器友好但人类看不懂)和字面时间(如“2024-01-01 12:00:00”)这两种表示形式,并给出了利用`date`命令进行转换的具体操作。这种转换在数据校验、日志分析等场景下尤为关键,能立刻将抽象数字还原为直观的时间点。 作者没有堆砌复杂的理论,而是从真实痛点切入,提供了一个可以直接套用的命令行解决方案。对于需要频繁与时间字段打交道的技术人员来说,这个小技巧能实实在在地提升数据检查的效率。

IT 累计浏览 3,828

linux中为何没有网卡设备文件

这篇讲的是一个看似简单却让很多人好奇的系统细节:为什么在Linux/Unix中,我们能看到硬盘的/dev/sda,却找不到网卡对应的设备文件?作者从这个问题切入,带读者回顾了网络设备在Unix哲学中独特的抽象历史。 文章并没有给出一个高深的技术答案,而是揭示了背后的思考。核心观点在于,Unix将网络设备(如eth0)抽象为字符设备或块设备,而是通过套接字(socket)接口统一管理,这是一种更高层次的抽象,更符合网络通信的流式与协议特性。作者通过这个细节,带出了对早期Unix设计者如何平衡硬件抽象与网络通信模型的思考。 这不仅仅是一个历史冷知识。它能帮助我们理解,现代操作系统中许多“理所当然”的设计(比如ifconfig和ip命令)并非凭空而来,而是源于清晰的设计哲学。对于开发者和运维人员来说,理解这种设计意图,能让我们更深刻地把握系统的行为逻辑。

IT 累计浏览 4,511

一个空格引发的惨剧

这篇文章讲的是一个因代码中多了一个空格而导致可能删除整个系统目录的灾难性故事。作者从个人经历出发,引出了开源项目 bumblebee(一个将 NVIDIA Optimus 技术移植到 Linux 的项目)安装脚本中的一个真实 bug。 这个 bug 的全部内容,就是一行 `rm -rf` 命令中,本应删除 `/usr/lib` 下特定文件的路径,因为一个空格变成了删除 `/usr` 和 `/lib` 两个独立目录——极有可能导致系统完全瘫痪。文章展示了这个 bug 的修复 diff,视觉冲击力极强,生动诠释了为何“测试程序是一种懦夫的行为”。 比 bug 本身更精彩的是,文章后续收录了全世界程序员围绕这个 commit 在 GitHub 上展开的欢乐 code review。评论中充斥着各种夸张的梗图和讽刺,将一次严重的线上事故变成了全球开发者的集体狂欢,既是对疏忽的嘲讽,也是对严谨编码的另类呼唤。

IT 累计浏览 3,942

Linux下方便的socket读写查看器(socktop)

这篇文章介绍了一个名为 socktop 的实用工具,用于解决一个非常具体的排查痛点:在 Linux 环境下观测 Unix 域套接字(Unix domain socket)的数据流。作者从实际工作中的需求出发——同事需要确认两个程序间是否通过 Unix 域套接字成功收发了消息,但常用的网络抓包工具如 tcpdump 和 Wireshark 对此无能为力。文章随后引出了解决方案:socktop 是一个轻量级的诊断工具,能够实时监听并展示指定套接字上的读写操作与数据,让原本“不可见”的进程间通信变得清晰可查。 内容不仅指出了问题所在,还直接给出了工具的使用场景和核心价值,对于需要进行本地 IPC 问题排查的开发者和运维人员来说,提供了一个即学即用的利器。文章的叙述平实而聚焦,从一个真实的问题切入,最终交付了一个具体的、可落地的技术方案。

IT 累计浏览 1,805

一些有意思的贴子和工具

这是一篇典型的资源集合类推荐。作者延续了CoolShell上杂项分享的风格,将近期在互联网上发现的各种新奇有趣的网站、工具和讨论帖子汇编在一起。不同于专题文章,它的价值在于精心筛选后的“发现感”。 文章涵盖了从实用开发工具到脑洞大开的在线项目,可能包括提高效率的命令行神器、设计独特的Web应用,或是程序员社区里引发热烈讨论的深度帖。作者并非简单罗列链接,而是为每个资源附上了简短的个人点评或背景说明,帮助读者快速判断其趣味点和实用价值,节省了大家自行发掘的时间。 这种持续更新的杂项集合,就像一个不断扩展的“有趣事物清单”,非常适合技术爱好者作为日常灵感的来源,或者在工作间隙换换脑子时浏览,总能从中发现一两个让你眼前一亮的东西。

IT 累计浏览 4,293

Unix高级环境编程系列笔记

这篇讲的是作者硬啃APUE这本“程序员圣经”的亲身经历。他坦言,阅读过程并不轻松,甚至可以说相当“辛苦”。 作者从实际阅读体验出发,指出了几个关键点:首先,APUE对读者的Unix编程经验有硬性要求,很多接口特性和编程陷阱,如果没有实操基础,很难真正理解;其次,书中逐一介绍API的写法虽然全面,但大量细节容易让人感到枯燥和疲倦。他特别提到,这本厚厚的书更像一部“Unix百科全书”,其描述的精确与深入让他对大师的功力肃然起敬。此外,阅读英文原版本身也构成了一重挑战,不仅影响了速度,偶尔还会导致对概念的理解偏差。 尽管过程艰苦,但这次阅读显然是一次扎实的深度学习。对于想挑战这本经典的开发者而言,作者的这些真实反馈或许能帮你做好心理准备:它需要耐心,更需要结合实践,才能将其中的宝藏真正转化为自己的知识。

IT 累计浏览 2,972

umask补习班

这篇讲的是Linux系统中umask命令的深入复习。作者从umask的常见用法和误区