Linux CentOS

目录

1、Linux概述

2、Linux 目录结构

3、远程登录到Linux

4、vi 和 vim 编辑器

5、开机、重启和用户注销

6、用户管理

7、 实用指令

7.1 指定运行级别

7.2 帮助指令(了解即可,一般都去百度)

 7.3 文件目录类

7.4 时间日期类

7.5 搜索查找类

7.6 压缩解压类

8、组管理和权限管理

9、crond任务调度

10、Linux磁盘分区、挂载

11、网络配置

12、进程管理

13、RPM和YUM



1、Linux概述

Linux 是一款操作系统免费,开源, 安全,高效,稳定, 处理高并发非常强悍,现在很多的企业级的项目都部署到 Linux/unix 服务器运行。

主要就是互联网服务端都部署在Linux系统上,所以就必须学了。

说明: 公司开发时候,具体的情况是这样的
1) linux服务器是开发小组共享的.
2) 正式上线的项目是运行在公网的.
3) 因此程序员需要远程登录到centos进行项目管理或者开发.

1.1 Linux主要发行版

总结:常用的是CentOSE, python用Ubuntu,这篇文章讲的就是CentOSE

1.2 Linux 和 Unix

Linux是Unix演变而来的

2、Linux 目录结构

linux 的文件系统是采用级层式的树状目录结构,在此结构中的最上层是根目录“/”,然后在此目录下再创建其他的目录。

记住一句经典的话:Linux 世界里,一切皆文件

 /lib
•系统开机所需要最基本的动态连接共享库,其作用类似于Windows里的DLL文件。几乎所有的应用程序都需要用到这些共享库。
/lost+found
•这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
/etc [重点]
•所有的系统管理所需要的配置文件和子目录my.conf
/usr [重点]
•这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似与windows下的program files目录。

/proc
•这个目录是一个虚拟的目录,它是系统内存的映射,访问这个目录来获取系统信息。
/boot [重点]
•存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件
/srv
•service缩写,该目录存放一些服务启动之后需要提取的数据。
/sys
•这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统sysfs
/tmp
•这个目录是用来存放一些临时文件的。
Linux目录结构

/dev
•类似于windows的设备管理器,把所有的硬件用文件的形式存储。
/media [重点]
•linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。
/mnt [重点]
•系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将外部的存储挂载在/mnt/上,然后进入该目录就可以查看里的内容了。d:/myshare

/selinux [security-enhanced linux] 360
•SELinux是一种安全子系统,它能控制程序只能访问特定文件。
/var [重点]
•这个目录中存放着在不断扩充着的东西,习惯将经常被修改的目录放在这个目录下。包括各种日志文件。
/opt
•这是给主机额外安装软件所摆放的目录。如安装ORACLE数据库就可放到该目录下。默认为空。
/usr/local [重点]
•这是另一个给主机额外安装软件所安装的目录。一般是通过编译源码方式安装的程序。

Linux 目录总结一下

(1)Linux 是以文件的形式管理我们的设备,因此 linux 系统,一切皆为文件。

(2)Linux 的各个目录存放的内容是规划好,不用乱放文件。

(3)Linux 的目录中有且只要一个根目录 /

3、远程登录到Linux

前文已经说了,程序员都是在公司的电脑上远程操作千里之外的某个机房的Linux服务器,因此需要一个远程登录软件和远程上传/下载软件

3.1 远程登录软件Linux-Xshell5

3.1.1 简介:

说明: Xshell 是目前最好的远程登录到 Linux 操作的软件,流畅的速度并且完美解决了中文乱码的问题, 是目前程序员首选的软件。

Xshell [1] 是一个强大的安全终端模拟软件,它支持 SSH1, SSH2, 以及 Microsoft Windows 平台的 TELNET 协议。

Xshell 可以在 Windows 界面下用来访问远端不同系统下的服务器,从而比较好的达到远程控制终端的目的。

特别说明:如果希望安装好 XShell 5 就可以远程访问 Linux 系统的话,需要有一个前提,就是

Linux 启用了 SSHD 服务,该服务会监听 22  号端口。

3.1.2 安装和配置

安装就是下一步就对了,很简单的。

关键配置:

Linux 启用了 SSHD 服务,该服务会监听 22  号端口。(如果没启动,就自行启动,后面会教你怎么启动监听服务)

3.2 远程上传下载文件 Xftp5

3.2.1 Xftp5简介

是一个基于 windows 平台的功能强大的 SFTPFTP 文件传输软件。使用了 Xftp  以后,windows 用户能安全地在 UNIX/Linux 和 Windows PC 之间传输文件。

3.2.2 安装与配置

安装很简单的,下一步就是了

关键配置,进入程序后,进入软件设置界面

第四章开始进入实操篇,主要讲cmd下的Linux命令

4、vi 和 vim 编辑器

4.1 vi 和 vim基本介绍

所有的 Linux 系统都会内建 vi 文本编辑器

Vim 具有程序编辑的能力,可以看做是 Vi 的增强版本,可以主动的以字体颜色辨别语法的正确性,方便程序设计。代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。

总结:vi和vim就类似于windows里面的文本文件,比windows方便的是,windows编辑了内容以后,还要调整后缀。vim编辑完保存就行了,都可以不用后缀

4.2 vi 和 vim的三种模式

(1)命令行模式
在进入一个文本之前,默认就处于命令行模式。在这个模式当中,可以提供你相关指令,完成读取、存盘、替换、离开vim 、显示行号等的动作则是在此模式中达成的!

(2)正常模式:
在命令行中,通过vim 命令打开一个文本,就直接进入一般模式了(这是默认的模式)。在这个模式中,你可以使用『上下左右』按键来移动光标,你可以使用『删除字符』或『删除整行』来处理档案内容,也可以使用『复制、贴上』来处理你的文件数据。
(3)插入模式:
进入插入模式以后,就可以编辑文本了。按下i, I, o, O, a, A, r, R等任何一个字母之后才会进入编辑模式, 一般来说按i即可.

4.3 常用快捷键(只举例常用的,需要其他的查字典)

  1. 拷贝当前行      yy ,    exp:拷贝当前行向下的 5 行并粘贴    解:5yy,并粘贴(p)。
  2. 删除当前行    dd    , exp:删除当前行向下的 5 行 解:5dd
  3. 在文件中查找某个单词  [命令行下  /关键字  , 回车  查找  ,       输入 n 就是查找下一个 ]
  4. 设置文件的行号,取消文件的行号.[命令行下    : set nu  和   :set nonu]
  5. 编辑 /etc/profile 文件,使用快捷键到底文档的最末行[G]和最首行[gg],注意这些都是在正常模式下执行的。
  6. 在一个文件中输入  "hello" ,然后又撤销这个动作,再正常模式下输入  u
  7. 编辑    /etc/profile 文件,并将光标移动到   第 20 行    shift+g

