Linux的学习笔记(学习于尚硅谷)

当前的IT行业,各个企业的应用服务都是跑在服务器上的,服务器其实就是一种特殊的电脑,服务器的操作系统目前绝大多数都是Linux,不管哪个行业,只要和服务器打交道,就必须了解Linux。


笔记内容:
入门篇:Linux概述、安装
基础篇:文件与目录结构、VI/VIM编辑器、网络配置、系统管理、远程登录
实操篇:文件目录类、时间日期类、用户管理类、文件权限类、磁盘分区类、进程线程类
扩展篇:软件包管理、克隆虚拟机

Linux发行版本:基于CentOS7


入门篇

1.Linux概述

①Linux是一个操作系统(OS),所谓操作系统,就是直接用来操作计算机底层硬件的软件

②计算机硬件-->操作系统核心层kernel(硬件接口层)-->命令解释层(shell)-->外围应用层

流程分析:整个计算机的最底层是:计算机硬件,我们操作电脑最终就是转换成指令去操作计算机硬件。那什么东西能直接操作硬件呢?就是操作系统。所以在计算机硬件之外必须有一个硬件的接口层,即操作系统的核心层kernel(Linux kernel)。实际要用一个操作系统的时候,肯定在其之上还应该有各种各样的应用程序,这些应用软件要和底层的操作系统内核交流、通讯,所以在kernel层的外面还应有一个媒介(接口):shell(命令解释层)。shell的作用是连接外部的应用程序和内层的操作系统内核,最外层就是外围的应用层。

③主流的、市面上常见的Linux发行版本:

Red Hat(不太关注桌面,性能稳定强悍)是一系列的软件:RedHatEnterpriseLinux(RHEL);fedoro、CentOS(这两者免费)

debian:ubuntu(基于debian发展出来的,免费的),有非常好用的桌面

2.Linux安装

VMware虚拟机的下载

Linux的学习笔记(学习于尚硅谷)_第1张图片

 CentOS7.9的下载

Linux的学习笔记(学习于尚硅谷)_第2张图片

创建虚拟机需要主机开启虚拟化,如果没打开,需要在BIOS设置里面把对应的虚拟化选项开启

Linux的学习笔记(学习于尚硅谷)_第3张图片

附件选择

 Linux的学习笔记(学习于尚硅谷)_第4张图片

分区:

/boot: 引导分区,系统启动时靠它进行快速的启动

/:根分区

swap:虚拟内存

 Linux的学习笔记(学习于尚硅谷)_第5张图片

打开终端的两种方式:

1.打开仿真终端:右键桌面打开终端,在命令行中输入init 3(3是运行级别的意思)

2.打开底层终端(大黑屏):ctrl+alt+f2~f6,然后登陆,此时鼠标消失,如果想使用鼠标就ctrl+alt;

3.退出终端回到图形化界面:ctrl+fn+alt+f1或init 5

[root@redis100 ~]# :用户root和主机名redis100,~是当前所在的位置(当前用户的主文件夹),#是输入命令的提示符号

基础篇

3.文件与目录结构

①linux的文件系统是采用级层式的树状目录结构,在此结构中的最上层是根目录" / ",然后在此目录下再创建其他的目录。深刻理解linux树状文件目录是非常重要的,在Linux世界里,一切皆文件

②具体的目录结构:

/bin [重点] (/usr/bin 、 /usr/local/bin):是Binary的缩写, 该目录存放着最经常使用的命令。

/sbin (/usr/sbin 、 /usr/local/sbin):s就是Super User的意思,这里存放的是系统管理员使用的系统管理程序。

/home [重点]:存放普通用户的主目录,在Linux中每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。

/root [重点]:该目录为系统管理员,也称作超级权限者的用户主目录。

/lib:系统开机所需要最基本的动态连接共享库,其作用类似于Windows里的DLL文件。几乎所有的应用程序都需要用到这些共享库。

/lost+found:该目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。

/etc [重点]:所有的系统管理所需要的配置文件和子目录 my.conf。

/usr [重点]: 这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似与windows下的program files目录。

/boot [重点]:存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件

/proc:这个目录是一个虚拟的目录,它是系统内存的映射,访问这个目录来获取系统信息

/srv:service缩写,该目录存放一些服务启动之后需要提取的数据

/sys:这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs。

/tmp:这个目录是用来存放一些临时文件的。

/dev:类似于windows的设备管理器,把所有的硬件用文件的形式存储。

/media [重点]:linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。

/mnt [重点]:系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将外部的存储挂载在/mnt/上,然后进入该目录就可以查看里的内容了。 d:/myshare

/opt:这是给主机额外安装软件所摆放的目录。如安装ORACLE数据库就可放到该目录下。默认为空。

/usr/local [重点]:这是另一个给主机额外安装软件所安装的目录。一般是通过编译源码方式安装的程序。

/var [重点]: 这个目录中存放着在不断扩充着的东西,习惯将经常被修改的目录放在这个目录下。包括各种日志文件。

