CentOS安装

目前,我们安装Linux操作系统的主要目的是为了更好地了解和学习它。如果条件允许,最好把Linux操作系统安装在一台PC机上;如果条件不允许也没有关系,阿铭会教你使用虚拟机来安装Linux操作系统。

大多数读者朋友比较习惯使用Windows操作系统,所以建议你使用虚拟机来学习Linux。阿铭相信,如果在Windows系统里安装一个虚拟机,然后在虚拟机上安装Linux,学习起来会更加方便。也许你会问:“现在我们使用虚拟机学习和练习,将来换成服务器能一样吗?”阿铭可以肯定地告诉你,除了几个小区别,它们几乎是一模一样的。至于是什么区别,阿铭会在后面的章节中进一步说明。

2.1 安装虚拟机

虚拟机技术在近几年非常流行,它可以模拟物理计算机的各种资源(如CPU、内存、硬盘等),所以,我们可以非常快捷地在Windows系统上安装多个Linux操作系统。虚拟机不仅可以在Windows平台上实现,也可以在Linux平台上实现。目前可以实现虚拟化技术的软件有很多,这里阿铭先介绍两种——VMware和VirtualBox。因为这两种软件比较适合我们来做实验,前者是收费的,后者是完全免费的。网上也有许多VMware的免费资源可以供大家下载,但这些免费的资源是破解版本(即盗版),如果在生产环境中使用,请购买正版授权。

阿铭不强求你用什么虚拟机程序来安装Linux,我们的目的不是为了学习如何使用虚拟机,而是为了学会如何使用虚拟机里面的Linux操作系统。

2.1.1 下载虚拟机软件

