• 1.2. 操作系统简单分类

    1.2.1. Windows

    目前最流行的个人桌面操作系统 ,不做多的介绍,大家都清楚。界面简单易操作,软件生态非常好。

    玩玩电脑游戏还是必须要有 Windows 的,所以我现在是一台 Windows 用于玩游戏,一台 Mac 用于平时日常开发和学习使用。

    1.2.2. Unix

    最早的多用户、多任务操作系统 。后面崛起的 Linux 在很多方面都参考了 Unix。

    目前这款操作系统已经逐渐逐渐退出操作系统的舞台。

    1.2.3. Linux

    Linux 是一套免费使用、开源的类 Unix 操作系统。 Linux 存在着许多不同的发行版本,但它们都使用了 Linux 内核

    1.2.4. Mac OS

    苹果自家的操作系统,编程体验和 Linux 相当,但是界面、软件生态以及用户体验各方面都要比 Linux 操作系统更好。

    1.3. 操作系统的内核(Kernel)

    我们先来看看维基百科对于内核的解释,我觉得总结的非常好!

    简单概括两点:

    1.4. 中央处理器(CPU,Central Processing Unit)

    关于 CPU 简单概括三点:

    1.5. CPU vs Kernel(内核)

    很多人容易无法区分操作系统的内核(Kernel)和中央处理器(CPU),你可以简单从下面两点来区别:

    下图清晰说明了应用程序、内核、CPU 这三者的关系。

    1.6. 系统调用

    介绍系统调用之前,我们先来了解一下用户态和系统态。

    根据进程访问资源的特点,我们可以把进程在系统上的运行分为两个级别:

    说了用户态和系统态之后,那么什么是系统调用呢?

    我们运行的程序基本都是运行在用户态,如果我们调用操作系统提供的系统态级别的子功能咋办呢?那就需要系统调用了!

    也就是说在我们运行的用户程序中,凡是与系统态级别的资源有关的操作(如文件管理、进程控制、内存管理等),都必须通过系统调用方式向操作系统提出服务请求,并由操作系统代为完成。

    这些系统调用按功能大致可分为如下几类:

    我在网上找了一个图,通过这个图可以很清晰的说明用户程序、系统调用、内核和硬件之间的关系。(太难了~木有自己画

    2. 初探 Linux

    2.1. Linux 简介

    我们上面已经简单了 Linux,这里只强调三点。

    2.2. Linux 诞生

    1989 年,Linus Torvalds 进入芬兰陆军新地区旅,服 11 个月的国家义务兵役,军衔为少尉,主要服务于计算机部门,任务是弹道计算。服役期间,购买了安德鲁·斯图尔特·塔能鲍姆所著的教科书及 minix 源代码,开始研究操作系统。1990 年,他退伍后回到大学,开始接触 Unix。

    1991 年,Linus Torvalds 开源了 Linux 内核。Linux 以一只可爱的企鹅作为标志,象征着敢作敢为、热爱生活。

    2.3. 常见 Linux 发行版本有哪些?

    Linus Torvalds 开源的只是 Linux 内核,我们上面也提到了操作系统内核的作用。一些组织或厂商将 Linux 内核与各种软件和文档包装起来,并提供系统安装界面和系统配置、设定与管理工具,就构成了 Linux 的发行版本。

    Linux 的发行版本可以大体分为两类:

    对于初学者学习 Linux ,推荐选择 CentOS 。

    3. Linux 文件系统概览

    3.1. Linux 文件系统简介

    在 Linux 操作系统中,所有被操作系统管理的资源,例如网络接口卡、磁盘驱动器、打印机、输入输出设备、普通文件或是目录都被看作是一个文件。 也就是说在 Linux 系统中有一个重要的概念:一切都是文件

    其实这是 UNIX 哲学的一个体现,在 UNIX 系统中,把一切资源都看作是文件,Linux 的文件系统也是借鉴 UNIX 文件系统而来。

    3.2. inode 介绍

    inode 是 linux/unix 文件系统的基础。那么,inode 是什么?有什么作用呢?

    硬盘的最小存储单位是扇区(Sector),块(block)由多个扇区组成。文件数据存储在块中。块的最常见的大小是 4kb,约为 8 个连续的扇区组成(每个扇区存储 512 字节)。一个文件可能会占用多个 block,但是一个块只能存放一个文件。

    虽然,我们将文件存储在了块(block)中,但是我们还需要一个空间来存储文件的 元信息 metadata :如某个文件被分成几块、每一块在的地址、文件拥有者,创建时间,权限,大小等。这种 存储文件元信息的区域就叫 inode,译为索引节点:i(index)+node。每个文件都有一个 inode,存储文件的元信息。

    可以使用 stat 命令可以查看文件的 inode 信息。每个 inode 都有一个号码,Linux/Unix 操作系统不使用文件名来区分文件,而是使用 inode 号码区分不同的文件。

    简单来说:inode 就是用来维护某个文件被分成几块、每一块在的地址、文件拥有者,创建时间,权限,大小等信息。

    简单总结一下:

    3.3. Linux 文件类型

    Linux 支持很多文件类型,其中非常重要的文件类型有: 普通文件目录文件链接文件设备文件管道文件Socket 套接字文件等。

    3.4. Linux 目录树

    所有可操作的计算机资源都存在于目录树这个结构中,对计算资源的访问,可以看做是对这棵目录树的访问。

    Linux 的目录结构如下:

    Linux 文件系统的结构层次鲜明,就像一棵倒立的树,最顶层是其根目录:后端程序员必备的 Linux 基础知识+常见命令(近万字总结)-LMLPHP

    常见目录说明:

    4. Linux 基本命令

    下面只是给出了一些比较常用的命令。推荐一个 Linux 命令快查网站,非常不错,大家如果遗忘某些命令或者对某些命令不理解都可以在这里得到解决。

    Linux 命令大全:http://man.linuxde.net/

    4.1. 目录切换命令

    4.2. 目录的操作命令(增删改查)

    4.3. 文件的操作命令(增删改查)

    4.4. 压缩文件的操作命令

    1)打包并压缩文件:

    Linux 中的打包文件一般是以.tar 结尾的,压缩的命令一般是以.gz 结尾的。而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般.tar.gz。命令:tar -zcvf 打包压缩后的文件名 要打包压缩的文件 ,其中:

    比如:假如 test 目录下有三个文件分别是:aaa.txt bbb.txt ccc.txt,如果我们要打包 test 目录并指定压缩后的压缩包名称为 test.tar.gz 可以使用命令:tar -zcvf test.tar.gz aaa.txt bbb.txt ccc.txttar -zcvf test.tar.gz /test/

    2)解压压缩包:

    命令:`tar [-xvf] 压缩文件``

    其中:x:代表解压

    示例:

    4.5. Linux 的权限命令

    操作系统中每个文件都拥有特定的权限、所属用户和所属组。权限是操作系统用来限制资源访问的机制,在 Linux 中权限一般分为读(readable)、写(writable)和执行(excutable),分为三组。分别对应文件的属主(owner),属组(group)和其他用户(other),通过这样的机制来限制哪些用户、哪些组可以对特定的文件进行什么样的操作。

    通过 ls -l 命令我们可以 查看某个目录下的文件或目录的权限

    示例:在随意某个目录下ls -l

    第一列的内容的信息解释如下:

    文件的类型:

    Linux 中权限分为以下几种:

    文件和目录权限的区别:

    对文件和目录而言,读写执行表示不同的意义。

    对于文件:

    对于目录:

    需要注意的是:超级用户可以无视普通用户的权限,即使文件目录权限是 000,依旧可以访问。

    在 linux 中的每个用户必须属于一个组,不能独立于组外。在 linux 中每个文件有所有者、所在组、其它组的概念。

    修改文件/目录的权限的命令:chmod

    示例:修改/test 下的 aaa.txt 的权限为文件所有者有全部权限,文件所有者所在的组有读写权限,其他用户只有读的权限。

    chmod u=rwx,g=rw,o=r aaa.txt 或者 chmod 764 aaa.txt

    补充一个比较常用的东西:

    假如我们装了一个 zookeeper,我们每次开机到要求其自动启动该怎么办?

    4.6. Linux 用户管理

    Linux 系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。

    用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。

    Linux 用户管理相关命令:

    useradd 命令用于 Linux 中创建的新的系统用户。useradd可用来建立用户帐号。帐号建好之后,再用passwd设定帐号的密码.而可用userdel删除帐号。使用useradd指令所建立的帐号,实际上是保存在 /etc/passwd文本文件中。

    passwd命令用于设置用户的认证信息,包括用户密码、密码过期时间等。系统管理者则能用它管理系统用户的密码。只有管理者可以指定用户名称,一般用户只能变更自己的密码。

    4.7. Linux 系统用户组的管理

    每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同 Linux 系统对用户组的规定有所不同,如 Linux 下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。

    用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。

    Linux 系统用户组的管理相关命令:

    4.8. 其他常用命令


    后端程序员必备的 Linux 基础知识+常见命令(近万字总结)-LMLPHP

    后端程序员必备的 Linux 基础知识+常见命令(近万字总结)-LMLPHP


    本文分享自微信公众号 - Java建设者(javajianshe)。
    如有侵权,请联系 support@oschina.cn 删除。
    本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

    09-03 15:45