当前的IT行业,各个企业的应用服务都是跑在服务器上的,服务器其实就是一种特殊的电脑,服务器的操作系统目前绝大多数都是Linux,不管哪个行业,只要和服务器打交道,就必须了解Linux。
笔记内容:
入门篇:Linux概述、安装
基础篇:文件与目录结构、VI/VIM编辑器、网络配置、系统管理、远程登录
实操篇:文件目录类、时间日期类、用户管理类、文件权限类、磁盘分区类、进程线程类
扩展篇:软件包管理、克隆虚拟机
Linux发行版本:基于CentOS7
①Linux是一个操作系统(OS),所谓操作系统,就是直接用来操作计算机底层硬件的软件
②计算机硬件-->操作系统核心层kernel(硬件接口层)-->命令解释层(shell)-->外围应用层
流程分析:整个计算机的最底层是:计算机硬件,我们操作电脑最终就是转换成指令去操作计算机硬件。那什么东西能直接操作硬件呢?就是操作系统。所以在计算机硬件之外必须有一个硬件的接口层,即操作系统的核心层kernel(Linux kernel)。实际要用一个操作系统的时候,肯定在其之上还应该有各种各样的应用程序,这些应用软件要和底层的操作系统内核交流、通讯,所以在kernel层的外面还应有一个媒介(接口):shell(命令解释层)。shell的作用是连接外部的应用程序和内层的操作系统内核,最外层就是外围的应用层。
③主流的、市面上常见的Linux发行版本:
Red Hat(不太关注桌面,性能稳定强悍)是一系列的软件:RedHatEnterpriseLinux(RHEL);fedoro、CentOS(这两者免费)
debian:ubuntu(基于debian发展出来的,免费的),有非常好用的桌面
VMware虚拟机的下载
CentOS7.9的下载
创建虚拟机需要主机开启虚拟化,如果没打开,需要在BIOS设置里面把对应的虚拟化选项开启
附件选择
分区:
/boot: 引导分区,系统启动时靠它进行快速的启动
/:根分区
swap:虚拟内存
打开终端的两种方式:
1.打开仿真终端:右键桌面打开终端,在命令行中输入init 3(3是运行级别的意思)
2.打开底层终端(大黑屏):ctrl+alt+f2~f6,然后登陆,此时鼠标消失,如果想使用鼠标就ctrl+alt;
3.退出终端回到图形化界面:ctrl+fn+alt+f1或init 5
[root@redis100 ~]# :用户root和主机名redis100,~是当前所在的位置(当前用户的主文件夹),#是输入命令的提示符号
①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是一种安全子系统,它能控制程序只能访问特定文件 。
①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
①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注意:在虚拟机里面的更改,在主机里面也要做相应的更改(因为主机也要与这些虚拟机通信)
①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,配置服务的开机自启动选项
[*] 表示当前服务开机自启动,[ ] 表示当前服务开机不会启动,空格可以对其做更改
⑤系统的启动过程以及运行级别
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 取消关机
①做完网络配置就可以尝试进行远程的登录,操作自己的服务器(虚拟机),最经典最简单的远程登录方式ssh:ssh root@redis100,也可以使用远程登录工具Xshell等,都是基于ssh协议进行免密登录。
②上传下载文件,使用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键 提示,补全,更重要的是可以防止敲错 上下键 查找执行过的命令
①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 ,清空历史命令
基本语法: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
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 查看创建了哪些组
①文件属性:在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 +204800B.locate 快速定位文件路径
locate 指令利用事先建立的系统中所有文件名称及路径的 locate 数据库实现快速定位给定的文件。Locate 指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更新 locate时刻。
基本语法:locate 搜索文件
经验技巧:由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用 updatedb 指令更新locate数据库。C.grep 过滤查找及“|” 管道符
管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理
基本语法:grep 选项 查找内容 源文件
选项:-n 显示匹配行及行号。
案例实操:查找某文件在第几行:ls | grep -n testD.压缩和解压类
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 解压到指定目录
①.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:不保存分区信息直接退出
进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地
址空间,并占用一定的系统资源。①.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 任务
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 //网易1634)使用下载好的 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