/selinux [security-enhanced linux] 360:SELinux是一种安全子系统,它能控制程序只能访问特定文件 。

4.VI/VIM编辑器

Linux的学习笔记(学习于尚硅谷)_第6张图片

①vi 和vim常用的三种模式的简单介绍:
正常模式:vim xxx进去之后看到的页面就是正常模式,不能直接编辑文本,主要操作是:删除、复制、粘贴,在正常模式下使用u是撤回操作

编辑模式:在一般模式下使用i、a或b,进入编辑模式,主要操作:编辑文本

命令模式:在一般模式下使用:或者/,然后进行命令操作,:wq、:q:退出、:ql、:w:保存

退出编辑模式、命令模式,回到正常模式:ESC

退出VI/VIM编辑器::q

切换输入法:super(windows)+空格

:set nu :显示行号

:set nonu:去除行号显示

②三种模式的常用具体操作

A.正常模式:删除、复制、粘贴

语法: 功能描述:
yy 复制光标当前行
y数字y 复制一段(从光标当前行到后n行)
p 箭头移动到目的行粘贴,粘贴到光标的下一行
u 撤销上一步
dd 删除光标当前行
d数字d 删除光标(含)后多少行
x 剪切一个字符(当前光标),相当于del
X 剪切一个字符(当前光标的前一个),相当于Backspace
yw yw复制一个词(要从单词首字母开始使用)
y+$(shift+4) 复制从当前光标位置开始到当前行结束所有的内容
y+^(shift+6) 复制从开头到当前光标位置中间的所有内容
dw dw删除一个词(要从单词首字母开始使用)
shift+6(^) 移动到行头
shift+4($) 移动到行尾
r 更改当前光标位置的字符
R(shift+r) 依次替换
w 移动到下一个词的词头位置
e 移动到当前词的词尾
gg 移动到页头
G 移动到页尾
数字N+G 移动到目标

B.编辑模式

语法: 功能描述:
i 当前光标前
a 当前光标后
o 当前光标行的下一行
I(shift+i) 光标所在行最前
A 光标所在行最后
O 当前光标行的上一行

C.命令模式

语法: 功能描述:
:w 保存
:q 退出编辑模式
:wq 保存并退出
:q! 不保存强制退出
/要查找的词 n查找下一个,N往上查找
:noh 取消高亮显示
:set nu 显示行号
:set nonu 关闭行号
:s/old/new 替换当前行匹配到的第一个old为new
:s/old/new/g 替换当前行匹配到的所有old为new
:%s/old/new 替换文档中每一行匹配到的第一个old为new
:%s/old/new/g

替换文档中匹配到的所有old为new

5.网络配置

①ping的操作,测试主机和虚拟机能否连接通信

②VMnet8:pc主机虚拟出来的网卡,接到虚拟子网的路由上,使pc主机与虚拟机属于同一网段内,使主机能够与VM(虚拟机)通信

③修改静态IP:为每个虚拟机(服务器的ip)赋予一个固定值,更改静态ip是在子网的ip,不是以太网的ip,以太网的ip是外部上网的ip,所以更改的是VMnet8的ip。设置静态IP主要是为了方便连接时不用去查询ip。那么是谁连接谁呢?是主机远程操控服务器(虚拟机),这个时候连接虚拟机,所以是把虚拟机的ip设成静态的。

④如何在虚拟机里指定静态ip:

A.图形化界面

B.终端中:vim /etc/sysconfig/network-scripts/ifcfg-ens33

BOOTPROTO="static"
#IP地址
IPADDR="192.168.56.100"
#网关
GATEWAY="192.168.56.2"
#域名解析器
DNS1="192.168.56.2"

更改完之后需要重启:service network restart
⑤配置主机名:

方式一:vim /etc/hostname,进行修改,修改完之后需要重启服务

方式二:hostnamectl set-hostname 主机名

⑥在hosts文件里添加主机名和ip的映射关系:vim /etc/hosts

192.168.56.100 redis100
192.168.56.101 redis101
192.168.56.102 redis102
192.168.56.103 redis103
192.168.56.104 redis104

注意:在虚拟机里面的更改,在主机里面也要做相应的更改(因为主机也要与这些虚拟机通信)

6.系统管理

①linux中的进程和服务

计算机中,一个正在执行的程序或命令,被叫做进程(process),启动之后一直存在、常驻内存的进程,一般称作服务(service),具体执行这些服务的进程叫做守护进程

②service服务管理(CentOS6版本 -了解即可)

A.基本语法:service 服务名 start|stop|restart|status

B.经验技巧:

查看服务的方法:/etc/init.d/服务名,指令:ls /etc/init.d/

C.实例实操:

③systemctl(CentOS7版本 -重点掌握)

A.基本语法:systemctl start|stop|restart|status 服务名

B.经验技巧:

查看服务的方法:/usr/lib/systemd/system,指令:/usr/lib/systemd/system