第一步:显示行号 :set nu 第二步:输入 20 这个数第三步: 输入 shift+g

特别注意:根据4.2的课,自己思考以上快捷键在哪个模式下才有效

5、开机、重启和用户注销

5.1 关机&重启命令

shutdown

shutdown -h now : 表示立即关机

halt :表示立即关机

shutdown -h 1 : 表示 1 分钟后关机

shutdown -r now:  立即重启

reboot:重启系统

syn: 把系统数据同步到磁盘

注意:当我们关机或者重启时,都应该先执行以下 sync 指令,把内存的数据写入磁盘,防止数据丢失。

5.2 用户的登录和注销

5.2.1 基本介绍

(1)登录时尽量少用 root 帐号登录,因为它是系统管理员,最大的权限,避免操作失误。可以利用普通用户登录,登录后再用”su -  用户名’命令来切换成系统管理员身份.

(2)在提示符下输入 logout 即可注销用户

注意事项:

logout 注销指令在图形运行级别无效,在 运行级别 3 下有效.(运行级别,后面有讲解)

6、用户管理

6.1 基本介绍

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

6.2 添加用户

基本语法:
(1)useradd [选项] 用户名
应用案例
1)案例1:添加一个用户xm


说明:
1)当创建用户成功后,会自动的创建和用户同名的家目录
2)也可以通过useradd -d 指定目录新的用户名,给新创建的用户指定家目录

6.3 给用户指定或者修改密码

基本语法

passwd  用户名

应用案例

1) 给xm指定密码

6.4 删除用户

基本语法:
userdel      用户名

应用案例

(1)删除用户xm,但是保留家目录(xm离职了,家目录里面可能还有很多东西嘛)

(2)删除用户xm,及其家目录下的所有文件

6.5 查询用户信息

基本语法

id 用户名

应用实例

案例 1:请查询 root用户的信息

当用户不存在时,会显示无此用户

 6.6 切换用户

在操作 Linux 中,如果当前用户的权限不够,可以通过 su - 指令,切换到高权限用户,比如 root

基本语法

su    –     切换用户名

应用实例

在root用户下创建一个用户 zf, ,指定密码,然后切换到 zf.

注意:

1)从权限高的用户切换到权限低的用户,不需要输入密码,反之需要。

2)当需要返回到原来用户时,使用 exit 指令

6.7 用户组

用户组类似于角色,系统可以对有共性的多个用户进行统一的管理(即给不同组添加删除各种操作文件和文件夹的权限)

(1)增加组

groupadd 组名

案例演示:

(2)删除组

groupdel 组名

6.8 增加用户时直接加上组

基本语法:

useradd -g 用户组 用户名

案例演示:

增加一个用户zwj,直接将他指定到wudang

注意:如果增加用户时,不分组,默认放在一个组名为自己名字的组

6.9 修改用户的组

基本语法:

usermod -g 用户组 用户名

案例演示

创建一个 shaolin 组,让将 zwj  用户从wudang组修改到 shaolin组

6.10 /etc/passwd文件

用户(user)的配置文件,记录用户的各种信息

每列的含义:用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录 Shell

6.11 /etc/shadow文件 

口令配置文件

每列的含义:登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志

6.12 /etc/group 文件

组(group)的配置文件,记录Linux包含的组的信息
每行含义:组名:口令:组标识号:组内用户列表

 

7、 实用指令

7.1 指定运行级别

运行级别说明:
0 :关机
1 :单用户【不用验证,因此可以用于找回丢失密码】
2:多用户状态没有网络服务
3:多用户状态有网络服务
4:系统未使用保留给用户
5:图形界面
6:系统重启
常用运行级别是3和5 

要修改默认的运行级别可改文件
/etc/inittab的id:5:initdefault:这一行中的数字
命令:init [012356]

7.1.1 切换到指定运行级别

基本语法

init[012356]

面试题:如何找回 root 密码,如果我们不小心,忘记 root  密码,怎么找回。

思路: 进入到 单用户模式,然后修改 root 密码。因为进入单用户模式,root 不需要密码就可以登录。

解(注意观察):

开机->在引导时输入 回车键-> 看到一个界面输入 e ->  看到一个新的界面,选中第二行(编辑内核)在输入  e->  在这行最后输入    1 ,再输入 回车键->再次输入 b ,这时就会进入到单用户模式。

这时,我们就进入到单用户模式,使用 passwd  指令来修改 root  密码。

7.2 帮助指令(了解即可,一般都去百度)

当我们对某个指令不熟悉时,我们可以使用 Linux 提供的帮助指令来了解这个指令的使用方法。

7.2.1 man指令

基本语法:

man [命令或配置文件](功能描述:获得帮助信息)

应用案例:

查看ls命令的帮助信息

解:

7.2.2 help指令

基本语法:

help 命令(功能描述:获得 shell 内置命令的帮助信息)

案例:

help和man差异 

  1. -help: 是一个工具选项,可以用来显示一些工具的信息。这些帮助信息是程序的作者加上去的,2.       也就是说,这些信息是程序内部的。一般比man出来的要简单。
  2.    man : (manual)可以显示系统手册页中的内容,这些内容大多数都是对命令的解释信息。这些信息是操作系统文档里面的。 如果没有文档,是不会显示这些帮助信息的。一般比help出来的要详细。
操作键说明
空格显示下一屏信息
回车显示下一行信息
b显示上一屏信息
f显示下一屏信息
q退出

 7.3 文件目录类

7.3.1 pwd指令

基本语法:

pwd   (功能描述:显示当前工作目录的绝对路径)

案例:显示当前工作目录的绝对路径

7.3.2 ls指令

基本语法:

ls [选项] [目录或是文件]

常用选项
-a :显示当前目录所有的文件和目录,包括隐藏的。
-l :以列表的方式显示信息
•应用实例
案例:查看当前目录的所有内容信息

7.3.3 cd指令

基本语法
(1)cd  [参数](功能描述:切换到指定目录)
•常用参数
绝对路径和相对路径


(2)cd ~ 或者cd :回到自己的家目录
(3)cd .. 回到当前目录的上一级目录

•应用实例
案例1:使用绝对路径切换到root目录

cd   /root

案例2: 使用相对路径到/root 目录

这里我们需要知道该用户目录在哪个目录下,才能写出这个指令,假设在/usr/lib

cd   ../../root
案例3:表示回到当前目录的上一级目录

cd ..
案例4:回到家目录

