生如夏花

专注于工业物联网行业数据采集,嵌入式Linux系统裁剪,5G智慧网关软件开发等

密码学常识

对称密码公钥密码单向散列函数消息认证码数字签名伪随机数生成器,这六种技术称为密码学家的工具箱。

信息安全所面临的威胁受威胁的特性用以应对的密码技术
窃听(秘密泄露)机密性对称密码/公钥密码
篡改(信息被修改)完整性单向散列函数/消息认证码/数字签名
伪装(伪装成真正的发送者)认证消息认证码/数字签名
否认(是否称自己没有做过)不可否认性数字签名

进程关系

本文主要介绍了终端,包括物理终端、模拟终端以及伪终端等。

两种不同的登录方式、即终端登录和网络登录。

重点是进程组、会话以及控制终端之间的联系。

最后是作业控制,作业控制是目前很多类Unix系统都支持的功能。

介绍了shell程序是如何实现作业控制的以及shell运行程序的方式。

系统数据文件和信息

口令文件/etc/passwd和组文件/etc/group经常被多个进程频繁使用。用户每次登录Linux和使用ls命令都会访问口令文件。

除了直接访问文件之外,系统通过一些接口来对外提供信息,比如系统标识函数、时间和日期函数。

标准IO

标准I/O库由ISO C标准制定的。标准I/O库相对于系统I/O处理了很多细节,比如缓冲区分配、以优化的块大小执行I/O(这个数据存储在stat结构体中的st_blksize字段)等。

系统I/O是以文件描述符来作为基础展开的,而标准I/O是围绕流进行的,打开或创建文件时会将流和文件关联起来。

获取与流相关的文件描述符可以使用函数fileno()

流和文件相关联为文件流,流和内存关联起来为内存流。

文件和目录

本文描述了文件的属性,主要是struct stat结构体中的相关字段,比如文件所有者ID、文件所属组ID、块大小等。

其次详细描述了文件权限的相关内容,包括文件的基本权限、进程创建、读写文件的权限验证规则以及修改文件权限的相关接口等。

最后是文件系统简介,包含inode、目录项等,以及文件时间,创建删除以及读写目录等。

文件IO

本节主要介绍不带缓冲的I/O(unbuffered I/O),不带缓冲指的是每个readwrite都会调用内核中的一个系统调用。

不带缓冲的I/O函数不是ISO C的标准函数,但是是符合POSIX的。

原子操作在多进程之间贡献文件变得相当重要。

主要涉及的函数有oepn, read, write, lseek, close; dup, fcntl, sync, fsync, ioctl