zoukankan      html  css  js  c++  java
  • 83、Linux知识-系统介绍、文件系统、远程操作——2020年07月27日12:47:14

    83、Linux知识

    2020年07月25日15:51:35

    1. Unix/Linux操作系统介绍

    操作系统的地位

    操作系统在计算机系统中承上启下的地位:向下封装硬件,向上提供操作接口。

    image-20200725155355931

    Linux的两类用户

    132038210113896_副本_副本

    Linux的远亲

    无标题_副本_副本

    Linux和Unix的联系

    l UNIX系统是工作站上最常用的操作系统,它是一个多用户、多任务的实时操作系统,允许多人同时访问计算机, 并同时运行多个任务。UNIX系统具有稳定、高效、安全、方便、功能强大等诸多优点,自20世纪70年代开始便运行在许多大型和小型计算机上。

    l UNIX虽然是一个安全、稳定且功能强大的操作系统,但它也一直是一种大型的而且对运行平台要求很高的操作系统,只能在工作站或小型机上才能发挥全部功能,并且价格昂贵,对普通用户来说是可望而不可及的,这为后来Linux的崛起提供了机会,Linux是一个类UNIX操作系统。

    l Linux是免费的、不受版权制约、与UNIX兼容的操作系统。

    l Linux在x86架构上实现了UNIX系统的全部特性,具有多用户多任务的能力,同时保持了高效性和稳定性,Linux具有如下的优秀的特点:

    1. 开放性;

    2. 完全免费;

    3. 多用户,多任务;

    4. 设备独立性;

    5. 丰富的网络功能;

    6. 可靠的系统安全性;

    Linux内核及发行版介绍

    1) Linux内核版本

    内核(kernel)是系统的心脏,是运行程序和管理像磁盘和打印机等硬件设备的核心程序,它提供了一个在裸设备与应用程序间的抽象层。

    Linux内核版本又分为稳定版和开发版,两种版本是相互关联,相互循环:

    l 稳定版:具有工业级强度,可以广泛地应用和部署。新的稳定版相对于较旧的只是修正一些bug或加入一些新的驱动程序。

    l 开发版:由于要试验各种解决方案,所以变化很快。

    内核源码网址:http://www.kernel.org,所有来自全世界的对Linux源码的修改最终都会汇总到这个网站,由Linus领导的开源社区对其进行甄别和修改最终决定是否进入到Linux主线内核源码中。

    2) Linux发行版本

    Linux发行版 (也被叫做 GNU/Linux 发行版) 通常包含了包括桌面环境、办公套件、媒体播放器、数据库等应用软件。

    这些操作系统通常由Linux内核、以及来自GNU计划的大量的函式库,和基于X Window的图形界面,在X Window中用户同样可以通过使用鼠标对窗口、菜单等进行操作来完成相应的工作。

    X Window系统是一个非常出色的图形窗口系统,是类UNIX系统的图形用户界面的工业标准。X Window系统最重要的特征之一就是它的结构与设备无关。

    X Window系统的主要特点有如下几点:

    l X Window系统是客户机/服务器结构的。X Window的实现是与操作系统内核分开的,其主要由X Server和X Client两部分组成。

    l X Window系统不是Unix/Linux操作系统的必须的构成部分,而只是一个可选的应用程序组件。

    16010808298121

    POSITION 2015 2014
    1 Linux Mint Linux Mint
    2 Debian Ubuntu
    3 Ubuntu Debian
    4 openSUSE openSUSE
    5 Fedora Fedora
    6 Mageia Mageia
    7 Manjaro Arch
    8 CentOS Elementary
    9 Arch CentOS
    10 Elementary Zorin

    Unix/Linux开发应用领域介绍

    l Unix/Linux服务器

    是目前Unix/Linux应用最多的一个领域,可以提供Web、FTP、Gopher、SMTP/POP3、Proxy/Cache、DNS等服务器,支持服务器集群,支持虚拟主机、虚拟服务、VPN等。

    l 嵌入式Linux系统

    嵌入式Linux是将流行的Linux操作系统进行剪裁修改,能够在嵌入式计算机系统上运行的一种操作系统。Linux嵌入式系统能够支持多种CPU和硬件平台,性能稳定,剪裁性好,开发和使用容易。其中包括Embedix、uCLinux、muLinux等。

    l 桌面应用

    近年来,Linux系统特别强调在桌面应用方面的改进,并且已达到相当的水平,完全可以作为一种集办公应用、多媒体应用、网络应用等多方面功能于一体的图形界面操作系统,在办公应用方面,Unix/Linux集成了openOffice、SUN公司的StarOffice以及KOffice等工具。

    l 电子政务

    随着Linux的快速发展,Linux已逐渐成为Windows系统重要的竞争力量。尤其是Linux在安全性方面的独特优势,又使得Linux在政府应用领域得到很大的发展。目前一些国家正将其电子政务系统向Linux平台迁移。中国政府也对Linux给予极大的支持。

    2.文件系统

    2.1 目录和路径

    2.1.1 目录

    l 目录是一组相关文件的集合。

    l 一个目录下面除了可以存放文件之外还可以存放其他目录,即可包含子目录。

    l 在确定文件、目录位置时,DOS和Unix/Linux都采用“路径名+文件名”的方式。路径反映的是目录与目录之间的关系。

    2.1.2 路径

    Unix/Linux路径由到达定位文件的目录组成。在Unix/Linux系统中组成路径的目录分割符为斜杠“/”,而DOS则用反斜杠“”来分割各个目录。

    路径分为绝对路径和相对路径:

    l 绝对路径

    1. 绝对路径是从目录树的树根“/”目录开始往下直至到达文件所经过的所有节点目录。

    2. 下级目录接在上级目录后面用“/”隔开。

    3. 注意:绝对路径都是从“/”开始的,所以第一个字符一定是“/”。

    l 相对路径

    1. 相对路径是指目标目录相对于当前目录的位置。

    2. 如果不在当前目录下,则需要使用两个特殊目录“.”和“”了。目录“.”指向当前目录,而目录“..”。

    2.2 文件系统

    2.2.1 Windows和Linux文件系统区别

    在 windows 平台下,打开“计算机”,我们看到的是一个个的驱动器盘符:

    2016-05-29_105552

    每个驱动器都有自己的根目录结构,这样形成了多个树并列的情形,如图所示:

    图片1

    在 Linux 下,我们是看不到这些驱动器盘符,我们看到的是文件夹(目录):

    2016-05-29_100613

    RedHat

    2016-05-29_100947

    Ubuntu

    在早期的 UNIX 系统中,各个厂家各自定义了自己的 UNIX 系统文件目录,比较混乱。Linux 面世不久后,对文件目录进行了标准化,于1994年对根文件目录做了统一的规范,推出 FHS ( Filesystem Hierarchy Standard ) 的 Linux 文件系统层次结构标准。FHS 标准规定了 Linux 根目录各文件夹的名称及作用,统一了Linux界命名混乱的局面。

    和Windows操作系统类似,所有Unix/Linux的数据都是由文件系统按照树型目录结构管理的。而且Unix/Linux操作系统同样要区分文件的类型,判断文件的存取属性和可执行属性。

    Unix/Linux也采用了树状结构的文件系统,它由目录和目录下的文件一起构成。但Unix/Linux文件系统不使用驱动器这个概念,而是使用单一的根目录结构,所有的分区都挂载到单一的“/”目录上,其结构示意图如图所示:

    图片2

    无论何种版本的 Linux 发行版,桌面、应用是 Linux 的外衣,文件组织、目录结构才是Linux的内心。

    2.2.2 Linux目录结构
    • l /:根目录,一般根目录下只存放目录,在Linux下有且只有一个根目录。所有的东西都是从这里开始。当你在终端里输入“/home”,你其实是在告诉电脑,先从/(根目录)开始,再进入到home目录。
    • l /bin: /usr/bin: 可执行二进制文件的目录,如常用的命令ls、tar、mv、cat等。
    • l /boot:放置linux系统启动时用到的一些文件,如Linux的内核文件:/boot/vmlinuz,系统引导管理器:/boot/grub。
    • l /dev:存放linux系统下的设备文件,访问该目录下某个文件,相当于访问某个设备,常用的是挂载光驱 mount /dev/cdrom /mnt。
    • l /etc:系统配置文件存放的目录,不建议在此目录下存放可执行文件,重要的配置文件有 /etc/inittab、/etc/fstab、/etc/init.d、/etc/X11、/etc/sysconfig、/etc/xinetd.d。
    • l /home:系统默认的用户家目录,新增用户账号时,用户的家目录都存放在此目录下,表示当前用户的家目录,edu 表示用户 edu 的家目录。
    • l /lib: /usr/lib: /usr/local/lib:系统使用的函数库的目录,程序在执行过程中,需要调用一些额外的参数时需要函数库的协助。
    • l /lost+fount:系统异常产生错误时,会将一些遗失的片段放置于此目录下。
    • l /mnt: /media:光盘默认挂载点,通常光盘挂载于 /mnt/cdrom 下,也不一定,可以选择任意位置进行挂载。
    • l /opt:给主机额外安装软件所摆放的目录。
    • l /proc:此目录的数据都在内存中,如系统核心,外部设备,网络状态,由于数据都存放于内存中,所以不占用磁盘空间,比较重要的目录有 /proc/cpuinfo、/proc/interrupts、/proc/dma、/proc/ioports、/proc/net/* 等。
    • l /root:系统管理员root的家目录(宿主目录)。
    • l /sbin:/usr/sbin: /usr/local/sbin:放置系统管理员使用的可执行命令,如fdisk、shutdown、mount 等。与 /bin 不同的是,这几个目录是给系统管理员 root使用的命令,一般用户只能"查看"而不能设置和使用。
    • l /tmp:一般用户或正在执行的程序临时存放文件的目录,任何人都可以访问,重要数据不可放置在此目录下。
    • l /srv:服务启动之后需要访问的数据目录,如 www 服务需要访问的网页数据存放在 /srv/www 内。
    • l /usr:应用程序存放目录,/usr/bin 存放应用程序,/usr/share 存放共享数据,/usr/lib 存放不能直接运行的,却是许多程序运行所必需的一些函数库文件。/usr/local: 存放软件升级包。/usr/share/doc: 系统说明文件存放目录。/usr/share/man: 程序说明文件存放目录。/usr/include:存放头文件。
    • l /var:放置系统执行过程中经常变化的文件,如随时更改的日志文件 /var/log,/var/log/message:所有的登录文件存放目录,/var/spool/mail:邮件存放的目录,/var/run:程序或服务启动后,其PID存放在该目录下。

    2.3 一切皆文件

    2.3.1 一切皆文件

    Unix/Linux对数据文件(.mp3、.bmp),程序文件(.c、.h、*.o),设备文件(LCD、触摸屏、鼠标),网络文件( socket ) 等的管理都抽象为文件,使用统一的方式方法管理。

    在Unix/Linux操作系统中也必须区分文件类型,通过文件类型可以判断文件属于可执行文件、文本文件还是数据文件。在Unix/Linux系统中文件可以没有扩展名。

    2.3.2 文件分类

    通常,Unix/Linux系统中常用的文件类型有7种:

    • 普通文件 - 、
    • 目录文件 d 、
    • 管道文件 p 、
    • 套接字文件 s、
    • 软链接文件 l、
    • 块设备文件 b、
    • 字符设备文件 c。

    l 普通文件

    普通文件是计算机操作系统用于存放数据、程序等信息的文件,一般都长期存放于外存储器(磁盘、磁带等)中。普通文件一般包括文本文件、数据文件、可执行的二进制程序文件等。

    在Unix/Linux中可以通过file命令来查看文件的类型。如果file文件后面携带文件名,则查看指定文件的类型,如果携带通配符“*”,则可以查看当前目录下的所有文件的类型。

    l 目录文件

    Unix/Linux系统把目录看成是一种特殊的文件,利用它构成文件系统的树型结构。

    目录文件只允许系统管理员对其进行修改,用户进程可以读取目录文件,但不能对它们进行修改。

    每个目录文件至少包括两个条目,“..”表示上一级目录,“.”表示该目录本身。

    l 设备文件

    Unix/Linux系统把每个设备都映射成一个文件,这就是设备文件。它是用于向I/O设备提供连接的一种文件,分为字符设备和块设备文件。

    字符设备的存取以一个字符为单位,块设备的存取以字符块为单位。每一种I/O设备对应一个设备文件,存放在/dev目录中,如行式打印机对应/dev/lp,第一个软盘驱动器对应/dev/fd0。

    l 管道文件

    管道文件也是Unix/Linux中较特殊的文件类型,这类文件多用于进程间的通信。

    l 软链接文件

    似于 windows 下的快捷方式,链接又可以分为软链接(符号链接)和硬链接。

    2.4 文件权限

    文件权限就是文件的访问控制权限,即哪些用户和组群可以访问文件以及可以执行什么样的操作。

    Unix/Linux系统是一个典型的多用户系统,不同的用户处于不同的地位,对文件和目录有不同的访问权限。为了保护系统的安全性,Unix/Linux系统除了对用户权限作了严格的界定外,还在用户身份认证、访问控制、传输安全、文件读写权限等方面作了周密的控制。

    在 Unix/Linux中的每一个文件或目录都包含有访问权限,这些访问权限决定了谁能访问和如何访问这些文件和目录。

    2.4.1 访问用户

    通过设定权限可以从以下三种访问方式限制访问权限:

    • l 只允许用户自己访问(所有者)

    所有者就是创建文件的用户,用户是所有用户所创建文件的所有者,用户可以允许所在的用户组能访问用户的文件。

    • l 允许一个预先指定的用户组中的用户访问(用户组)

    用户都组合成用户组,例如,某一类或某一项目中的所有用户都能够被系统管理员归为一个用户组,一个用户能够授予所在用户组的其他成员的文件访问权限。

    • l 允许系统中的任何用户访问(其他用户)

    用户也将自己的文件向系统内的所有用户开放,在这种情况下,系统内的所有用户都能够访问用户的目录或文件。在这种意义上,系统内的其他所有用户就是 other 用户类

    这有点类似于 QQ 空间的访问权限:

    l 这个 QQ 空间是属于我的,我相当于管理者(也就是“所有者”),我想怎么访问就怎么访问。

    l 同时,我可以设置允许 QQ 好友访问,而这些 QQ 好友则类似于“用户组”。

    l 当然,我可以允许所有人访问,这里的所有人则类似于“其他用户”。

    2.4.2 访问权限

    用户能够控制一个给定的文件或目录的访问程度,一个文件或目录可能有读、写及执行权限:

    l 读权限(r)

    对文件而言,具有读取文件内容的权限;对目录来说,具有浏览目录的权限。

    l 写权限(w)

    对文件而言,具有新增、修改文件内容的权限;对目录来说,具有删除、移动目录内文件的权限。

    l 可执行权限(x)

    对文件而言,具有执行文件的权限;对目录了来说该用户具有进入目录的权限。

    注意:通常,Unix/Linux系统只允许文件的属主(所有者)或超级用户改变文件的读写权限。

    2.4.3 示例说明

    20150317203048157

    1. 第1个字母代表文件的类型:“d” 代表文件夹、“-” 代表普通文件、“c” 代表硬件字符设备、“b” 代表硬件块设备、“s”表示管道文件、“l” 代表软链接文件。

    2. 后 9 个字母分别代表三组权限:文件所有者、用户者、其他用户拥有的权限。

    每一个用户都有它自身的读、写和执行权限。

    n 第一组权限控制访问自己的文件权限,即所有者权限。

    n 第二组权限控制用户组访问其中一个用户的文件的权限。

    n 第三组权限控制其他所有用户访问一个用户的文件的权限。

    这三组权限赋予用户不同类型(即所有者、用户组和其他用户)的读、写及执行权限就构成了一个有9种类型的权限组。

    4. 编辑器

    4.1 gedit编辑器

    gedit是一个Linux环境下的文本编辑器,类似windows下的写字板程序,在不需要特别复杂的编程环境下,作为基本的文本编辑器比较合适。

    2016-05-30_214344

    4.2 vi/vim编辑器

    4.2.1 vi介绍

    vi 编辑器是 Unix系统中最常见的基础文本编辑器。Linux下升级为vim编辑器,它不仅兼容 vi 的所有指令,而且还有一些新的特性,例如 vim 可以撤消无限次、支持关键词自动完成、可以用不同的颜色来高亮你的代码。vim 普遍被推崇为类 vi 编辑器中最好的一个。出于历史的原因使用时大家习惯性的统一简称vi。

    vim 编辑器在Linux界有编辑器之神的美誉,几乎所有的 Linux 发行版中都包含 vi 程序。

    可以联网使用命令快捷安装: sudo apt-get install vim

    由于vi 工作时,不需要图形界面,非常适合远程及嵌入式工作,是效率很高的文本编辑器,尽管在 Linux 上也有很多图形界面的编辑器可用,但vi的功能是那些图形编辑器所无法比拟的。

    vi有三种基本工作模式:

    + 命令模式

    + 文本输入模式

    + 末行模式。

    要想使用vi对文件进行编辑,必须熟练掌握这三种工作模式之间的工作关系。

    img

    4.2.2 vi最基本操作

    1) 打开文件

    vi filename:打开或新建文件,并将光标置于第一行行首,如果文件不存在,则会新建文件。

    img

    2) 编辑文件

    如果通过vi打开一个已经存在的文件,首先进入命令模式,此时输入的任何字符都被视为命令,不能输入内容。

    20150603174305350

    3) 保存文件

    一定要先退出插入模式(按Esc进入命令模式),然后,shift + zz (按住 “shift” + 按两下“z”键) 即可保存退出当前文件。

    4.2.3 vi实用命令

    1) 转换为编辑模式

    按键 功能
    a 光标位置右边插入文字
    i 光标位置当前处插入文字
    o(字母) 光标位置下方开启新行
    O(字母) 光标位置上方开启新行
    I 光标所在行首插入文字
    A 光标所在行尾插入文字
    s 以删除一个字符为条件,切换工作模式
    S 以删除一行为条件,切换工作模式

    2) vi的退出

    按键 功能
    ZZ(shift+z+z) 保存退出
    :wq 保存退出
    :x(小写) 保存退出
    :w filename 保存到指定文件
    :q 退出,如果文件修改但没有保存,会提示无法退出
    :q! 退出,不保存

    3) vi的删除和修改功能

    按键 功能
    [n]x 删除光标后 n 个字符
    [n]X 删除光标前 n 个字符
    D 删除光标所在开始到此行尾的字符
    [n]dd 删除从当前行开始的 n 行(准确来讲,是剪切,剪切不粘贴即为删除)
    [n]yy 复制从当前行开始的 n 行
    p 把粘贴板上的内容插入到当前行
    dG 删除光标所在行开始到文件尾的所有字符

    4) vi的行定位功能

    按键 功能
    Ctrl + f 向前滚动一个屏幕
    Ctrl + b 向后滚动一个屏幕
    gg 到文件第一行行首
    G(大写) 到文件最后一行行首,G必须为大写
    [n]G或[n]gg 到指定行,n为目标行数

    5) vi的文本查找功能

    按键 功能
    /字符串 查找指定字符串
    n 寻找下一个
    * 匹配一个已有字符。向后找寻
    # 匹配一个已有字符。向前找寻

    7) vi的set指令

    按键 功能
    :set nu 显示行号
    :set nonu 不显示行号

    5. 远程操作

    5.1 SSH介绍

    SSH为Secure Shell的缩写,由 IETF 的网络工作小组(Network Working Group)所制定;SSH 为建立在应用层和传输层基础上的安全协议。

    SSH是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。常用于远程登录,以及用户之间进行资料拷贝

    利用SSH协议可以有效防止远程管理过程中的信息泄露问题。SSH最初是 UNIX 系统上的一个程序,后来又迅速扩展到其他操作平台。SSH 在正确使用时可弥补网络中的漏洞。SSH 客户端适用于多种平台。几乎所有 UNIX 平台—包括 HP-UX、Linux、AIX、Solaris、Digital UNIX、Irix,以及其他平台,都可运行SSH

    使用SSH服务,需要安装相应的服务器和客户端。客户端和服务器的关系:如果,A机器想被B机器远程控制,那么,A机器需要安装SSH服务器,B机器需要安装SSH客户端。

    5.2 远程登录

    5.2.1 Linux平台相互远程

    操作命令:ssh -l username hostip

    参数 含义
    -l 选项, 是字母“l”,不是数字“1”
    username 被远程登录的用户名
    hostip 被远程登录的ip地址

    注意:远程登录的两台机器必须要能ping通(平通)。

    首先,查看需要被远程机器的ip:

    20150316152825888

    远程登录(这里是用户 wencong ( A 机器 ) 远程登录 edu ( B 机器 ) ), 可以不用sudo :

    20150316153919561

    SSH 告知用户,这个主机不能识别,这时键入"yes",SSH 就会将相关信息,写入" ~/.ssh/know_hosts" 中,再次访问,就不会有这些信息了。然后输入完口令,就可以登录到主机了。

    接着,提示输入登陆密码:

    20150316154524057

    登陆成功:

    20150316154843114

    20150316155025807

    5.2.2 Windows远程登录Linux

    如果想在 Windows 平台下远程登录 Linux,这时候,Windows 需要安装 安装相应软件包。这里介绍是Xmanager。

    Xmanager是一款小巧、便捷的浏览远端X窗口系统的工具。它包含Xshell、Xftp等软件:

    2016-05-31_012644

    l Xshell:是一个Windows平台下的SSH、TELNET和RLOGIN终端软件。它使得用户能轻松和安全地在Windows平台上访问Unix/Linux 主机。

    l Xftp:是一个应用于 Windows 平台的 FTP 和 SFTP 文件传输程序。Xftp能安全地在Unix/Linux 和 Windows 平台之间传输文件。

    配置Xshell,远程登录:

    20150204190645466

    20150204190727336

    20150204190758412

    20150204190815011

    20150204190840376

    20150204190921904

    Linux默认采用的编码格式是UTF-8,Windows默认采用的编码格式是ANSI(GB2312、GBK),所以需要设置一下相应编码:

    img

    5.3 远程传输文件

    5.3.1 Linux平台相互传输

    SSH 提供了一些命令和shell用来登录远程服务器。在默认情况下,不允许用户拷贝文件,但还是提供了一个“scp”命令。

    参数 含义
    RemoteUserName 远程用户名
    RemoteHostIp 远程ip
    RemoteFile 远程文件,可带上路径
    FileName 拷贝到本地后的名字,可带上路径,不带路径拷贝到当前目录

    本地文件复制到远程:

    scp FileName RemoteUserName@RemoteHostIp:RemoteFile
    
    scp FileName RemoteHostIp:RemoteFolder
    
    scp FileName RemoteHostIp:RemoteFile
    

    本地目录复制到远程:

    scp -r FolderName RemoteUserName@RemoteHostIp:RemoteFolder
    
    scp -r FolderName RemoteHostIp:RemoteFolder
    

    远程文件复制到本地:

    scp RemoteUserName@RemoteHostIp:RemoteFile FileName
    
    scp RemoteHostIp:RemoteFolder FileName
    
    scp RemoteHostIp:RemoteFile FileName
    

    远程目录复制到本地:

    scp -r RemoteUserName@RemoteHostIp:RemoteFolder FolderName
    
    scp -r RemoteHostIp:RemoteFolder FolderName
    

    拷贝远程的文件****:

    20150316170559766

    20150316170617192

    拷贝远程的文件可以任意修改其名字:

    20150316170844785

    拷贝远程的文件可以指定存放路径:

    20150316171318882

    5.3.2 Windows和Linux相互传输文件

    Xmanager自带的Xftp是一个应用于 Windows 平台的 FTP 和 SFTP 文件传输程序。Xftp能安全地在Unix/Linux 和 Windows 平台之间传输文件。

    2016-05-31_020103

    2016-05-31_020242

    2016-05-31_020305

    END

    2020年07月27日12:44:35

  • 相关阅读:
    POJ 3281 Dining 网络流最大流
    Codeforces Gym 100203I I
    Codeforces Gym 100203G G
    Codeforces Gym 100203E E
    Codeforces Gym 100523K K
    Codeforces Gym 100523E E
    Codeforces Gym 100523C C
    Codeforces Codeforces Round #316 (Div. 2) C. Replacement SET
    Codeforces Codeforces Round #316 (Div. 2) C. Replacement 线段树
    URAL 1784 K
  • 原文地址:https://www.cnblogs.com/oneapple/p/13384854.html
Copyright © 2011-2022 走看看