cd

cd   ~

7.3.4 mkdir指令

mkdir指令用于创建目录(新建文件夹)
•基本语法
mkdir  [选项]  要创建的目录
•常用选项
-p :创建多级目录
•应用实例
案例1:创建一个目录/home/dog


案例2:创建多级目录/home/animal/tiger

7.3.5 rmdir指令

rmdir指令删除空目录
•基本语法
rmdir  [选项]  要删除的空目录
•应用实例
案例1:删除一个目录/home/dog


•使用细节
rmdir 删除的是空目录,如果目录下有内容时无法删除的。
提示:如果需要删除非空目录,需要使用rm -rf 要删除的目录

7.3.6 touch指令

touch指令创建空文件
•基本语法
touch 文件名称
•应用实例
案例1: 创建一个空文件hello.txt

7.3.7 cp指令(重要)
cp 指令拷贝文件到指定目录
•基本语法
cp [选项] source dest
•常用选项
-r :递归复制整个文件夹
•应用实例
案例1: 将/home/aaa.txt 拷贝到/home/bbb 目录下


案例2: 递归复制整个文件夹,举例将/home/test 整个目录拷贝到 /home/zwj 目录

•使用细节
强制覆盖不提示的方法:\cp

7.3.8 rm指令
rm 指令移除文件或目录
•基本语法
rm [选项] 要删除的文件或目录
•常用选项
-r :递归删除整个文件夹
-f :强制删除不提示
•应用实例
案例1: 将/home/aaa.txt 删除


案例2: 递归删除整个文件夹/home/bbb

•使用细节
强制删除不提示的方法:带上-f 参数即可

7.3.9 mv指令

mv 移动文件与目录或重命名(机理:移动到同一目录,自然需要重命名)
•基本语法
mv oldNameFile newNameFile (功能描述:重命名)
mv /temp/movefile /targetFolder (功能描述:移动文件)
•应用实例
案例1: 将/home/aaa.txt 文件重新命名为pig.txt


案例2:将/home/pig.txt 文件移动到/root 目录下

7.3.10 cat指令

cat 查看文件内容,是以只读的方式打开。
•基本语法
cat [选项] 要查看的文件
•常用选项
-n :显示行号
•应用实例
案例1: /ect/profile 文件内容,并显示行号


•使用细节
cat 只能浏览文件,而不能修改文件,为了浏览方便,一般会带上管道命令| more

cat 文件名 | more [分页浏览]

7.3.11 more指令

more指令是一个基于VI编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容。more指令中内置了若干快捷键,详见操作说明

基本语法
more 要查看的文件
•操作说明


•应用实例
案例: 采用more查看文件
/etc/profile

7.3.12 less指令

less指令用来分屏查看文件内容,它的功能与more指令类似,但是比more指令更加强大,支持各种显示终端。less指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要加载内容,对于显示大型文件具有较高的效率。

基本语法
less 要查看的文件
•操作说明


•应用实例
案例: 采用less查看一个大文件文件/opt/金庸-射雕英雄传txt精校版.txt

7.3.13 >指令和>>指令

这两个指令都可以对文本内容进行更新,但是:

>输出重定向:会将原来的文件内容覆盖

>>追加:不会覆盖原来文件的内容,而是追加到文件的尾部

基本语法:

(1)ls -l>文件a(功能描述:列表的内容写入文件a.txt中(覆盖写))

说明:ls -l > a.txt , 将 ls -l 的显示的内容覆盖写入到 a.txt 文件,如果该文件不存在,就创建该文件

(2)ls -al >>文件aa       (功能描述:列表的内容追加到文件 aa.txt 的末尾)

(3)cat 文件1>文件2 (功能描述:将文件 1 的内容覆盖到文件 2)

(4)将/home目录下的文件列表写入到/home/info.txt 中

(5)将当前日历信息  追加到 /home/mycal 文件中 [提示 cal ]

7.3.14 echo指令

echo输出内容到控制台。
•基本语法
echo [选项] [输出内容]
•应用实例
案例: 使用echo 指令输出环境变量

7.3.15 head指令
head用于显示文件的开头部分内容,默认情况下head指令显示文件的前10行内容
•基本语法
head 文件(功能描述:查看文件头10行内容)
head -n 5 文件(功能描述:查看文件头5行内容,5可以是任意行数)
•应用实例
案例: 查看/etc/profile 的前面5行代码

7.3.16 tail指令

tail用于输出文件中尾部的内容,默认情况下tail指令显示文件的后10行内容。
•基本语法
1) tail 文件(功能描述:查看文件后10行内容)
2) tail -n 5 文件(功能描述:查看文件后5行内容,5可以是任意行数)
3) tail -f 文件(功能描述:实时追踪该文档的所有更新,工作中常用)
•应用实例
案例1: 查看/etc/profile 最后5行的代码


案例2: 实时监控mydate.txt , 看看到文件有变化时,是否看到,实时的追加日期

7.3.17 In指令

软链接也成为符号链接,类似于windows里的快捷方式,主要存放了链接其他文件的路径
•基本语法
ln -s [原文件或目录] [软链接名] (功能描述:给原文件创建一个软链接)
•应用实例
案例1: 在/home 目录下创建一个软连接linkToRoot,连接到/root 目录


案例2: 删除软连接linkToRoot

细节说明:

当我们使用 pwd 指令查看目录时,仍然看到的是软链接所在目录。(就像windows下,快捷方式也还是在桌面上嘛,自然看到的是桌面)

7.3.18 history指令(千万别乱来,公司可以通过这个查到)

查看已经执行过历史命令,也可以执行历史指令
•基本语法
history(功能描述:查看已经执行过历史命令)
•应用实例
案例1: 显示所有的历史命令


案例2: 显示最近使用过的10个指令。


案例3:执行历史编号为178的指令

7.4 时间日期类

7.4.1 date指令-显示当前日期

基本语法
1) date(功能描述:显示当前时间)
2) date +%Y(功能描述:显示当前年份)
3) date +%m(功能描述:显示当前月份)
4) date +%d(功能描述:显示当前是哪一天)
5) date "+%Y-%m-%d %H:%M:%S"(功能描述:显示年月日时分秒)
•应用实例
案例1: 显示当前时间信息


案例2: 显示当前时间年月日


案例3: 显示当前时间年月日时分秒

7.4.2 date指令-设置日期

基本语法
date -s 字符串时间
•应用实例
案例1: 设置系统当前时间,比如设置成2020-11-11 11:22:22

7.4.3 cal指令

查看日历指令

基本语法
cal [选项](功能描述:不加选项,显示本月日历)
•应用实例
案例1: 显示当前日历