C.实例实操:

④指令:setup,配置服务的开机自启动选项

Linux的学习笔记(学习于尚硅谷)_第7张图片

[*]  表示当前服务开机自启动,[ ] 表示当前服务开机不会启动,空格可以对其做更改

 Linux的学习笔记(学习于尚硅谷)_第8张图片

 ⑤系统的启动过程以及运行级别

A.开机----BIOS自检和启动----/boot中获取引导文件和kernal中的内容进行系统初始化----启动init进程----判断运行级别----启动运行级别对应的服务

B.CentOS6中的7种运行级别,常用的是3和5,级别越高功能越强大(6除外)

运行级别0:系统停机状态,系统默认运行级别不能设为0,否则不能正常启动

运行级别1:单用户工作状态,只允许root用户登录,禁止远程登录,所以只能root用户在实体的物理机上进行系统的维护,做一些相关权限更改以及比较重要的系统管理的操作,类似于windows下的安全模式。

运行级别2:多用户状态(没有NFS:网络文件系统),不支持网络

运行级别3:完全的多用户状态(有NFS),登录后进入控制台命令行模式

运行级别4:系统未使用,保留

运行级别5:X11控制台,登录后进入图形GUI模式

运行级别6:系统正常关闭并重启,默认运行级别不能设为6,否则不能正常启动

C.CentOS7的运行级别简化为:(target表示为一组服务的集合)

multi-user.target 等价于原运行级别3(多用户有网,无图形界面)

graphical.target 等价于原运行级别5(多用户有网,有图形界面)

D.查看当前运行级别的指令:systemctl get-default

E.修改当前运行级别的指令:systemctl set-default TARGET.target(TARGET可以是multi-user或graphical)

F.常用指令:

查看所有服务能否开机自启动的信息:systemctl list-unit-files

设置开机自启动:systemctl enable 服务名

设置开机不启动:systemctl disable 服务名

实战:配置防火墙开机是否自启动:status、stop、disable、enable

I.先看一下防火墙的状态:systemctl status  firewalld

⑥关机重启命令:在linux'领域内大多用在服务器上,很少遇到关机的操作。毕竟服务器上跑一个服务是永无止境的,除非特殊情况下,不得已才关机。

语法 功能描述
sync 将数据由内存同步到硬盘中
halt 停机,关闭系统,但不关闭电源
poweroff 关机,断电
reboot 重启,等同于shutdown -r now
shutdown now 立刻关机
shutdown[选项] 时间
选项 功能
-H 相当于--halt,停机
-r

-r=reboot,重启

-c 取消关机

7.远程登录

①做完网络配置就可以尝试进行远程的登录,操作自己的服务器(虚拟机),最经典最简单的远程登录方式ssh:ssh root@redis100,也可以使用远程登录工具Xshell等,都是基于ssh协议进行免密登录。

Linux的学习笔记(学习于尚硅谷)_第9张图片

②上传下载文件,使用Xshell的配套工具xftp,基于ftp协议(远程的传输文件的工具)

附加:常用基本命令(重要)

shell可以看作是一个命令解释器,为我们提供了交互式的文本控制台界面。我们可以通过终端控制台来输入命令,由shell进行解释并最终交给内核执行。下面将介绍常用的基本shell命令。

①帮助命令

A.man 获得帮助信息

基本语法:man [命令或配置文件]   ,比如查看ls命令的帮助信息:man ls

B.help获得shell内置命令的帮助信息

一部分基础功能的系统命令是直接内嵌在shell内的,比如cd,exit,系统加载启动之后会随着shell一起加载,常驻系统内存中。这部分命令被称为“内置(built-in)命令”;相应的其他命令被称为"外部命令",比如ls。使用type去区分内置命令和外部命令

基本语法:help 命令 (功能描述:获得shell内置命令的帮助信息),比如查看cd命令的帮助信息:help cd(man -f cd)

C.linux的shell常用的快捷键

常用快捷键 功能
ctrl+c 停止进程
ctrl+l 清屏,等同于clear;彻底清屏是reset
善于用tab键 提示,补全,更重要的是可以防止敲错
上下键 查找执行过的命令

实操篇

8.文件目录类