不管你使用的虚拟机是VMware(其官方地址为http://www.VMware.com)还是VirtualBox,都可以很好地安装Linux,后者是免费的,请从官方下载地址(https://www.virtualbox.org/wiki/Downloads)自行下载。VirtualBox有多个平台的支持版本,如果你使用的是Windows系统,请下载带for Windows hosts字样的版本。其实VMware虚拟化有好几个产品,而我们使用的是VMware Workstation,企业使用VMware ESXi比较多。至于VMware Workstation的下载地址,大家既可以自行搜索,也可以在前言中找到阿铭提供的地址下载。在接下来的内容中,将采用VMware 10来给大家演示。

2.1.2 安装虚拟机

首先,需要下载VMware Workstation软件,下载完后进行安装。

(1) 双击VMware-workstation-full-10.0.0-1295980.exe后,首先出现的是欢迎界面,如图2-1所示。

{%}

图 2-1 欢迎界面

(2) 点击“下一步”按钮,会弹出许可协议,这一步需要点击“我接受许可协议中的条款”,继续点击“下一步”按钮。

(3) 此时需要我们选择“设置类型”,根据它的提示,“自定义”类型是给高级用户提供的,所以我们选择“典型”类型即可,如图2-2所示。然后,点击“下一步”按钮。

{%}

图 2-2 设置类型

(4) 选择VMware Workstation安装路径,默认是要安装在C盘的。如果C盘空间快满了,那请更改到其他盘符。这里阿铭选择了默认路径。然后,继续点击“下一步”按钮。

(5) 此时它会提示我们启动时是否需要检查产品更新,如图2-3所示。这里,阿铭是把对勾取消的,毕竟我们使用的是老版本,并不想自动更新。

{%}

图 2-3 软件更新

(6) 点击“下一步”按钮后,又提示是否帮助改善VMware Workstation,这里阿铭也是把对勾取消的。继续点击“下一步”按钮。

(7) 在快捷方式里,阿铭保留了两个对勾,这样方便我们每次打开VMware Workstation,继续点击“下一步”按钮。

(8) 此时会弹出“已准备好执行请求的操作”,我们直接点击“继续”按钮即可。等待几分钟后,它会弹出“安装完成”的提示。点击“完成”按钮,则完成安装,最后它会提示我们输入产品的密钥。只有正确输入产品密钥,才可以继续使用VMware Workstation。

2.1.3 新建一个虚拟机

输入正确的产品密钥后,就可以正式使用VMware Workstation了。下面阿铭就教你如何在VMware Workstation(后面简称VMware)上创建一个Linux虚拟机。

(1) 运行VMware后,将会看到它的主页,如图2-4所示。

图 2-4 VMware主页

可以看到,它有5个功能,我们需要的就是第一个功能“创建新的虚拟机”,点击这个按钮,会弹出“新建虚拟机向导”界面,从中选择“典型”配置项,然后点击“下一步”按钮。

(2) 此时会提示如何安装客户机操作系统,如图2-6所示。这里所谓的“客户机”,其实就是后面要安装Linux操作系统的虚拟机。请大家选择“稍后安装操作系统”,这是因为当前还没有Linux操作系统的安装镜像文件。点击“下一步”按钮,继续。

{%}

图 2-5 新建虚拟机向导

{%}

图 2-6 安装来源

(3) 选择要安装的操作系统类型。这里VMware已经给大家列出来常见的几种操作系统类型,这里选择Linux,版本为“CentOS 64位”,如图2-7所示。

小知识 所有的操作系统都分32位和64位,这个指标取决于计算机的CPU标准,目前的计算机已经普遍支持64位了。那么,如何区分使用32位和64位的操作系统呢?其中一个重要的指标就是内存大小。32位操作系统最多支持4GB内存,要想使用超过4GB内存的计算机,就必须使用64位操作系统。这里阿铭选择CentOS 64位。CentOS 7刚出来的时候并没有32位,在2015年推出了32位系统,但即使你下载了32位的镜像,这里同样要选择64位。

{%}

图 2-7 客户机操作系统

(4) 点击“下一步”按钮,将出现如图2-8所示的“命名虚拟机”对话框。你可以给你的虚拟机起一个自定义的名字,如aminglinux01-CentOS7。“位置”这里需要定义到一个大的分区中,因为这台虚拟机会占用较大的空间。

{%}

图 2-8 命名虚拟机

(5) 继续点击“下一步”按钮,此时会让我们指定磁盘容量,这里采用默认值即可,因为20GB足以支持我们后续的实验。

{%}

图 2-9 指定磁盘容量

(6) 点击“下一步”按钮后,请点击“自定义硬件”,进一步定义CPU、内存等硬件指标,如图2-10所示。内存建议至少1GB,这里阿铭为了让虚拟机更加高效,分配了2GB。而你需要根据你的电脑配置来分配内存,如果你的物理机内存低于或等于4GB,请设置1GB,否则会影响到你的物理机速度。处理器数量选择1,每个处理器的核心数量选择2,这样相当于1颗物理CPU,2颗逻辑CPU。目前,市面上的电脑配置并不低,几乎所有的电脑都是支持这样分配的。CD/DVD这一项暂时先保持默认,后续我们安装操作系统之前再来设置它。网络适配器,请大家选择NAT模式,因为这种网络模式是兼容性最好的,其他项采用默认值即可。

{%}

图 2-10 自定义硬件

之后点击“关闭”按钮,再点击“完成”按钮。这样就创建完了第一台虚拟机。下面就是在虚拟机里面安装Linux操作系统了。

小知识 这里阿铭要向大家介绍一下VMware虚拟机中涉及的3种常见网络模式。

  • 桥接模式。这种模式下,虚拟机和物理机连的是同一个网络,虚拟机和物理机是并列关系,地位是相当的。比如,你家如果有用路由器,那么你的电脑和你的手机同时连接这个路由器提供的Wi-Fi,那么它们的关系就是这种模式。
  • NAT模式。这种模式下,物理机会充当一个“路由器”的角色,虚拟机要想上网,必须经过物理机,那物理机如果不能上网,虚拟机也就不能上网了。之所以说这种模式兼容性最好,是因为当物理机的网络环境变化时,虚拟机的网络并不会有影响。比如,上班时你把物理机连接在公司的网络环境中,下班后又把物理机连接在你家的路由器上。你公司的网段很有可能和你家的网段是不同的。桥接模式下,虚拟机和物理机一样,都要自动获取IP才可以上网,而我们做实验的时候,是需要把虚拟机设置为静态IP的,这样就导致虚拟机网络不稳定。而设置为NAT模式,虚拟机的网络并不需要依赖你公司的网络环境或者你家的网络环境。
  • 仅主机模式。这个就很容易理解了,这种模式下,相当于拿一根网线直连了物理机和虚拟机。

2.2 安装Linux操作系统

创建虚拟机之后,便可安装Linux操作系统,其安装过程与Windows系统极为相似。如果你之前安装过Windows系统,那接下来的操作就不难了。在安装CentOS之前,我们还需要做一件事情——下载一个CentOS镜像文件。

2.2.1 下载CentOS镜像文件

什么是镜像文件?镜像文件就是用来制作系统安装盘的。相信你一定了解系统安装光盘,只不过这几年光盘逐渐被U盘所取代。安装盘里面的内容其实就是镜像文件,而且虚拟机可以直接把镜像文件放到虚拟光驱中,因此,我们不需要放入系统安装盘也可以安装CentOS。

CentOS当前的两个主流版本为CentOS 6和CentOS 7,由于CentOS 6使用2.6版本的Linux内核,而CentOS 7则使用了3.10版本的Linux内核,所以二者区别还是很大的。目前,越来越多的企业使用CentOS 7,这是因为很多软件都是基于Linux 3.x版本的内核来开发的,比如Docker、OpenStack等主流软件在CentOS 6上兼容性不好。阿铭相信,过不了多久,CentOS 6将成为历史。所以,后续的章节都是基于CentOS 7来展开讲解的。

CentOS的官方下载地址为http://www.centos.org/,但下载速度太慢。阿铭建议大家到http://r.aminglinux.com(这里提供的下载地址是搜狐公司提供的一个国内镜像地址,下载速度很快)下载,请选择对应的CentOS 7下载地址。阿铭在写本书时,最新的CentOS 7版本为7.3,所以本书中的实验也基于该版本。

2.2.2 设置虚拟光驱

下载镜像文件后,我们先来设置虚拟光驱,具体的操作方法如下。

(1) 当创建完第一台虚拟机后,VMware将多出来一个页面,如图2-11所示。

图 2-11 虚拟机页面

(2) 点击“编辑虚拟机设置”按钮,然后选择CD/DVD(IDE),在右侧选择“使用ISO镜像文件”,再点击“浏览”按钮,找到我们刚刚下载好的CentOS 7的镜像,如图2-12所示。

{%}

图 2-12 设置ISO镜像

(3) 点击“确定”按钮返回刚才的虚拟机页面。点击“开启此虚拟机”按钮,开始启动虚拟机。然后会弹出一些诸如图2-13所示的类似提醒,我们只需要点击“确定”按钮即可,不用关注它。

{%}

图 2-13 键盘挂钩超时值提醒

2.2.3 安装CentOS

安装页面终于出现了,下面就跟着阿铭一步一步来安装CentOS吧。

(1) 首先出现的是黑底白字的欢迎页面,如图2-14所示,这和之前CentOS 6版本有所不同。在这里阿铭要提醒大家的是:要想在虚拟机里面点击鼠标,必须先在虚拟机的页面里单击鼠标;要想退出来,需要同时按下Ctrl和Alt这两个键。

{%}

图 2-14 开始安装

(2) 点击鼠标后,按键盘上下方向键选择对应的项。其中,第一行Install CentOS Linux 7的作用是安装CentOS 7系统。第二行Test this media & install CentOS Linux 7,是先检测安装镜像文件的可用性,然后再安装CentOS 7。第三行Troubleshooting用于处理一些故障问题,选择这一项,会进入一个内存操作系统,然后可以把磁盘上的系统挂载到这个内存操作系统上,这样方便我们去处理一些问题。这里阿铭选择第一项,然后回车。

(3) 此时会出现一个提示,你需要再按一次回车才可以进一步操作。等待几秒后,会出现一个图形安装界面,如图2-15所示。首先选择使用的语言,这里需要选择“中文”和“简体中文”。

{%}

图 2-15 选择语言

(4) 点击“继续”按钮后,会弹出如图2-16所示的“安装信息摘要”。

{%}

图 2-16 安装信息摘要

本地化包括“日期和时间”“键盘”“语言支持”三项,这三项采用默认值即可,不需要设置。软件包括“安装源”和“软件选择”这两项,也采用默认值,不用设置。系统包括“安装位置”、KDUMP、“网络和主机名”和SECURITY POLICY四项,其中“安装位置”就是分区,这一项需要设置,其他采用默认值即可。

(5) 点击“安装位置”,将会出现如图2-17所示的“安装目标位置”界面,从中选择“我要配置分区”单选按钮。

{%}

图 2-17 安装目标位置

(6) 点击左上角的“完成“按钮后,会出现分区界面,如图2-18所示。

{%}

图 2-18 手动分区

点击LVM下拉菜单,选择“标准分区”,然后点击左下角的+按钮,在弹出的“添加新挂载点”对话框中,设置挂载点为/boot,设置期望容量为200MB,简写为200M,然后点击“添加挂载点”按钮。

{%}

图 2-19 设置/boot分区

继续点击+按钮,再增加swap分区,大小为4GB,如图2-20所示。

{%}

图 2-20 添加swap分区

继续点击+按钮,挂载点选择“/”,期望容量留空,然后点击“添加挂载点”按钮,这样就把剩余空间全部给了“/”分区。

{%}

图 2-21 添加根分区

小知识 这里阿铭要向大家介绍一下划分磁盘分区的规则。如果到一家企业工作,当你遇到安装CentOS操作系统时,分区要按照公司领导的要求来,如果领导没有要求,就按照阿铭的方法来。具体是这样的:(1)/boot分区分200MB;(2)swap分区分内存的2倍(如果内存大于等于4GB,swap分8GB即可,因为分多了也是浪费磁盘空间);(3)/分区分20GB;(4)剩余的空间给/data分区。在本书中,阿铭并没有单独分/data分区,这是因为阿铭的虚拟机一共就20GB的空间,毕竟是做实验用,就不再单独额外分了。

(7) 最终完成分区,如图2-22所示。

{%}

图 2-22 分区完成

点击左上角的“完成”按钮后,将弹出如图2-23所示的提醒。

{%}

图 2-23 更改摘要

点击“接受更改”按钮,返回最初的“安装信息摘要”界面,此时点击右下角的“开始安装”按钮,开始安装操作系统,如图2-24所示。

{%}

图 2-24 配置

但你会发现该页面还有两个叹号,这是因为我们还没有设置ROOT用户的密码,ROOT用户就是CentOS操作系统的超级管理员用户,密码是必须要设置的。所以,点击它,进入设置ROOT密码的界面,如图2-25所示。

{%}

图 2-25 设置ROOT密码

ROOT用户密码尽量要复杂(最好是大小写字母和数字的组合),否则很容易被暴力破解。设置完ROOT密码后,点击“完成”按钮返回刚才的界面,发现两个叹号已经消失。当然,你还可以继续设置一个普通用户,这里我们并没有设置普通用户。等待几分钟之后,系统安装完成,它会提示让我们重启,如图2-26所示。

{%}

图 2-26 安装完成

点击“重启”按钮,就可以进入CentOS 7操作系统了。

2.3 第一次亲密接触

重启CentOS后,会出现如图2-27所示的黑框,提示我们登录。这个登录界面没有出现任何图形,因为我们没有安装与图形相关的程序包。如果你想使用图形,可以在进入系统后安装图形套件,然后切换到图形界面就可以了。

{%}

图 2-27 登录

2.3.1 初次使用命令行登录

在如图2-27所示的黑框里点击鼠标,在localhost login:后面输入root并回车,然后输入先前设置的ROOT密码,进入CentOS系统,如图2-28所示。

{%}

图 2-28 进入系统

在图2-28中,倒数第2行提示我们上一次root用户登录系统的时间以及终端(tty1)。在命令行模式下,默认有6个终端,即tty1,tty2…tty6;以图形形式登录会显示tty7;如果是通过远程登录的,那会显示pts/0,pts/1,pts/2……。

2.3.2 设置网络

给Linux设置网络是为了使用yum工具安装图形套件,然后启动图形界面。下面请跟阿铭一起来给你的CentOS 7设置网络,使其可以上网。前面创建虚拟机时,我们已经将这台机器设置成NAT网络模式。所以,下面的操作都是基于NAT模式来的。桥接模式和NAT模式类似,这里就不再演示了。

(1) 在登录黑框中输入如下命令,让CentOS 7自动获取一个IP地址:

# dhclient

这里阿铭需要先声明:以后所有的命令都会以#开头,命令下面是执行该命令的结果。输入命令后回车,稍等几秒钟就可以获取IP地址了。

(2) 正常情况下是不会有任何输出内容的。如果你的CentOS 7返回一些信息,那说明你的操作有问题,请到阿铭论坛发帖,或者通过阿铭的微信进行求助。那获取到的IP地址是什么样的呢?我们如何查看?请运行如下命令:

# ip addr

它将返回如图2-29所示的信息。

{%}

图 2-29 IP地址

ip addr命令就是用来查看IP地址的。这里请大家注意英文字母的大小写,Linux操作系统是区分大小写的。从图2-29中可以看出,这台机器有两个IP地址。第一个地址127.0.0.1是回环地址,网卡名字叫作lo,Windows操作系统也有该地址,用来自己和自己通信。第二个地址192.168.188.128就是刚刚我们自动获取到的IP地址,其中ens33就是网卡的名字。你获取到的IP地址和阿铭的可能不一样,这是因为VMware分配的地址段不一样,请大家放心,这并不是你没有配置对。另外,你的网卡名字也不一定是ens33,这个也是没有关系的。下面阿铭教你怎么看VMware NAT网络模式的网段是多少。

首先同时按下Ctrl和Alt这两个键,释放你的鼠标,然后点击VMware虚拟机左上角菜单栏中的“编辑”,选择“虚拟网络编辑器”,此时会弹出如图2-30所示的界面。

{%}

图 2-30 虚拟网络编辑器

选中VMnet8(NAT模式),此时下面就可以看到子网IP为192.168.188.0,子网掩码为255.255.255.0,我们获取到的那个IP就在这个子网里面。然后点击右侧的“NAT 设置”按钮,此时会出现如图2-31所示的界面。

{%}

图 2-31 NAT 设置

在这个界面中,我们会看到网关为192.168.188.2。请大家记住这个网关地址,因为接下来还会用到它。

(3) 自动获取IP地址后,我们先来测试一下CentOS 7是否可以联网。请大家注意,你的CentOS 7能联网的前提是你的物理机可以联网。输入如下命令进行测试:

# ping -c 4 www.aminglinux.com

运行结果如图2-32所示。

{%}

图 2-32 测试网络

ping命令相信很多朋友都用过,它是用来检测网络的工具。图2-32的结果表示本机是可以联网的。如果你的结果和阿铭的不同,那很有可能说明你的设置有问题,请添加阿铭微信获取帮助。

(4) 虽然CentOS 7已经可以联网,但阿铭觉得这还不够,因为你还不会手动给CentOS 7设置IP地址。在日常的运维工作中,我们是需要手动给Linux系统设置IP地址的。下面阿铭教你如何手动设置IP地址。输入如下命令:

# vi  /etc/sysconfig/network-scripts/ifcfg-ens33

请大家注意,在Linux系统下,命令后面是需要带空格的,这里的vi是一个用来编辑文本的命令,第7章会详细介绍它。它后面跟一个空格(当然跟多个空格也没错),再后面是一个文件的路径。这个文件就是网卡的配置文件,要修改IP地址,就得编辑这个文件。你的网卡配置文件名字(ifcfg-ens33)可能和阿铭的不一样,这个主要是看你的网卡名字是什么。回车后,进入如图2-33所示的界面。

{%}

图 2-33 网卡配置

进入网卡配置文件后,我们可以使用上、下、左、右方向键去移动光标,但不能直接去修改文件内容。要想修改文件内容,只需按字母i键。我们需要修改的内容有,将ONBOOT=no改为ONBOOT=yes,将BOOTPROTO=dhcp改为BOOTPROTO=static,并增加如下几行字符:

IPADDR=192.168.188.128
NETMASK=255.255.255.0
GATEWAY=192.168.188.2
DNS1=119.29.29.29

这里需要说明的是,ONBOOT设置为yes,表示网卡随系统一同启动。BOOTPROTO用来设置网卡的启动类型,dhcp表示自动获取IP地址,static表示手动设置静态IP地址。IPADDR指定IP地址(请不要设置的和阿铭的一样,你的IP地址取决于前面你自动获取到的地址),NETMASK指定子网掩码,GATEWAY指定网关(这个网关就是刚刚阿铭让大家记住的网关地址),DNS1指定上网用的DNS IP地址,这个119.29.29.29是国内DNSpod公司提供的一个公共DNS。完成以上的更改后,按一下Esc键,紧接着输入“:wq”并回车,退出刚才的文档。然后重启网络服务,运行如下命令:

# systemctl restart network.service

然后再查看一下IP地址:

# ip addr

如果正确的话,你看到的结果依然如图2-29所示。当然,还需要再测试一下网络连通性,此时输入如下命令:

# ping -c 4 www.aminglinux.com

如果网络没有问题,可以运行如下命令来安装图形界面:

# yum groupinstall –y “GNOME Desktop”

这里需要说明的是,yum命令是CentOS系统里用来安装软件包的工具,9.2节会讲到它。这个过程会需要一段时间,因为它需要下载网络资源,耐心等待即可。等安装完成后,输入如下命令:

# init 5

等待几秒钟后,就会出现如图2-34所示的页面。

{%}

图 2-34 初始化设置

这里要做一下初始化设置,比如要设置一个普通用户,目的是为了拿这个普通用户登录图形界面。在它的提示下面,我们输入数字1并回车,将出现License information,其中有两个选项,1表示阅读这个许可,2表示直接同意这个许可。我们输入数字2并回车,再输入字母c继续。此时又再次跳出之前的Initial setup界面,和之前有变化的是,第1项多了一个[x],这表示这一项我们已经设置过了,如图2-35所示。

{%}

图 2-35 许可信息

设置完第1项后,输入数字2并回车,此时会出现User creation的提示。不过这里只有1项提示,所以没得选,直接输入数字1并回车。此时将会出现6项关于创建用户的列表,如图2-36所示。

{%}

图 2-36 创建用户

第1项不用管,输入数字2并回车,设置Fullname为aming,回车后发现第3项也自动设置为了aming,如图2-37所示。

{%}

图 2-37 Fullname

再输入数字4,回车后,它自动会在数字4后面加个[x],说明接下来要设置密码。此时,你会发现又多出来一项。再输入数字5,回车,它会让我们输入aming用户的密码,连续输入两次密码。这里请尽量把密码设置得复杂一些(包括大小写字母,长度不低于8位),否则会提醒我们密码太简单。

{%}

图 2-38 设置密码

继续输入数字6并回车,此时在数字6后面多一个[x],如图2-39所示。

{%}

图 2-39 Administrator

这表示将aming用户设置为管理员。再输入数字7并回车,设置aming用户的组,组名为aming。其实,aming用户已经属于wheel组,这样它又多了一个组,如图2-40所示。

{%}

图 2-40 设置组

最后输入字母c,回车后又回到最初的Initial setup界面,你会发现2数字后面也有个[x],说明这一项已经设置。然后再次输入字母c,回车后就会进入登录界面,如图2-41所示。

{%}

图 2-41 登录界面

点击aming并输入密码,最终进入图形化界面。然后它会弹出一个欢迎界面,让我们设置键盘、语言等信息。直接点击右上角的“下一步”→“下一步”→“跳过”按钮,最终会弹出如图2-42所示的界面,点击“开始使用 CentOS Linux”按钮即可。

{%}

图 2-42 开始使用

接下来,就进入CentOS 7的图形界面,你可以用鼠标点着操作了。对比一下,和咱们熟悉的Windows操作系统有什么不同吧。阿铭觉得,这个操作系统和苹果的macOS还是有些像的。不过,话说回来,很少有人拿CentOS操作系统作为办公使用,而绝大多数作为服务器,所以几乎没有人使用它的图形化界面。

2.3.3 图形和命令行切换

刚才我们启动了图形界面,那么在图形模式下如何切换到命令行模式呢?有两种方法可以实现。

  • 同时按Ctrl、Alt以及F2(或者F3-F6)这3个键切换到命令行模式,按Ctrl+Alt+F1组合键切回图形界面。
  • 在图形界面下,点击左上角的“应用程序”按钮,选择“终端”选项,如图2-43所示。

{%}

图 2-43 终端

然后在终端窗口下输入如下命令init 3,然后输入aming用户的密码,从而关闭图形服务,进入命令行模式:

# init 3

另外,在命令行模式下,比如在终端tty1,可以使用Alt+F2组合键切换到终端tty2。同理,使用Alt+F3组合键可以切换到终端tty3,使用Alt+F7组合键可以切换到图形模式,但前提是已开启图形服务。也就是说,tty1-tty6为命令行的终端,而tty7为图形的终端。但在此处,咱们刚刚做的实验有些特殊,因为刚才启动的图形服务,是在tty1的基础上起来的,所以tty1在刚才是图形界面。

2.3.4 学会使用快捷键

切换回命令行界面后,我们继续下面的学习。在日常运维管理工作中,快捷键可以大大提高工作效率。在Linux系统中,常用的快捷键如下。

  • Ctrl+C:结束(终止)当前命令。如果你输入了一大串字符,但不想运行,可以按Ctrl+C组合键,此时光标将跳入下一行,而在刚刚的光标处会留下一个^C的标记,如图2-44所示。

    {%}

    图 2-44 取消命令

  • Tab:实现自动补全功能。这个键比较重要,使用频率也很高。当你输入命令、文件或目录的前几个字符时,它会自动帮你补全。比如,前面阿铭教大家编辑网卡的配置文件时文件路径很长,这时结合Tab键就会很轻松。

  • Ctrl+D:退出当前终端。同样,你也可以输入命令exit实现该功能。

  • Ctrl+Z:暂停当前进程。这和Ctrl+C是有去区别的,暂停后,使用fg命令恢复该进程,该知识点会在第10章中介绍到。

  • Ctrl+L:清屏,使光标移动到屏幕的第一行。 当命令和显示的结果占满整个屏幕时,我们每运行一个命令,都会在最后一行显示,这样看起来不太方便,此时就可以使用这个快捷键,让光标移动到屏幕第一行,也就是所谓的清屏。

  • Ctrl+A:可以让光标移动到命令的最前面。有时候一条命令很长,快敲完时发现前面某个字母不对,此时可以直接用这个快捷键把光标定位到行首,然后再用左右方向键微调光标的位置。

  • Ctrl+E:可以让光标移动到最后面,作用同上。

2.3.5 学会查询帮助文档 —— man

man命令用于查看命令的帮助文档,其格式为man命令。例如,输入如下命令:

# man ls

这样可以查看ls命令的帮助文档,如图2-45所示。

{%}

图 2-45 man命令

如果屏幕不能显示完整,可以按空格键下翻,或者按上下方向键前后移动文本。若想退出帮助文档,按字母键q。当然,想要看明白这个文档,还需要你有一定的英文阅读能力。这个man命令非常实用。尤其是对于初学者来讲,我们刚刚学一个命令时,总是记不住它的各个选项的用法,记不清时,随手man一下,就可以看到了,非常方便!同时,阿铭相信经常查看英文的文档也会提升你的英文阅读能力。

2.3.6 Linux系统目录结构

登录Linux系统后,在当前命令窗口下输入如下命令:

# ls /

此时将会出现如图2-46所示的界面。

{%}

图 2-46 ls

你的结果可能和阿铭的有所不同,不要紧,目前我们探讨的并不是差异,而是相同的地方。其中,ls是list的缩写,该命令用于列出指定目录或者文件。/是Linux操作系统里面最核心的一个目录,所有的文件和目录全部在它下面,所以称它为“根目录”。前面讲磁盘分区时,阿铭也是单独给它分了一个区的。大家要逐渐适应Linux系统的特性,毕竟它和Windows有太多的差异。

通过上一节中提到的命令man ls,可以了解ls命令具体的用法。对于ls这个最常用的命令,阿铭在这里举几个简单的例子帮你快速掌握其用法:

# ls
anaconda-ks.cfg  Desktop  Documents  Downloads  initial-setup-ks.cfg  Music  Pictures  Public  Templates  Videos

# ls -a
.   anaconda-ks.cfg  .bash_logout   .bashrc  .config  Desktop    Downloads  .ICEauthority         .local  Pictures  .tcshrc    Videos
..  .bash_history    .bash_profile  .cache   .cshrc   Documents  .esd_auth  initial-setup-ks.cfg  Music   Public    Templates  .Xauthority

# ls -l
总用量 8
-rw-------. 1 root root 1422 2月  13 05:38 anaconda-ks.cfg
drwxr-xr-x. 2 root root    6 2月  13 22:40 Desktop
drwxr-xr-x. 2 root root    6 2月  13 22:40 Documents
drwxr-xr-x. 2 root root    6 2月  13 22:40 Downloads
-rw-r--r--. 1 root root 1655 2月  13 23:22 initial-setup-ks.cfg
drwxr-xr-x. 2 root root    6 2月  13 22:40 Music
drwxr-xr-x. 2 root root    6 2月  13 22:40 Pictures
drwxr-xr-x. 2 root root    6 2月  13 22:40 Public
drwxr-xr-x. 2 root root    6 2月  13 22:40 Templates
drwxr-xr-x. 2 root root    6 2月  13 22:40 Videos

# ls initial-setup-ks.cfg
initial-setup-ks.cfg

# ls /var/
account  adm  cache  crash  db  empty  games  gopher  kerberos  lib  local  lock  log  mail  nis  opt  preserve  run  spool  target  tmp  yp

说明:其中以#开头的行都是运行的命令,它下面的内容是命令运行后的结果。可能你的结果和阿铭的有所不同,但不要紧,这是因为你的系统和阿铭的系统是存在一些差异的。如果有任何异议,请联系阿铭获取帮助。下面阿铭来讲解一下以上几个小案例的含义。

  • 后面不加任何选项也不跟目录名或者文件名:会列出当前目录下的文件和目录,不包含隐藏文件。
  • 后面加-a选项、不加目录名或者文件名:会列出当前目录下所有文件和目录,含有隐藏文件。
  • 后面加-l选项、不加目录名或者文件名:会列出当前目录下除隐藏文件外的所有文件和目录的详细信息,包含其权限、所属主、所属组以及文件创建日期和时间。
  • 后面不加选项、只跟文件名:会列出该文件,使用时通常都是加上-l选项,用来查看该文件的详细信息。
  • 后面不加选项、只跟目录名:会列出指定目录下的文件和目录。

其实,ls命令的可用项还有很多,不过阿铭只介绍了最常用的选项。因为在日常工作和学习中,这些已经足够。如果实在遇到不懂的选项,可以用man命令来查看帮助文档。

下面我们接着来讨论Linux的目录结构。

  • /bin:bin是Binary的缩写,该目录下存放的是最常用的命令。

  • /boot:该目录下存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。

  • /dev:dev是Device(设备)的缩写。该目录下存放的是Linux的外部设备。在Linux中,访问设备的方式和访问文件的方式是相同的。

  • /etc:该目录下存放的是所有系统管理所需要的配置文件和子目录。

  • /home:这是用户的家目录。在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。

  • /lib和/lib64:这两个目录下存放的是系统最基本的动态连接共享库,其作用类似于Windows里的DLL文件,几乎所有的应用程序都需要用到这些共享库。其中/lib64为64位的软件包的库文件所在目录。

  • /media:系统会自动识别一些设备(如U盘、光驱等),当识别后,Linux会把识别的设备挂载到该目录下。

  • /mnt:系统提供该目录是为了让用户临时挂载别的文件系统。我们可以将光驱挂载到/mnt/上,然后进入该目录查看光驱里的内容。

  • /opt:这是给主机额外安装软件所设置的目录,该目录默认为空。比如,你要安装一个Oracle数据库,可以放到该目录下。

  • /proc:该目录是一个虚拟目录,是系统内存的映射,可以直接访问它来获取系统信息。该目录的内容在内存里,我们可以直接修改里面的某些文件。比如可以通过下面的命令来屏蔽主机的ping命令,使其他人无法ping你的机器。在日常工作中,你会经常用到类似的用法:

    # echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
    
  • /root:该目录是系统管理员的用户家目录。

  • /run:这个目录其实和/var/run是同一个目录,这里面存放的是一些服务的pid。一个服务启动完后,是有一个pid文件的。至于为什么说是同一个目录,Linux是如何做到的,4.9节会详细介绍。

  • /sbin:s就是Super User的意思,该目录存放的是系统管理员使用的系统管理程序。

  • /srv:该目录存放的是一些服务启动之后需要提取的数据。

  • /sys:该目录存放的是与硬件驱动程序相关的信息。

  • /tmp:该目录用来存放一些临时文件。

  • /usr:这是一个非常重要的目录,类似于Windows下的Program Files目录,用户的很多应用程序和文件都存放在该目录下。后面的章节中,我们会多次用到这个目录。

  • /usr/bin:该目录存放的是系统用户使用的应用程序。

  • /usr/sbin: 该目录存放的是超级用户使用的比较高级的管理程序和系统守护程序。

  • /usr/src :该目录是内核源代码默认的放置目录。

  • /var:该目录存放的是不断扩充且经常修改的目录,包括各种日志文件或者pid文件,其中刚刚提到的/var/run就是在这个目录下面。

在Linux系统中,有几个重要的目录需要注意,不要误删除或者随意更改其内部文件。下面阿铭再简单总结一下这几个重要的目录。

  • /etc目录下是系统的配置文件,如果更改了该目录下的某个文件,可能会导致系统无法正常启动。
  • /bin、/sbin、/usr/bin和/usr/sbin目录是系统预设的执行文件的放置目录,其中/bin和/usr/bin目录下是供系统用户使用的指令(除root外的通用账户),而/sbin和/usr/sbin目录下则是供root使用的指令。比如,ls指令就存放在/bin/目录下。
  • /var也是一个非常重要的目录,系统上运行各个程序时所产生的日志都被记录在该目录下(即/var/log目录中)。另外mail指令的预设也放置在这里。

2.3.7 如何正确关机、重启

Linux主要用在服务器领域,而在服务器上执行一项服务是永无止境的,除非遇到特殊情况,否则不会关机。和Windows不同,在 Linux系统下,很多进程都是在后台执行的。在屏幕背后,可能有很多人同时在工作。如果直接按下电源开关关机,其他人的数据可能就此中断。更严重的是,若不正常关机,严重的话,可能会造成文件系统损坏,从而导致数据丢失。

如果要关机,必须要保证当前系统中没有其他用户在登录系统。我们可以使用who命令查看是否还有其他人在登录,或者使用命令ps -aux 查看是否还有后台进程运行。shutdownhaltpoweroff都为关机的命令,我们可以使用命令man shutdown查看其帮助文档。例如,可以运行如下命令关机(//符号后面的内容为解释性文字):

# shutdown -h 10  //计算机将在10分钟后关机,且会显示在登录用户的当前屏幕中
# shutdown -h now  //立即关机
# shutdown -h 20:25  //系统会在20:25关机
# shutdown -h +10  //10分钟后关机
# shutdown -r now  //立即重启
# shutdown -r +10  //10分钟后重启
# reboot  //重启,等同于shutdown -r now
# halt  //关闭系统,等同于shutdown -h now和poweroff

不管是重启系统还是关闭系统,首先要运行sync命令,它可以把当前内存中的数据写入磁盘中,防止数据丢失。

再来总结一下,关机的命令有shutdown -h nowhaltpoweroffinit 0,重启系统的命令有shutdown -r nowrebootinit 6

2.3.8 忘记root密码怎么办

以前阿铭忘记了Windows的管理员密码,当时不会用光盘清除密码,最后只能重装系统。现在想来那是多么愚笨的一件事情。同样,如果你忘记了Linux系统的root密码,该怎么办呢?重新安装系统吗?当然不用!你只需要进入emergency mode更改root密码即可。这个模式有人也叫作单用户模式,因为在CentOS 6时,我们是进入单用户模式修改root密码的。其实在CentOS 7已经没有单用户模式了,而是这个emergency模式,具体操作步骤如下。

  1. 重启系统

    3秒钟内按向下的方向键,目的是为了不让它进入系统,而是停留在开机界面,如图2-47所示。

    {%}

    图 2-47 开机界面

    按方向键移动光标,定位在第一行,按字母e编辑它,然后进入另外一个界面,此时会出来很多字符,这些都是CentOS 7启动选项,那么这些字符有什么用呢?我们暂时先放一放不用太过关心。移动向下的方向键,把光标定位到linux16开头的行,如图2-48所示。

    {%}

    图 2-48 编辑启动项

  2. 进入emergency模式

    按向右的方向键,将光标移动到ro这里,把ro改成rw init=/sysroot/bin/bash,如图2-49所示。

    {%}

    图 2-49 修改ro

    然后同时按Ctrl和x这两个键,系统就会进入如图2-50所示的界面,这样就正式进入emergency模式。

    {%}

    图 2-50 emergency模式

  3. 修改root密码

    首先切换到原始系统,然后再修改密码,操作过程如图2-51所示。

    {%}

    图 2-51 修改密码

    其中chroot命令用来切换系统,后面的/sysroot目录就是原始系统(也就是我们的CentOS 7系统),在这个下面才可以修改root密码。passwd命令就是修改root密码的命令,后续章节还会介绍它。但运行后,返回的结果很奇怪,出现了很多小方块,俗称乱码。其实这些小方块本来是汉字的,但是在VMware里面它并不支持中文。如果大家知道这个命令的用法,此时你连续输入两次新密码就ok了。但作为新用户,第一次看到肯定会不知所措。没有关系,阿铭教你如何把方块变成你能认识的字符。那就是设置语言。请跟着阿铭一起输入LANG=en,这个命令就是把当前终端的语言设置为英文。再次运行passwd命令,就可以正常显示字符了。

    密码虽然修改完了,但是还需要一个额外的操作,相关命令如下:

    # touch /.autorelabel
    

    注意,这个文件名字一定要写对,否则更改的密码将不能生效。执行这一步的作用是让SELinux生效,如果不执行,则我们修改的密码是不会生效的。也就是说,即使你输对了密码,也无法登录。至于SELinux是什么,13.4.1节会详细介绍。执行完该命令后,同时按Ctrl+D这两个键,再输入命令reboot,这样系统会重启,等待几秒后,出现登录界面,此时使用我们新设置的密码登录即可。

2.3.9 学会使用救援模式

救援模式即rescue模式,这个模式主要应用于系统无法进入的情况,比如grub损坏或者某一个配置文件修改出错。那么,如何使用rescue模式呢?具体的操作方法如下。

  1. 光盘启动

    首先检查你的光驱是否是开机启动。具体方法是把鼠标挪到VMware右下角的小光盘图标处,点击它,此时会出现两个选项,选择“设置”选项,会弹出“虚拟机设置”对话框,看一下右侧的“设备状态”,要保证两个对勾都是打上的,如图2-52所示。

    {%}

    图 2-52 设备状态

    但此时,重启系统并不会进入光驱启动界面,这还需要我们设置一个VMware的BIOS。由于VMware启动很快,往往我们还没有来得及按F2键(要进入BIOS,需要按F2键),它就已经进入系统的启动界面了。这里有一个技巧,首先把CentOS 7关机,然后在VMware左侧选中这台虚拟机并右击,从中选择“电源”→“启动时进入 BIOS”,如图2-53所示。

    {%}

    图 2-53 进入BIOS

    进入BIOS后,按向右方向键,选择Boot,然后按-或者+调节各个启动对象,其中有硬盘、光驱、网卡等,总之让CD-ROM在最前面,也就是让它第一个启动。最终的结果如图2-54所示。

    {%}

    图 2-54 BIOS

    设置完这步之后,直接按F10键保存设置并退出。

  2. 进入rescue模式

    随后进入光驱启动界面,使用上下方向键选择Troubleshooting,如图2-55所示。

    {%}

    图 2-55 Troubleshooting

    回车后,又出现如图2-56所示的界面,使用向下方向键选择Rescue a CentOS Linux system。

    {%}

    图 2-56 选择Rescue a CentOS Linux system

    连续敲两次回车,会出现如图2-57所示的界面。

    {%}

    图 2-57 rescue selection

    其中有一些提示,它告诉我们,初始系统在/mnt/sysimage下面,其实这和上一节的/sysroot类似。这里有4个选项:选择第1项将会继续往下走;选择第2项将会把初始的系统挂载为只读模式,我们不能写磁盘,也就意味着不能再修改配置文件,也不能更改root密码;选择第3项会直接出现一个shell;而选择第4项则会重启。

    这里选择第1项,所以输入数字“1”,回车后,再次回车,如图2-58所示。它又再一次告诉我们:初始系统已经挂载到了/mnt/sysimage下面,要想进入初始系统下面,需要执行chroot /mnt/sysimage命令。

    {%}

    图 2-58 获取shell

    进入初始系统后,执行修改root密码的命令passwd,如图2-59所示。

    {%}

    图 2-59 修改密码

    其实,执行完chroot命令之后,你会发现命令行前后有一处变化,即原来的sh-4.2变成了bash-4.2,这就是因为环境变量发生了变化,第10章再讨论这个知识点。当然,救援模式并非只有改root密码这么简单的作用,我们还可以在救援模式下处理一些故障、修复数据等。要想退出救援模式也很简单,先使用Ctrl+D组合键退出原始系统,然后执行reboot命令即可。但是重启后你会发现,它依然进入光驱启动界面。所以,我们还需要再设置一遍BIOS,让硬盘第一个启动。这里还有一种方法,设置VMware,关闭光驱即可。

2.4 课后习题

(1) 32位和64位操作系统有什么区别?什么时候安装32位或64位操作系统?如何查看Linux系统是32位的还是64位的?

(2) swap分区的作用是什么?如何决定swap分区的大小?

(3) 查资料了解bootloader、grub的概念,并理解它们的作用。

(4) 如何在安装系统时给grub设置密码?

(5) 在安装Linux时,你是如何分区的?

posted @ 2020-03-20 20:40  青春无语  阅读(990)  评论(0编辑  收藏  举报