案例2: 显示2020年日历

7.5 搜索查找类

7.5.1 find指令

find指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件或者目录显示在终端。
•基本语法
find [搜索范围] [选项]
•选项说明

应用实例
案例1: 按文件名:根据名称查找/home 目录下的hello.txt文件


案例2:按拥有者:查找/opt目录下,用户名称为nobody的文件


案例3:查找整个linux系统下大于200m的文件(+n 大于-n小于n等于)

案例4:查询 / 目录下,所有 .txt 的文件

7.5.2 locate指令

    locate指令可以快速定位文件路径。locate指令利用事先建立的系统中所有文件名称及路径的locate数据库实现快速定位给定的文件。Locate指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更新locate时刻。
•基本语法
locate 搜索文件
•特别说明
由于locate指令基于数据库进行查询,所以第一次运行前,必须使用updatedb指令创建locate数据库。
•应用实例
案例1: 请使用locate 指令快速定位hello.txt 文件所在目录

7.5.3 grep指令和管道符号|

grep 过滤查找,管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理。
•基本语法
grep [选项]查找内容源文件
•常用选项

应用实例
案例1:请在hello.txt 文件中,查找"yes" 所在行,并且显示行号

7.6 压缩解压类

7.6.1 gzip/gunzip指令

gzip 用于压缩文件,gunzip 用于解压的
•基本语法
gzip 文件(功能描述:压缩文件,只能将文件压缩为*.gz文件)
gunzip 文件.gz(功能描述:解压缩文件命令)
•应用实例
案例1:gzip压缩,将/home下的hello.txt文件进行压缩


案例2: gunzip压缩,将/home下的hello.txt.gz 文件进行解压缩

 注意:只能压缩文件,不能压缩目录,压缩后不保留 原始文件,压缩比大概1/5

7.6.2 zip/unzip指令

zip 用于压缩文件,unzip 用于解压的,这个在项目打包发布中很有用的
•基本语法
zip [选项] XXX.zip 将要压缩的内容(功能描述:压缩文件和目录的命令)
unzip [选项] XXX.zip(功能描述:解压缩文件)
•zip常用选项
-r:递归压缩,即压缩目录
•unzip的常用选项
-d<目录> :指定解压后文件的存放目录
•应用实例
案例1:将/home下的所有文件进行压缩成mypackage.zip


案例2: 将mypackge.zip 解压到/opt/tmp 目录下

注意:压缩后保留原始文件,压缩比不如gzip.

7.6.3 tar指令

tar 指令是打包指令,最后打包后的文件是.tar.gz 的文件。(gzip没法压缩目录,tar可以打包目录进去)
•基本语法
tar [选项] XXX文件名.tar.gz 打包的内容(功能描述:打包目录,压缩后的文件格式.tar.gz)
•选项说明

应用实例
案例1:压缩多个文件,将/home/a1.txt 和/home/a2.txt 压缩成a.tar.gz

案例2: 将/home 的文件夹压缩成myhome.tar.gz

案例 3:  将  a.tar.gz  解压到当前目录

8、组管理和权限管理

8.1 组的基本介绍

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

8.2 文件/目录 所有者

一般为文件的创建者,谁创建了该文件,就自然的成为该文件的所有者。

8.2.1 查看文件的所有者
1)指令:ls –ahl(all human list)

应用实例:创建一个组 police,再创建一个用户 tom,将 tom 放在 police 组 ,然后使用 tom 来创建一个文件 ok.txt,看看情况如何

8.2.2修改文件所有者
•指令:chown 用户名 文件名
•应用案例
要求:使用root 创建一个文件apple.txt ,然后将其所有者修改成tom

8.3 组的创建

基本指令
groupadd 组名
应用实例:
创建一个组, monster
创建一个用户fox ,并放入到monster组中

8.4 文件/目录 所在组

当某个用户创建了一个文件后,这个文件的所在组就是该用户用户名所在的组。
8.4.1 查看文件/目录所在组
•基本指令
ls –ahl

8.4.2 修改文件所在的组(不会修改文件的所有者)
•基本指令
chgrp 组名 文件名
•应用实例
使用root用户创建文件orange.txt ,看看当前这个文件属于哪个组,然后将这个文件所在组,修改到police组。

8.5 其他组

除文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组。

8.6 改变用户所在组

在添加用户时,可以指定将该用户添加到哪个组中,同样的用root的管理权限可以改变某个用户所在的组。
改变用户所在组
1) usermod –g 组名 用户名
2) usermod –d 目录名 用户名     改变该用户登陆的初始目录。
应用实例
创建一个土匪组(bandit)将 tom  这个用户从原来所在的 police 组,修改到 bandit(土匪) 组

8.7 权限的基本介绍

ls -l 中显示的内容如下:
-rwxrw-r--1 root root 1213 Feb 2 09:39 abc
0-9位说明
1)第0位确定文件类型(d, -, l , c , b)
2)第1-3位确定所有者(该文件的所有者)拥有该文件的权限。---User
3)第4-6位确定所属组(同用户组的)拥有该文件的权限,---Group
4)第7-9位确定其他用户拥有该文件的权限---Other

8.8 rwx权限详解

8.8.1 rwx作用到文件

1) [ r ]代表可读(read): 可以读取,查看
2) [ w ]代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件.
3) [ x ]代表可执行(execute):可以被执行

8.8.2 rwx作用到目录

1) [ r ]代表可读(read): 可以读取,ls查看目录内容
2) [ w ]代表可写(write): 可以修改,目录内创建+删除+重命名目录
3) [ x ]代表可执行(execute):可以进入该目录

8.9 文件及目录权限实际案例

ls -l 中显示的内容如下:
-rwxrw-r--1 root root 1213 Feb 2 09:39 abc
10个字符确定不同用户能对文件干什么
第一个字符代表文件类型:文件(-),目录(d),链接(l)
其余字符每3个一组(rwx) 读(r) 写(w) 执行(x)
第一组rwx : 文件拥有者的权限是读、写和执行
第二组rw-: 与文件拥有者同一组的用户的权限是读、写但不能执行
第三组r--: 不与文件拥有者同组的其他用户的权限是读不能写和执行
可用数字表示为: r=4,w=2,x=1 因此rwx=4+2+1=7
1               文件:硬连接数或目录:子目录数
root           用户
root           组
1213         文件大小(字节),如果是文件夹,显示4096字节
Feb 2 09:39 最后修改日期
abc           文件名

8.10 修改权限—chmod