pwd(内置命令显示当前工作目录的绝对路径,print working directory 打印工作目录

ls 列出目录的内容,基本语法:ls [选项] [目录或文件],比如 ls -l /bin | grep sh

选项 功能
-a 全部的文件,连同隐藏档(开头为 . 的文件)一起列出来(常用)
-l 长数据串列出,包含文件的属性与权限等数据(常用),等价于" ll (io)"

cd 切换目录,change directory 切换路径,基本语法:cd [参数]

参数 功能
cd 绝对路径 切换路径
cd 相对路径 切换路径
cd ~或者cd 回到当前用户的主文件夹目录
cd - 回到上一次所在目录
cd .. 回到当前目录的上一级目录
cd -P 跳转到实际物理路径,而非快捷方式路径

mkdir 创建一个新目录,Make directory 建立目录,基本语法:mkdir [选项] 要创建的目录选项说明:-p  创建多层目录

比如:mkdir xiyou(创建一个目录);mkdir -p xiyou/dssz/meihouwang(创建一个多级目录)。

rmdir 删除一个空的目录,Remove directory 移除目录,基本语法:rmdir 要删除的目录

比如:rmdir xiyou/dssz/meihouwang(删除一个空的文件夹)

touch 创建空文件,基本语法:touch 文件名称

比如:touch xiyou/dssz/sunwukong.txt

cp 复制文件或目录(copy)

基本语法:cp [选项] source dest,功能描述:复制source文件到dest

选项说明:-r 递归复制整个文件夹

参数说明:source 源文件;dest 目标文件

经验技巧:强制覆盖不提示的方法:\cp 

rm 删除文件或目录

基本语法:rm [选项] deleteFile,功能描述:递归删除目录中所有内容

选项说明:

        -r 递归删除目录中的所有内容

        -f 强制执行删除操作,而不提示用于进行确认

        -v 显示指令的详细执行过程

mv 移动文件与目录或重命名

基本语法:mv oldNameFile  newNameFile,功能:重命名

mv /temp/movefile   /targetFolder,功能:移动文件

实例实操:

重命名:mv xiyou/dssz/sunwukong.txt xiyou/dssz/houge.txt

移动文件:mv xiyou/dssz/houge.txt ./

cat 查看文件内容,从第一行开始显示

基本语法:cat [选项] 要查看的文件

选项说明:-n 显示所有行的行号,包括空行

经验技巧:一般查看比较小的文件,一屏幕能显示全的

实例实操:查看文件内容并显示行号:cat -n houge.txt

11.more 文件内容分屏查看器

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

基本语法:more 要查看的文件

操作说明

操作 功能说明
空白键(space) 代表向下翻一页
Enter 代表向下翻一行
q 代表立刻离开more,不再显示该文件内容
f 向下滚动一屏
b 返回上一屏
= 输出当前行的行号
:f 输出文件名和当前行的行号

12.less 分屏显示文件内容

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

基本语法:less 要查看的文件

操作说明:

操作 功能说明
空白键 向下翻动一页
[pagedown] 向下翻动一页
[pageup] 向上翻动一页
/字串 向下搜寻[字串]的功能;n:向下查找,N:向上查找
?字串

向上搜寻[字串]的功能;n:向上查找,N:向下查找

13.echo 输出内容到控制台

基本语法:echo [ 选项] [输出内容]

选项:-e 支持反斜线控制的字符转换

\\        输出\本身

\n        换行符

\t        制表符,也就是tab键

实例实操:echo "hello\tworld" 结果是:hello\tworld

echo -e "hello\tworld" 结果是:hello        world

echo $ 然后按tab:查看所有的系统环境变量

14.head 显示文件开头部分内容,默认情况下head指令显示文件的前10行内容

基本语法:head 文件,功能:查看文件头10行内容

head -n 行数 文件,功能:查看文件头n行内容

15.tail 输出文件尾部内容,默认情况下tail指令显示文件的后10行内容

基本语法:tail 文件,功能:查看文件尾部10行内容

tail -n 行数 文件,功能:查看文件尾部n行内容

tail -f 文件,功能:实时追踪该文档的所有更新,ctrl+s暂时的停止监控,ctrl+q继续监控,ctrl+c退出监控。

16.> 输出重定向  和   >> 追加

比如:ls > 文件 ,功能:将ls查看信息写入文件中,覆盖写

ll >>文件,功能:ls查看的详细信息追加到文件的末尾

cat 文件1 > 文件2,功能:将文件1的内容覆盖到文件2

echo  "内容" >> 文件,功能:将内容追加到文件

17.ln 软链接 ,也称为符号链接,类似于windows里的快捷方式,有自己的数据块,主要存放了链接其他文件的路径

基本语法:ln -s [原文件或目录] [软链接名] ,功能:给原文件创建一个软链接

经验技巧:

删除软链接:rm -rf 软链接名,而不是rm -rf 软链接名/

如果使用 rm -rf 软链接名/ 删除,会把软链接对应的真实目录下内容删掉

查询:通过ll就可以查看,列表属性第1位是l,尾部会有位置指向

18.history 查看已经执行过得历史命令

基本语法:history ,功能:查看已经执行过得历史命令   

history -c ,清空历史命令                                  

9.时间日期类

基本语法:date [选项] [+格式]

选项说明:

-d<时间字符串>    显示指定的“时间字符串”表示的时间,而非当前时间

-s<日期时间>        设置系统日期时间

参数说明:

<+日期时间格式>  指定显示时使用的日期时间格式

①.date 显示当前时间

基本语法:

        date                 显示当前时间

        date +%Y         显示当前年份

        date +%m        显示当前月份

        date +%d         显示当前是哪一天

        date +%s         获得时间戳

        date "+%Y-%m-%d %H:%M:%S" 显示年月日时分秒

②.显示非当前时间

基本语法:

        date -d "数字 days ago"        前n天时间

        date -d "-数字 days ago"       n天后时间 

③.设置系统时间

基本语法:date -s 字符串时间

比如:设置系统当前时间:date -s "2022-05-15 17:49:35"

④.cal 查看日历

基本语法:cal [选项],不加选项时,显示本月日历

选项说明:

具体某一年         显示这一年的日历

比如:cal 1997

10.用户管理类

linux系统本身是一个多用户多任务的分时操作系统,里面可能会有很多人都用同一台机器进行操作,甚至可能是同时登陆同时操作的,所以需要有用户管理,对于不同的人给予相应的身份。

A.①.useradd 添加新用户

基本语法:

        useradd 用户名,功能:添加新用户

        useradd -g 组名 用户名,功能:添加新用户到某个组

实例实操:添加一个新用户

        useradd tangseng

②.passwd 设置用户密码

基本语法:passwd 用户名,功能:设置用户密码

实例实操:设置用户的密码

        passwd 用户名,然后回车,会出现设置密码的界面

③.id 查看用户是否存在

基本语法:id 用户名

④.cat /etc/passwd 批量查看创建了哪些用户

⑤.su 切换用户,swith user 切换用户

基本语法:

        su 用户名称,功能:切换用户,只能获得用户的执行权限,不能获得环境变量

        su - 用户名称,功能:切换到用户并获得该用户的环境变量及执行权限

        exit:可以退回上一次用户

⑥.userdel 删除用户,userdel 用户名

⑦.who 查看登录用户信息

        who am i:查看登录用户的信息

        whoami:查看当前用户的身份

⑧.sudo 设置普通用户具有root权限

操作:修改配置文件,vim /etc/sudoers,然后使用sudo进行操作

找到如下两行:

        ## Allow root to run any commands anywhere 
        root    ALL=(ALL)       ALL

在其下面添加:用户名        ALL=(ALL)       ALL,此时使用命令sudo时需要使用密码,

如果使用这种方式,可以不输入密码:atguigu         ALL=(ALL)         NOPASSWD:ALL

usermod 修改用户

基本语法:usermod -g 用户组 用户名

选项 :-g ,功能:修改用户的初始登录组,给定的组必须存在。默认组 id 是 1

B.用户组管理命令:每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。

①.groupadd 新增组,基本语法:groupadd 组名

②.groupdel 删除组,

③.groupmod 修改组
基本语法:groupmod -n 新组名 老组名
选项:-n<新组名> 指定工作组的新组名

④. cat /etc/group 查看创建了哪些组

11.文件权限类

文件属性:在linux中我们可以使用ll或者ls -l命令来显示一个文件的属性以及文件所属的用户和组。ll查看的详细信息分别是:

文件类型与权限 链接数 文件属主 文件属组 文件大小 建立或最近修改的时间 文件名字

>>如果查看到是文件:链接数指的是硬链接个数。
>>如果查看的是文件夹:链接数指的是子文件夹个数。

A.如果没有权限,就会出现减号[ - ]而已。从左至右用0-9这些数字来表示:

I.0 首位表示类型,在Linux中第一个字符代表这个文件是目录、文件或链接文件等等
        - 代表文件
        d 代表目录
        l 链接文档(link file)

        c 字符类型的设备文件,比如鼠标、键盘

        b 块设备文件,比如硬盘

II.第1-3位确定属主(该文件的所有者)拥有该文件的权限。r:读,w:写,x:执行
III.第4-6位确定属组(所有者的同组用户)拥有该文件的权限。r:读,-:无,x:执行
IV.第7-9位确定其他用户拥有该文件的权限 。r:读,-:无,x:执行
B.rwx 作用文件和目录的不同解释
I.作用到文件:
        [ r ]代表可读(read): 可以读取,查看
        [ w ]代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件。

        [ x ]代表可执行(execute):可以被系统执行
II.作用到目录:
        [ r ]代表可读(read): 可以读取,ls查看目录内容
        [ w ]代表可写(write): 可以修改,目录内创建+删除+重命名目录
        [ x ]代表可执行(execute):可以进入该目录

chmod 改变权限

第一种方式变更权限:chmod [{ugoa}{+-=}{rwx}] 文件或目录

经验:=:是给权限赋值,+:是增加权限,-:是减少权限

比如:chmod u+x 文件,chmod u-x,o+x 文件
第二种方式变更权限:chmod [mode=421 ] [文件或目录]

经验:r=4,w=2,x=1,rwx=4+2+1=7

chown 改变所有者

基本语法:chown [选项] [最终用户] [文件或目录],功能:改变文件或者目录的所有者
选项:-R  递归改变文件所有者或所有组

比如:

改变文件所有者(属主):chown 用户 文件名

改变文件所有者和所属组(属组):chown 用户名:用户组 文件名 

④.chgrp 改变所属组
基本语法:chgrp [最终用户组] [文件或目录] (功能描述:改变文件或者目录的所属组)
比如:

修改文件的所属组:chgrp 用户组 文件或目录

⑤.搜索查找类

A.find 查找文件或者目录,find指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件显示在终端。

基本语法:find [搜索范围] [选项]

选项:

        -name<查询方式>   按照指定的文件名查找模式查找文件

        -user<用户名>         查找属于指定用户名的所有文件

        -size<文件大小>       按照指定的文件大小查找文件。

        文件大小:

        b块(512字节),c字节,w字(2字节),k千字节,M兆字节,G吉字节

实例实操:

        按文件名:根据名称查找/目录下的filename.txt文件。 find xiyou/ -name "*.txt"
        按拥有者:查找/opt目录下,用户名称为-user的文件。find xiyou/ -user atguigu
        按文件大小:在/home目录下查找大于200m的文件(+n 大于 -n小于 n等于)
       find /home -size +204800

B.locate 快速定位文件路径
locate 指令利用事先建立的系统中所有文件名称及路径的 locate 数据库实现快速定位给定的文件。Locate 指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更新 locate时刻。
基本语法:locate 搜索文件
经验技巧:由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用 updatedb 指令更新locate数据库。

C.grep 过滤查找及“|” 管道符
管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理
基本语法:grep 选项 查找内容 源文件
选项:-n 显示匹配行及行号。
案例实操:查找某文件在第几行:ls | grep -n test

D.压缩和解压类
I.gzip/gunzip 压缩和解压缩
基本语法:

gzip 文件 (功能描述:压缩文件,只能将文件压缩为*.gz 文件)
gunzip 文件.gz (功能描述:解压缩文件命令)
经验技巧:
(1)只能压缩文件不能压缩目录
(2)不保留原来的文件
(3)同时多个文件会产生多个压缩包

II.zip/unzip 压缩和解压缩
基本语法:
zip [选项] XXX.zip 将要压缩的内容 (功能描述:压缩文件和目录的命令,XXX.zip是压缩包的名字)

unzip [选项] XXX.zip (功能描述:解压缩文件)
zip选项:-r 压缩目录
unzip选项:-d<目录> 指定解压后文件的存放目录
经验技巧:zip 压缩命令在windows/linux都通用,可以压缩目录且保留源文件

III. tar 打包
基本语法:

tar [选项] XXX.tar.gz 将要打包进去的内容,功能:打包目录,压缩后的文件格式.tar.gz
选项:
        -c         产生.tar 打包文件
        -v         显示详细信息
        -f         指定压缩后的文件名
        -z         打包同时压缩
        -x         解包.tar 文件
        -C         解压到指定目录

12.磁盘分区类

①.du 查看文件和目录占用的磁盘空间,disk usage 磁盘占用情况

基本语法:du 目录或文件,功能:显示目录下每个子目录的磁盘使用情况

选项:

        -h        以人们交易阅读的GBytes,MBytes,KBytes等格式自行显示 

        -a        不仅查看子目录大小,还要包括文件

        -c        显示所有的文件和子目录大小后,显示总和

        -s        只显示总和

        --max-depth=n        指定统计子目录的深度为第n层

实例实操:查看当前用户主目录占用的磁盘空间大小,du -sh

②.df 查看磁盘空间使用情况,disk free 空余磁盘

基本语法:df 选项,功能:列出文件系统的整体磁盘使用量,检查文件系统的磁盘占用情况

选项:-h ,以人们交易阅读的GBytes,MBytes,KBytes等格式自行显示 

比如:查看磁盘使用情况:df -h        

③.lsblk 查看设备挂载情况,基本语法:lsblk

选项:-f,查看详细的设备挂载情况,显示文件系统信息

④.mount/umount 挂载/卸载

Linux中每个分区都是用来组成整个文件系统的一部分,它在用一种叫做“挂载”的处理
方法,它整个文件系统中包含了一整套的文件和目录,并将一个分区和一个目录联系起来,
要载入的那个分区将使它的存储空间在这个目录下获得。

A.挂载前准备(必须要有光盘或者已经连接镜像文件)

B.基本语法

        mount [-t vfstype] [-o options] device dir (功能描述:挂载设备)
        umount 设备文件名或挂载点 (功能描述:卸载设备)

C.参数说明

        -t vfstype:

                指定文件系统的类型,通常不必指定。mount 会自动选择正确的类
                型。常用类型有:
                        光盘或光盘镜像:iso9660
                        DOS fat16 文件系统:msdos
                        Windows 9x fat32 文件系统:vfat
                        Windows NT ntfs 文件系统:ntfs
                        Mount Windows 文件网络共享:smbfs
                        UNIX(LINUX) 文件网络共享:nfs
        -o options:

                主要用来描述设备或档案的挂接方式。常用的参数有:
                        loop:用来把一个文件当成硬盘分区挂接上系统
                        ro:采用只读方式挂接设备
                        rw:采用读写方式挂接设备
                        iocharset:指定访问文件系统所用字符集
        device:要挂接(mount)的设备
        dir:设备在系统上的挂接点(mount point)

D.实例实操

        I.挂载光盘镜像文件:

         mkdir /mnt/cdrom,建立挂载点

         mount -t iso9660 /dev/cdrom /mnt/cdrom,设备/dev/cdrom挂载到挂载点/mnt/cdrom中

         ll /mnt/cdrom 

        II.卸载光盘镜像文件:umount /mnt/cdrom

E.设置开机自动挂载:vim /etc/fstab

找到下面内容,仿照其模式进行追加

        # Accessible filesystems, by reference, are maintained under '/dev/disk'
        # See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
        #
        UUID=7b590bb3-7723-40e9-a615-ffb48a334624 /              xfs     defaults        0 0
        UUID=625b994f-63e2-4188-98eb-42965a451813 /boot      xfs     defaults        0 0
        UUID=09ffc562-f07c-4372-835b-8281ec474697 swap        swap    defaults      0 0

⑤.fdisk 分区,该命令必须在root用户下才能使用

基本语法:

        fdisk -l,功能:查看磁盘分区详情,显示所有硬盘的分区列表

        fdisk 磁盘设备名,功能:对新增硬盘进行分区操作

功能说明:

        A.Linux 分区
                Device:分区序列
                Boot:引导
                Start:从X磁柱开始
                End:到Y磁柱结束
                Blocks:容量
                Id:分区类型ID
                System:分区类型
        B.分区操作按键说明
                m:显示命令列表
                p:显示当前磁盘分区
                n:新增分区
                w:写入分区信息并退出
                q:不保存分区信息直接退出

13.进程线程类

进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地
址空间,并占用一定的系统资源。

①.ps 查看当前系统进程状态,process status 进程状态

基本语法:

        ps aux | grep xxx,功能:查看系统中所有进程

        ps -ef | grep xxx,功能:可以查看子父进程之间的关系

选项:

        a        列出带有终端的所有用户的进程

        x        列出当前用户的所有进程,包括没有终端的进程

        u        面向用户友好的显示风格

        -e       列出所有进程

        -u       列出某个用户关联的所有进程

        -f        显示完整格式的进程列表

功能说明:

        A.ps aux 显示信息说明
                USER:该进程是由哪个用户产生的
                PID:进程的 ID 号
                %CPU:该进程占用 CPU 资源的百分比,占用越高,进程越耗费资源;
                %MEM:该进程占用物理内存的百分比,占用越高,进程越耗费资源;
                VSZ:该进程占用虚拟内存的大小,单位 KB;
                RSS:该进程占用实际物理内存的大小,单位 KB;
                TTY:该进程是在哪个终端中运行的。对于 CentOS 来说,tty1 是图形化终端,
                tty2-tty6 是本地的字符界面终端。pts/0-255 代表虚拟终端。
                STAT:进程状态。常见的状态有:R:运行状态、S:睡眠状态、T:暂停状态、
                Z:僵尸状态、s:包含子进程、l:多线程、+:前台显示
                START:该进程的启动时间

                TIME:该进程占用 CPU 的运算时间,注意不是系统时间
                COMMAND:产生此进程的命令名
        B.ps -ef 显示信息说明
                UID:用户 ID
                PID:进程 ID
                PPID:父进程 ID
                C:CPU 用于计算执行优先级的因子。数值越大,表明进程是 CPU 密集型运算,
                执行优先级会降低;数值越小,表明进程是 I/O 密集型运算,执行优先级会提高
                STIME:进程启动的时间
                TTY:完整的终端名称
                TIME:CPU 时间
                CMD:启动进程所用的命令和参数

经验技巧:

        如果想查看进程的 CPU 占用率和内存占用率,可以使用 aux;
        如果想查看进程的父进程 ID 可以使用 ef

②.kill 终止进程

基本语法:

        kill [选项] 进程号(PID),功能:通过进程号杀死进程

        killall 进程名称,功能:通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用。

选项说明:

        -9 表示强迫进程立即停止

③.pstree 查看进程树
基本语法:pstree [选项]
选项:
        -p    显示进程的 PID
        -u    显示进程的所属用户

.top 实时监控系统进程状态
基本命令:top [选项]
选项:

        -d 秒数,指定 top 命令每隔几秒更新。默认是3秒在top命令交互模式中可以执行的命令

        -i 使 top 不显示任何闲置或者僵死进程。
        -p 通过指定监控进程 ID 来仅仅监控某个进程的状态。

操作:
        P 以 CPU 使用率排序,默认就是此项
        M 以内存的使用率排序
        N 以 PID 排序
        q 退出 top

实例实操:

        top -d 1;top -i;top -p 2575
        执行上述命令后,可以按 P、M、N对查询出的进程结果进行排序。

⑤.netstat 显示网络状态和端口占用信息
基本语法:
        netstat -anp | grep 进程号 (功能描述:查看该进程网络信息)
        netstat –nlp | grep 端口号 (功能描述:查看网络端口号占用情况)
选项:
        -a 显示所有正在监听(listen)和未监听的套接字(socket)
        -n 拒绝显示别名,能显示数字的全部转化成数字
        -l 仅列出在监听的服务状态
        -p 表示显示哪个进程在调用

实例实操:

        通过进程号查看sshd进程的网络信息:netstat -anp | grep sshd

        查看某端口号是否被占用:netstat -nltp | grep 22

⑥. crontab 系统定时任务
A.crontab 服务管理
实例实操:

        重新启动 crond 服务:systemctl restart crond
B.crontab 定时任务设置
基本语法:crontab [选项]
选项:
        -e 编辑 crontab 定时任务
        -l 查询 crontab 任务
        -r 删除当前用户所有的 crontab 任务

扩展篇:

14.软件包管理

A.RPM

①.RPM 概述
RPM(RedHat Package Manager),RedHat软件包管理工具,类似windows里面的setup.exe,是Linux这系列操作系统里面的打包安装工具,它虽然是RedHat的标志,但理念是通用的。
        RPM安装包的名称格式:Apache-1.3.23-11.i386.rpm
                - “apache” 软件名称
                - “1.3.23-11”软件的版本号,主版本和此版本
                - “i386”是软件所运行的硬件平台,Intel 32位处理器的统称
                - “rpm”文件扩展名,代表RPM包

②.RPM 查询命令(rpm -qa
基本语法:rpm -qa (功能描述:查询q所安装的所有a rpm软件包)
经验技巧:由于软件包比较多,一般都会采取过滤。rpm -qa | grep rpm软件包
案例实操
        查询firefox软件安装情况:rpm -qa | grep firefox
        查询结果:firefox-45.0.1-1.el6.centos.x86_64
③.RPM 卸载命令(rpm -e
基本语法:
        rpm -e RPM软件包
        rpm -e --nodeps 软件包
选项:
        -e                 卸载软件包
        --nodeps      卸载软件时,不检查依赖。这样的话,那些使用该软件包的软件在此之后可能就不能正常工作了。

案例实操:
        卸载firefox软件:rpm -e firefox

④.RPM 安装命令(rpm -ivh) 
基本语法
rpm -ivh RPM包全名
选项:
        -i   install,安装
        -v  verbose,显示详细信息
        -h  hash,进度条
        --nodeps 安装前不检查依赖

B.YUM 仓库配置

YUM(全称为 Yellow dog Updater, Modified)是一个在 Fedora 和 RedHat 以及 CentOS
中的 Shell 前端软件包管理器。基于 RPM 包管理,能够从指定的服务器自动下载 RPM 包
并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次
次下载、安装。YUM类似于我们java开发中的maven工具,可以从镜像网站上下载应用程序,并直接安装。

①.YUM 的常用命令

基本语法:yum [选项] [参数]

选项:-y,对所有提问都回答yes

参数:

        install,安装rpm软件包

        update,更新rpm软件包

        check-update,检查是否有可用的更新rpm软件包

        remove,删除指定的rpm软件包

        list,显示软件包信息

        clean,清理yum过期的缓存

        deplist,显示yum软件包的所有依赖关系

实例实操:

        采用yum方式安装firefox,yum -y install firefox

②.修改网络YUM源

默认的系统YUM源,需要连接国外apache网站,网速比较慢,可以修改关联的网络YUM源为国内镜像的网站,比如网易163,aliyun等。

1)安装wget,wget用来从指定的URL下载文件:yum install wget
2)在/etc/yum.repos.d/目录下,备份默认的 repos 文件
[root@hadoop101 yum.repos.d] pwd
/etc/yum.repos.d
[root@hadoop101 yum.repos.d] cp CentOS-Base.repo CentOS-Base.repo.backup
3)下载网易163 或者是 aliyun 的 repos 文件,任选其一
[root@hadoop101 yum.repos.d] wget http://mirrors.aliyun.com/repo/Centos-7.repo //阿里云
[root@hadoop101 yum.repos.d] wget http://mirrors.163.com/.help/CentOS7-Base-163.repo //网易163

4)使用下载好的 repos文件替换默认的 repos文件
例如:用 CentOS7-Base-163.repo 替换 CentOS-Base.repo
[root@hadoop101 yum.repos.d]# mv CentOS7-Base-163.repo CentOS-Base.repo
5)清理旧缓存数据,缓存新数据
[root@hadoop101 yum.repos.d]#yum clean all
[root@hadoop101 yum.repos.d]#yum makecache
yum makecache就是把服务器的包信息下载到本地电脑缓存起来
6)测试
[root@hadoop101 yum.repos.d]# yum list | grep firefox
[root@hadoop101 ~]#yum -y install firefox

15.克隆虚拟机

你可能感兴趣的:(linux,学习,服务器,centos)