基本说明:
通过chmod指令,可以修改文件或者目录的权限。
8.10.1 第一种方式:+ 、-、= 变更权限
u:所有者g:所有组o:其他人a:所有人(u、g、o的总和)
1) chmod u=rwx,g=rx,o=x 文件目录名
2) chmod o+w 文件目录名
3) chmod a-x 文件目录名
•案例演示
1) 给abc文件的所有者读写执行的权限,给所在组读执行权限,给其它组读执行权限。


2) 给abc文件的所有者除去执行的权限,增加组写的权限


3) 给abc文件的所有用户添加读的权限

8.10.2 第二种方式:通过数字变更权限
r=4 w=2 x=1 rwx=4+2+1=7
chmod u=rwx,g=rx,o=x 文件目录名
相当于chmod 751 文件目录名
•案例演示
要求:将/home/abc.txt 文件的权限修改成rwxr-xr-x, 使用给数字的方式实现:

rwx = 4+2+1 = 7

r-x = 4+1=5

r-x = 4+1 =5

指令:chmod 755 /home/abc.txt

8.11 修改文件所有者—chown

基本介绍
chown newowner file   改变文件的所有者
chown newowner:newgroup file 改变用户的所有者和所有组
-R 如果是目录则使其下所有子文件或目录递归生效
案例演示:
1)请将/home/abc .txt 文件的所有者修改成tom


2)请将/home/kkk 目录下所有的文件和目录的所有者都修改成tom

8.12 修改文件所在组—chgrp

基本介绍
chgrp newgroup file 改变文件的所有组
案例演示:
1)请将/home/abc .txt 文件的所在组修改成bandit(土匪)

chgrp bandit /home/abc.txt
2)请将/home/kkk 目录下所有的文件和目录的所在组都修改成bandit(土匪)

 

9、crond任务调度

9.1 原理示意图

crontab 进行定时任务的设置
9.2 概述
任务调度:是指系统在某个时间执行的特定的命令或程序。
任务调度分类:

(1)系统工作:有些重要的工作必须周而复始地执行。如病毒扫描等
(2)个别用户工作:个别用户可能希望执行某些程序,比如对mysql数据库的备份。
基本语法:
crontab [选项]
常用选项

9.3 快速入门

设置任务调度文件:/etc/crontab
设置个人任务调度。执行crontab –e命令。
接着输入任务到调度文件如:*/1 * * * * ls –l /etc/ > /tmp/to.txt
意思说每小时的每分钟执行ls –l /etc/ > /tmp/to.txt命令

步骤如下:

step1:cron -e

step2: */ 1 * * * * ls -l /etc >> /tmp/to.txt

step3:当保存退出后就可执行程序。

step4:在每一分钟都会自动的调用 ls -l /etc >> /tmp/to.txt

9.3.1 参数细节说明
•5个占位符的说明

特殊符号说明

特定时间执行任务案例

9.3.2 应用实例
案例1:每隔1分钟,就将当前的日期信息,追加到/tmp/mydate 文件中

Step1 :先编写一个文件         

   /home/mytask1.sh date >> /tmp/mydate

Step2:给 mytask1.sh  一个可以执行权限

chmod 744 /home/mytask1.sh

Step3:crontab -e

Step4:*/1 * * * *    /home/mytask1.sh
案例2:每隔1分钟,将当前日期和日历都追加到/home/mycal 文件中

Step1: 先编写一个文件    /home/mytask2.sh

date >> /tmp/mycal

cal >> /tmp/mycal

Step2: 给 mytask1.sh 一个可以执行权限

chmod 744 /home/mytask2.sh

Step3: crontab -e

Step4: */1 * * * *    /home/mytask2.sh

案例3: 每天凌晨2:00 将mysql数据库testdb ,备份到文件中。mydb.bak

Step1: 先编写一个文件    /home/mytask3.sh

/usr/local/mysql/bin/mysqldump -u root -proot testdb > /tmp/mydb.bak

Step2: 给 mytask3.sh 一个可以执行权限

chmod 744 /home/mytask3.sh

Step3: crontab -e

Step4: 0 2 * * *       /home/mytask3.sh

9.4 crond相关指令

1) conrtab –r:终止任务调度。

2) crontab –l:列出当前有那些任务调度

3) service crond restart [重启任务调度]

 

10、Linux磁盘分区、挂载

10.1 分区基础知识

10.1.1 分区的方式:
1) mbr分区:
1.最多支持四个主分区
2.系统只能安装在主分区
3.扩展分区要占一个主分区
4.MBR最大只支持2TB,但拥有最好的兼容性
2) gtp分区:
1.支持无限多个主分区(但操作系统可能限制,比如windows下最多128个分区)
2.最大支持18EB的大容量(1EB=1024 PB,1PB=1024 TB )
3.windows7 64位以后支持gtp

10.1.2 windows下的磁盘分区

10.2 Linux分区

10.2.1 原理介绍

1)Linux来说无论有几个分区,分给哪一目录使用,它归根结底就只有一个根目录,一个独立且唯一的文件结构, Linux中每个分区都是用来组成整个文件系统的一部分。
2)Linux采用了一种叫“载入”的处理方法,它的整个文件系统中包含了一整套的文件和目录,且将一个分区和一个目录联系起来。这时要载入的一个分区将使它的存储空间在一个目录下获得。
3)示意图

10.2.2 硬盘说明

1)Linux硬盘分IDE硬盘和SCSI硬盘,目前基本上是SCSI硬盘

2)对于IDE硬盘,驱动器标识符为“hdx~”,其中“hd”表明分区所在设备的类型,这里是指IDE硬盘了。“x”为盘号(a为基本盘,b为基本从属盘,c为辅助主盘,d为辅助从属盘),“~”代表分区,前四个分区用数字1到4表示,它们是主分区或扩展分区,从5开始就是逻辑分区。例,hda3表示为第一个IDE硬盘上的第三个主分区或扩展分区,hdb2表示为第二个IDE硬盘上的第二个主分区或扩展分区。

3)对于SCSI硬盘则标识为“sdx~”,SCSI硬盘是用“sd”来表示分区所在设备的类型的,其余则和IDE硬盘的表示方法一样。

10.2.3使用 lsblk 指令查看当前系统的分区情况

命令:lsblk 或者lsblk -f

10.3 挂载经典案例

需求是给我们的 Linux 系统增加一个新的硬盘,并且挂载到/home/newdisk下面我们以增加一块硬盘为例来熟悉下磁盘的相关指令和深入理解磁盘分区、挂载、卸载的概念。


10.3.1 如何增加一块硬盘
1)虚拟机添加硬盘
2)分区   fdisk         /dev/sdb
3)格式化   mkfs      -t ext4    /dev/sdb1
4)挂载  先创建一个  /home/newdisk   , 挂 载  mount  /dev/sdb1      /home/newdisk
5)设置可以自动挂载(永久挂载,当你重启系统,仍然可以挂载到 /home/newdisk)

vim      /etc/fstab

/dev/sdb1      /home/newdisk     ext4 defaults  0 0

10.3.2 具体操作步骤整理

Step1:在【虚拟机】菜单中,选择【设置】,然后设备列表里添加硬盘,然后一路【下一步】,中间只有选择磁盘大小的地方需要修改,至到完成。然后重启系统(才能识别)!

Step2:分区命令fdisk /dev/sdb
开始对/sdb分区
•m 显示命令列表
•p 显示磁盘分区同fdisk –l
•n 新增分区
•d 删除分区
•w 写入并退出
说明:开始分区后输入n,新增分区,然后选择p ,分区类型为主分区。两次回车默认剩余全部空间。最后输入w写入分区并退出,若不保存退出输入q。

Step3:格式化磁盘

分区命令:mkfs -t ext4 /dev/sdb1
其中ext4是分区类型

Step4:挂载:将一个分区与一个目录联系起来

命令:

(1)mount 设备名称  挂载目录

例如:mount /dev/sdb1 /newdisk

(2)umount    设备名称  或者   挂载目录

例如:umount   /dev/sdb1 或者  umount/newdisk

Step5:设置永久挂载
永久挂载: 通过修改/etc/fstab实现挂载
添加完成后执行mount –a 即刻生效
•用命令行挂载重启后会失效

10.4 磁盘情况查询

10.4.1 查询系统整体磁盘使用情况

基本语法
df -h
•应用实例
查询系统整体磁盘使用情况

10.4.2 查询指定目录磁盘占用情况

基本语法
du -h  /目录
查询指定目录的磁盘占用情况,默认为当前目录
-s指定目录占用大小汇总
-h 带计量单位
-a 含文件
--max-depth=1 子目录深度
-c 列出明细的同时,增加汇总值
•应用实例
查询/opt 目录的磁盘占用情况,深度为1

10.5 磁盘工作实用指令

1)统计/home文件夹下文件的个数


2)统计/home文件夹下目录的个数


3)统计/home文件夹下文件的个数,包括子文件夹里的


4)统计文件夹下目录的个数,包括子文件夹里的


5)以树状显示目录结构

11、网络配置

11.1 Linux网络配置原理图(含虚拟机)

目前我们的网络配置采用的是NAT

虚拟机网络模式

无论是vmware,virtual box,virtual pc等虚拟机软件,一般来说,虚拟机有三种网络模式:

1.桥接

2.NAT

3.Host-Only

初学者看到虚拟机有三种网络,估计就慌了,笔者也是。哪一种网络是适合自己的虚拟机呢?

桥接

    桥接网络是指本地物理网卡和虚拟网卡通过VMnet0虚拟交换机进行桥接,物理网卡和虚拟网卡在拓扑图上处于同等地位,那么物理网卡和虚拟网卡就相当于处于同一个网段,虚拟交换机就相当于一台现实网络中的交换机,所以两个网卡的IP地址也要设置为同一网段。

   所以当我们要在局域网使用虚拟机,对局域网其他pc提供服务时,例如提供ftp,提供ssh,提供http服务,那么就要选择桥接模式。

   例如大学宿舍里有一个路由器,宿舍里四个人连接这个路由器,路由器的wanip就不理会了,这个ip是动态获取的,而lanip默认是192.168.1.1,子网掩码是255.255.255.0。而其他四个人是自动获取ip,假设四个人的ip是:

   A:192.168.1.100/255.255.255.0,  B:192.168.1.101/255.255.255.0,  C:192.168.1.102/255.255.255.0,  D:192.168.1.103/255.255.255.0

   那么虚拟机的ip可以设置的ip地址是192.168.1.2-192.168.1.99,192.168.1.104-192.168.1.254(网络地址全0和全1的除外,再除去ABCD四个人的ip地址)

  那么虚拟机的ip地址可以设置为192.168.1.98/255.255.255.0,设置了这个ip地址,ABCD这四个人就可以通过192.168.1.98访问虚拟机了,如果虚拟机需要上外网,那么还需要配置虚拟机的路由地址,就是192.168.1.1了,这样,虚拟机就可以上外网了,但是,上网我们一般是通过域名去访问外网的,所以我们还需要为虚拟机配置一个dns服务器,我们可以简单点,把dns服务器地址配置为google的dns服务器:8.8.8.8,到此,虚拟机就可以上网了。

NAT

NAT模式中,就是让虚拟机借助NAT(网络地址转换)功能,通过宿主机器所在的网络来访问公网。

   NAT模式中,虚拟机的网卡和物理网卡的网络,不在同一个网络,虚拟机的网卡,是在vmware提供的一个虚拟网络。

   NAT和桥接的比较:

   (1) NAT模式和桥接模式虚拟机都可以上外网。

   (2) 由于NAT的网络在vmware提供的一个虚拟网络里,所以局域网其他主机是无法访问虚拟机的,而宿主机可以访问虚拟机,虚拟机可以访问局域网的所有主机,因为真实的局域网相对于NAT的虚拟网络,就是NAT的虚拟网络的外网,不懂的人可以查查NAT的相关知识。

   (3) 桥接模式下,多个虚拟机之间可以互相访问;NAT模式下,多个虚拟机之间也可以相互访问。

   如果你建一个虚拟机,只是给自己用,不需要给局域网其他人用,那么可以选择NAT,毕竟NAT模式下的虚拟系统的TCP/IP配置信息是由VMnet8(NAT)虚拟网络的DHCP服务器提供的,只要虚拟机的网路配置是DHCP,那么你不需要进行任何其他的配置,只需要宿主机器能访问互联网即可,就可以让虚拟机联网了。

  例如你想建多个虚拟机集群,作为测试使用,而宿主机可能是一个笔记本,ip不固定。这种应用场景,我们需要采用nat模式了,但是我们要考虑一个问题,虚拟机之间是需要互访的,默认采用dhcp,虚拟机的ip每次重启,ip都是不固定的,所以我们需要手工设置虚拟机的ip地址。

  但是我们对虚拟机网卡所在的虚拟网络的信息还一无所知,例如虚拟机网络的路由地址,子网掩码,所以我们需要先查下nat虚拟网络的信息。

  使用vmware,在Edit->Virtual Network Editor中配置好虚拟网络信息后看到下图所示,注意VMnet8,VMnet8相当于是本机的一个路由,虚拟机设置NAT后就通过这个路由进行上网的,可以查看其网络地址,路由地址,子网掩码。

  选择VMnet8->NAT设置,可以看到子网ip显示为192.168.233.0,子网掩码是255.255.255.0,那路由地址呢,其实就是网关IP了,都是同个东西,这里是192.168.233.2。

  接下来就好办了,在对应的虚拟机设置好ip,子网掩码,路由地址就可以上外网了,至于dns可以设置为8.8.8.8.

Host-Only

 在Host-Only模式下,虚拟网络是一个全封闭的网络,它唯一能够访问的就是主机。其实Host-Only网络和NAT网络很相似,不同的地方就是Host-Only网络没有NAT服务,所以虚拟网络不能连接到Internet。主机和虚拟机之间的通信是通过VMware Network Adepter VMnet1虚拟网卡来实现的。

  Host-Only的宗旨就是建立一个与外界隔绝的内部网络,来提高内网的安全性。这个功能或许对普通用户来说没有多大意义,但大型服务商会常常利用这个功能。如果你想为VMnet1网段提供路由功能,那就需要使用RRAS,而不能使用XP或2000的ICS,因为ICS会把内网的IP地址改为192.168.0.1,但虚拟机是不会给VMnet1虚拟网卡分配这个地址的,那么主机和虚拟机之间就不能通信了。

综述

  在VMware的3中网络模式中,NAT模式是最简单的,基本不需要手动配置IP地址等相关参数。至于桥接模式则需要额外的IP地址,如果是在内网环境中还很容易,如果是ADSL宽带就比较麻烦了,ISP一般是不会大方的多提供一个公网IP的。

11.2 查看网络IP和网关

11.2.1 查看虚拟网络管理器

11.2.2 修改ip地址(修改虚拟网络的ip)

11.2.3 查看网关

11.3 查看 windows 环境的中 VMnet8 网络配置 (ipconfig 指令)

(1)使用ipconfig查看

(2)界面查看

 11.4 ping测试主机之间网络的连通性

基本语法
ping 目的主机(功能描述:测试当前服务器是否可以连接目的主机)
应用实例
测试当前服务器是否可以连接百度
[root@hadoop100 桌面]# ping www.baidu.com

11.5 Linux网络环境配置

11.5.1 第一种方法(自动获取):


说明:登陆后,通过界面的来设置自动获取ip
缺点:linux启动后会自动获取IP,缺点是每次自动获取的ip地址可能不一样。这个不适用于做服务器,因为我们的服务器的 ip 需要时固定的。

11.5.2 第二种方法(指定固定的ip)
说明:
直接修改配置文件来指定IP,并可以连接到外网(程序员推荐),编辑vi /etc/sysconfig/network-scripts/ifcfg-eth0
要求:将ip地址配置的静态的,ip地址为192.168.184.130

修改后,一定要 重启服务

(1)service network restart

(2)reboot 重启系统

11.6 防火墙设置

查看开放的端口号

firewall-cmd --list-all

设置开放的端口号

firewall-cmd --add-service=http –permanent

firewall-cmd --add-port=80/tcp --permanent

重启防火墙

firewall-cmd –reload

12、进程管理

12.1 进程的基本介绍

1)在LINUX中,每个执行的程序(代码)都称为一个进程。每一个进程都分配一个ID号。

2)每一个进程,都会对应一个父进程,而这个父进程可以复制多个子进程。例如www服务器。

3)每个进程都可能以两种方式存在的。前台与后台,所谓前台进程就是用户目前的屏幕上可以进行操作的。后台进程则是实际在操作,但由于屏幕上无法看到的进程,通常使用后台方式执行。

4)一般系统的服务都是以后台进程的方式存在,而且都会常驻在系统中。直到关机才才结束。

12.2 显示系统执行的进程

查看进行使用的指令是  

ps ,一般来说使用的参数是 ps -aux

 12.2.1 ps指令详解

1)指令:ps –aux|grep xxx ,比如我看看有没有sshd服务
2)指令说明
•System V展示风格
•USER:用户名称
•PID:进程号
•%CPU:进程占用CPU的百分比
•%MEM:进程占用物理内存的百分比
•VSZ:进程占用的虚拟内存大小(单位:KB)
•RSS:进程占用的物理内存大小(单位:KB)
•TT:终端名称,缩写.
•STAT:进程状态,其中S-睡眠,s-表示该进程是会话的先导进程,N-表示进程拥有比普通优先级更低的优先级,R-正在运行,D-短期等待,Z-僵死进程,T-被跟踪或者被停止等等
•STARTED:进程的启动时间
•TIME:CPU时间,即进程使用CPU的总时间
•COMMAND:启动进程所用的命令和参数,如果过长会被截断显示

12.2.3 应用实例

要求:以全格式显示当前所有的进程,查看进程的父进程。


•ps -ef是以全格式显示当前所有的进程
•-e 显示所有进程。-f 全格式。
•ps -ef|grep xxx
•是BSD风格
•UID:用户ID
•PID:进程ID
•PPID:父进程ID
•C:CPU用于计算执行优先级的因子。数值越大,表明进程是CPU密集型运算,执行优先级会降低;数值越小,表明进程是I/O密集型运算,执行优先级会提高
•STIME:进程启动的时间
•TTY:完整的终端名称
•TIME:CPU时间
•CMD:启动进程所用的命令和参数

思考题,如果我们希望查看 sshd 进程的父进程号是多少,应该怎样查询 ?

12.3 终止进程kill和killall

12.3.1 介绍

若是某个进程执行一半需要停止时,或是已消了很大的系统资源时,此时可以考虑停止该进程。使用kill命令来完成此项任务。
基本语法:
kill [选项] 进程号(功能描述:通过进程号杀死进程)
killall 进程名称(功能描述:通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用)
常用选项:
-9 :表示强迫进程立即停止
最佳实践:
案例1:踢掉某个非法登录用户


案例2: 终止远程登录服务sshd, 在适当时候再次重启sshd服务


案例3: 终止多个gedit 编辑器【killall ,  通过进程名称来终止进程】


案例4:强制杀掉一个终端

12.4 查看进程树 pstree

基本语法:
pstree [选项] ,可以更加直观的来看进程信息
常用选项:
-p :显示进程的PID
-u :显示进程的所属用户
应用实例:
案例1:请你树状的形式显示进程的pid


案例2:请你树状的形式进程的用户id

pstree -u 即可

12.5 服务(service)管理

服务(service) 本质就是进程,但是是运行在后台的,通常都会监听某个端口,等待其它程序的请求,比如(mysql , sshd 防火墙等),因此我们又称为守护进程,是Linux中非常重要的知识点。【原理图】


service管理指令:
service 服务名[start | stop | restart | reload | status]
在CentOS7.0后不再使用service ,而是systemctl
使用案例:
1) 查看当前防火墙的状况,关闭防火墙和重启防火墙。


细节讨论:
1)关闭或者启用防火墙后,立即生效。[telnet 测试某个端口即可]


2)这种方式只是临时生效,当重启系统后,还是回归以前对服务的设置。
3)如果希望设置某个服务自启动或关闭永久生效,要使用chkconfig指令,马上讲。

12.5.1 查看服务名

方式1:使用setup -> 系统服务就可以看到。或者直接使用ntsysv命令,可进入系统服务


方式2: /etc/init.d/服务名称

12.5.2 服务的运行级别

Linux系统有7种运行级别(runlevel):常用的是级别3和5
•运行级别0:系统停机状态,系统默认运行级别不能设为0,否则不能正常启动
•运行级别1:单用户工作状态,root权限,用于系统维护,禁止远程登陆
•运行级别2:多用户状态(没有NFS),不支持网络
•运行级别3:完全的多用户状态(有NFS),登陆后进入控制台命令行模式
•运行级别4:系统未使用,保留
•运行级别5:X11控制台,登陆后进入图形GUI模式
•运行级别6:系统正常关闭并重启,默认运行级别不能设为6,否则不能正常启动

开机流程说明:

.

12.5.3 chkconfig指令

介绍
通过chkconfig 命令可以给每个服务的各个运行级别设置自启动/关闭
•基本语法
1) 查看服务chkconfig    --list|grep xxx
 

2) chkconfig 服务名--list

3) chkconfig --level 5 服务名on/off

请将 sshd 服务在运行级别为 5 的情况下,不要自启动。

案例 1: 请显示当前系统所有服务的各个运行级别的运行状态

bash> chkconfig --list

案例 2 :请查看 sshd 服务的运行状态

bash> service sshd status

案例 3: 将 sshd 服务在运行级别 5 下设置为不自动启动,看看有什么效果?

bash> chkconfig --level 5 sshd off

案例 4: 当运行级别为 5 时,关闭防火墙。

bash> chkconfig    --level 5    iptables off

案例 5: 在所有运行级别下,关闭防火墙

bash> chkconfig  iptables off

6) 案例 6: 在所有运行级别下,开启防火墙

bash> chkconfig   iptables  on

使用细节
1) chkconfig重新设置服务后自启动或关闭,需要重启机器reboot才能生效.

12.6 动态监控进程

12.6.1 介绍:
top与ps命令很相似。它们都用来显示正在执行的进程。Top与ps最大的不同之处,在于top在执行一段时间可以更新正在运行的的进程。

基本语法:
top [选项]
选项说明:

交互操作说明:

应用实例:
案例1.监视特定用户

top:输入此命令,按回车键,查看执行的进程。

u:然后输入“u”回车,再输入用户名,即可


案例2:终止指定的进程。

top:输入此命令,按回车键,查看执行的进程。

k:然后输入“k”回车,再输入要结束的进程ID号


案例3:指定系统状态更新的时间(每隔10秒自动更新):

bash> top -d 10

12.6.2 查看系统网络情况netstat(重要)

基本语法
netstat [选项]

netstat -anp
•选项说明
-an 按一定顺序排列输出
-p 显示哪个进程在调用
•应用案例

(1)查看系统所有的网络服务


(2)请查看服务名为sshd 的服务的信息。

检测主机连接命令ping:是一种网络检测检测工具,它主要是用检测远程主机是否正常,或是两部主机间的介质是否为断、网线是否脱落或网卡故障。
如: ping 对方ip地址

13、RPM和YUM

13.1 rpm包的管理

13.1.1 介绍:
一种用于互联网下载包的打包及安装工具,它包含在某些Linux分发版中。它生成具有.RPM扩展名的文件。RPM是RedHat Package Manager(RedHat软件包管理工具)的缩写,类似windows的setup.exe,这一文件格式名称虽然打上了RedHat的标志,但理念是通用的。
Linux的分发版本都有采用(suse,redhat, centos 等等),可以算是公认的行业标准了。

13.1.2 rpm包的简单查询指令:
查询已安装的rpm列表      rpm –qa|grep xx

请查询看一下,当前的 Linux 有没有安装 firefox

13.1.3 rpm包名基本格式:
一个rpm包名:firefox-45.0.1-1.el6.centos.x86_64.rpm
名称:firefox
版本号:45.0.1-1
适用操作系统: el6.centos.x86_64
表示centos6.x的64位系统
如果是i686、i386表示32位系统,noarch表示通用。

13.1.4 rpm包的其他查询指令:

rpm -qa :查询所安装的所有rpm软件包
rpm -qa | more   分页显示
rpm -qa | grep X [rpm -qa | grep firefox ]


rpm -q 软件包名:查询软件包是否安装
rpm -q firefox
rpm -qi 软件包名:查询软件包信息

rpm -qi file

rpm -ql 软件包名:查询软件包中的文件
rpm -ql firefox


rpm -qf 文件全路径名查询文件所属的软件包
rpm -qf /etc/passwd
rpm -qf /root/install.log

13.1.5 卸载rpm包:
•基本语法
rpm -e RPM包的名称
•应用案例
1)删除firefox 软件包


•细节讨论
1) 如果其它软件包依赖于您要卸载的软件包,卸载时则会产生错误信息。
如:$ rpm -e foo
removing these packages would break dependencies:foo is needed by bar-1.0-1
2) 如果我们就是要删除foo这个rpm 包,可以增加参数--nodeps ,就可以强制删除,但是一般不推荐这样做,因为依赖于该软件包的程序可能无法运行
如:$ rpm -e --nodeps foo

带上 --nodeps  就是强制删除。

13.1.6 安装rpm包:
•基本语法
rpm -ivh RPM包全路径名称
•参数说明
i=install 安装
v=verbose 提示
h=hash 进度条
•应用实例

1) 演示安装 firefox 浏览器

步骤先找到 firefox 的安装 rpm 包,你需要挂载上我们安装 centos 的 iso 文件,然后到/media/下去找 rpm 找 。

cp firefox-45.0.1-1.el6.centos.x86_64.rpm /opt/

13.2 yum
13.2.1 介绍:
Yum 是一个Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并
且一次安装所有依赖的软件包。


13.2.2 yum的基本指令
•查询yum服务器是否有需要安装的软件
yum list|grep xx软件列表
•安装指定的yum包
yum install xxx 下载安装

13.2.3yum应用实例:
案例:请使用yum的方式来安装firefox

(1)先查看一下  firefox       rpm 在 yum 服务器有没有

(2)安装

yum install firefox

会安装最新版本的软件。成功!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值