注:本篇笔记根据黑马程序员新版Linux零基础快速入门到精通的内容所创建。
1.初识Linux
-
Linux的诞生
Linux由林纳斯 托瓦兹在1991年创立并发展至今成为服务器操作系统领域的核心系统。
-
什么是Linux系统的内核
内核提供了Linux系统的主要功能,如硬件调度管理的能力,Linux内核是免费开源的,任何人都可以查看内核的源代码,甚至是贡献源代码。 -
什么是Linux系统发行版
内核无法被用户直接使用,需要配合应用程序才能被用户使用,在内核之上,封装系统级应用程序,组合在一起就称之为Linux发行版。
2.目录结构
- Linux的目录结构是一个树型结构,而Windows 系统可以拥有多个盘符,如 C盘、D盘、E盘;Linux没有盘符这个概念,只有一个根目录/,所有文件都在它下面。
- 在Linux系统中,路径之间的层级关系,使用 :/来表示;在Windows系统中,路径之间的层级关系,使用 :\ 来表示。
3.Linux命令
概述
- 学习Linux,本质上是学习在命令行下熟练使用Linux的各类命令。
- 命令行: 即Linux终端(Terminal),是一种命令提示符页面。以纯"字符”的形式操作系统,可以使用各种字符化命令对系统发出操作指令。
- 命令: 即Linux程序。一个命令就是一个Linux的程序。命令没有图形化页面,可以在命令行(终端中)提供字符化的反馈。
基础格式
无论是什么命令,用于什么用途,在Linux中,命令有其通用的格式:
command [-options] [parameter]
注:
- command: 命令本身
- -options: 命令的一些选项,可以通过选项控制命令的行为细节
- parameter: 命令的参数,多数用于命令的指向目标等语法中的[,表示可选的意思
- [] 中的内容为可选
ls命令
ls命令的作用是列出目录下的内容,语法细节如下
1s [-a -1 -h] [Linux路径]
当不使用选项和参数,直接使用ls命令本体, 表示: 以平铺形式,列出当前工作目录下的内容。
Linux系统的命令行终端,在启动的时候,默认会加载
- 当前登录用户的HOME目录作为当前工作目录,所以ls命令列出的是HOME目录的内容
- HOME目录: 每个Linux操作用户在Linux系统的个人账户目录,路径在:/home/用户名
各个选项作用
- -a选项,表示: all的意思,即列出全部文件(包含隐藏的文件/文件夹)。以 . 开头的,表示是Linux系统的隐藏文件/文件夹(只要以 . 开头,就能自动隐藏)只有通过-a选项,才能看到这些隐藏的文件/文件夹。
- -l 选项,表示: 以列表(竖向排列)的形式展示内容,并展示更多信息。
- -h表示以易于阅读的形式,列出文件大小,如K、M、G。-h选项必须要搭配 -l 一起使用。
注: 语法中的选项是可以组合使用的,比如学习的-a和-l可以组合应用。如: ls -l -a ,ls -la ,ls -al。这三种写法都是等价的,表示同时使用 =l 和 -a 的功能。
cd命令
当Linux终端(命令行)打开的时候,会默认以用户的HOME目录作为当前的工作目录,我们可以通过cd命令,更改当前所在的工作目录。cd命令来自英文: Change Directory
语法:
cd [Linux路径]
cd命令无需选项,只有参数,表示要切换到哪个目录下;cd命令直接执行,不写参数,表示回到用户的HOME目录。
pwd命令
通过ls来验证当前的工作目录,其实是不恰当的,我们可以通过pwd命令,来查看当前所在的工作目录。pwd命令来自:Print Work Directory
语法:
pwd
pwd命令,无选项,无参数,直接输入pwd即可
相对路径和绝对路径
绝对路径: 以根目录为起点,描述路径的一种写法,路径描述以/开头
相对路径: 以当前目录为起点,描述路径的一种写法,路径描述无需以/开头
特殊路径符:
.
表示当前目录,比如 cd./Desktop
表示切换到当前目录下的Desktop目录内,和cd Desktop
效果一致
..
表示上一级目录,比如:cd..
即可切换到上一级目录,cd ../..
切换到上二级的目录
~
表示HOME目录,比如: cd ~
即可切换到HOME目录 cd ~/Desktop
,切换到HOME内的Desktop目录
mkdir命令
通过mkdir命令可以创建新的目录(文件夹)。mkdir来自英文:Make Directory
语法:
mkdir [-p] Linux路径
参数必填,表示Linux路径,即要创建的文件夹的路径,相对路径或绝对路径均可。p选项可选,表示自动创建不存在的父目录,适用于创建连续多层级的目录。
注意: 创建文件夹需要修改权限,请确保操作均在HOME目录内,不要在HOME外操作涉及到权限问题,HOME外无法成功。
清屏快捷键:CTRL+L
touch命令
可以通过touch命令创建文件
语法:
touch Linux路径
touch命令无选项,相对、绝对、特殊路径符均可以使用。
cat和more命令
可以通过cat查看内容
语法:
cat Linux路径
more命令同样可以查看文件内容,同cat不同的是,cat是直接将内容全部显示出来,而more支持翻页,如果文件内容过多,可以一页页的展示。(按空格进行翻页,按q退出翻页)
语法:
more Linux路径
cp,mv,rm命令
-
cp命令
cp命令可以用于复制文件\文件夹,cp命令来自英文单词:copy
语法:cp [-r] 参数1 参数2
注:
- -r 选项,可选,用于复制文件夹使用,表示递归
- 参数1,Linux路径,表示被复制的文件或文件夹
- 参数2,Linux路径,表示要复制去的地方
-
mv命令
mv命令可以用于移动文件或文件夹,mv命令来自英文单词:move
语法:
mv 参数1 参数2
注:
- 参数1,Linux路径,表示被移动的文件或文件夹
- 参数2,Linux路径,表示要移动去的地方,如果目标不存在,则进行改名,将参数二改成参数一,确保目标存在
-
rm命令
rm命令可用于删除文件、文件夹,rm命令来自英文单词:remove
语法:rm [-r -f] 参数1 参数2......参数N
注:
- 同cp命令一样,-r 选项用于删除文件夹
- -f 表示force,强制删除(不会弹出提示确认信息)
- 普通用户删除内容不会弹出提示,只有root管理员用户删除内容会有提示
- 所以一般普通用户用不到-f选项.
- 参数1、参数2、…、参数N 表示要删除的文件或文件夹路径,按照空格隔开
通配符
rm命令支持通配符 * ,用来做模糊匹配符号* 表示通配符,即匹配任意内容(包含空)。示例:
test*
表示匹配任何以test开头的内容*test
表示匹配任何以test结尾的内容*test*
表示匹配任何包含test的内容
切换root管理员
通过su -root
命令,输入密码切换root管理员,可以通过exit
命令,退回普通用户。
注意:
rm是一个危险的命令,特别是在处于root(超级管理员)用户的时候。请谨慎使用!!!
如下命令请千万千万不要在root管理员用户下执行,除非不想努力了。
rm -rf /
rm -rf /*
效果等同于在Windows上执行C盘格式化。
which和find命令
Linux命令的本体就是一个个的二进制可执行程序。我们可以通过which命令,查看所使用的一系列命令的程序文件存放在哪里。
语法:
which 要查找的命令
若要去搜索指定的文件,则需要用到find指令。
语法:
按照名称搜索
find 起始路径 -name "要查找文件名"
按照大小搜索
find 起始路径 -size +|-n[kMG]
- +、- 表示大于和小于
- n 表示大小数字
- kMG表示大小单位,k(小写字母)表示kb,M表示MB,G表示GB
grep,wc命令和|管道符
gerp命令
可以通过grep命令,从文件中通过关键字过滤出带有该关键字的文件行。
语法:
grep [-n] 关键字 文件路径
- 选项,-n,可选,表示在结果中显示匹配的行的行号
- 参数,关键字,必填,表示过滤的关键字,带有空格或其它特殊符号,建议使用 ” ” 将关键字包围起来
- 参数,文件路径,必填,表示要过滤内容的文件路径,可作为内容输入端口
wc命令
可以通过wc命令统计文件的行数、单词数量等
语法:
wc [-c -m -1 -w] 文件路径
-
选项,-c,统计bytes数量
-
选项,-m,统计字符数量
-
选项,-l,统计行数
-
选项,-w,统计单词数量
-
参数,文件路径,被统计的文件,可作为内容输入端口
-
若一个选项也不选,则显示行数,字节数,以及单词数
管道符 |
管道符的含义是:将管道符左边命令的结果,作为右边命令的输入,管道符支持嵌套
cat test.txt | grep hello
cat test.txt | grep hello wc -l
echo,tail命令和重定向符
echo命令
可以使用echo命令在命令行内输出指定内容。
语法:
echo 要输出的内容
无需选项,只有一个参数,表示要输出的内容,复杂内容可以用””包围
反引号 `
我们可以通过将命令用反引号(通常也称之为飘号)将其包围,被包围的内容,会被作为命令执行,而非普通字符。
如echo pwd
和echo `pwd`
,前者打印pwd,而后者会执行pwd命令。
tail命令
使用tail命令,可以查看文件尾部内容,跟踪文件的最新更改。
语法:
tail [-f -num] Linux路径
- 参数,Linux路径,表示被跟踪的文件路径
- 选项,-f,表示持续跟踪,可用快捷键CTRL+C停止该指令,即停止跟踪
- 选项, -num,表示,查看尾部多少行,不填默认10行
重定向符: > 和 >>
> ,将左侧命令的结果,覆盖(将原本的内容清空)写入到符号右侧指定的文件中。
>>,将左侧命令的结果,追加写入到符号右侧指定的文件中。
如:
echo "hello linux" > zyh.txt
echo "hello linux" >> zyh.txt
练习
输出内容:我当前的工作目录是:具体的工作目录路径并将输出结果覆盖写入work.txt文件
echo "我当前的工作目录是:'pwd'" > work.txt
4.vi\vim编辑器介绍
概述
vi\vim是visualinterface的简称,是Linux中最经典的文本编辑器同图形化界面中的 文本编辑器一样,vi是命令行下对文本文件进行编辑的绝佳选择。vim 是 vi的加强版本,兼容 vi的所有指令,不仅能编辑文本,而且还具有 shell程序编辑的功能,可以不同颜色的字体来辨别语法的正确性,极大方便了程序的设计和编辑性。
vi\vim编辑器的三种工作模式
-
命令模式(Command mode)
命令模式下,所敲的按键编辑器都理解为命令此模型下,以命令驱动执行不同的功能。此模式下,不能自由进行文本编辑。 -
输入模式(Insert mode)
也就是所谓的编辑模式、插入模式。此模式下,可以对文件内容进行自由编辑。 -
底线命令模式(Last line mode)
以 : 开始,通常用于文件的保存、退出。
命令模式
如果需要通过vi/vim编辑器编辑文件,请通过如下命令:
vi 文件路径
vim 文件路径
注意:
如果文件路径表示的文件不存在,那么此命令会用于编辑新文件。
如果文件路径表示的文件存在,那么此命令用于编辑已有文件。
常用快捷键
快捷键 | 功能 |
---|---|
i | 在当前光标处进入输入模式 |
o | 在当前光标处的下一行进入输入模式 |
: | 进入命令模式 |
esc | 退回到命令模式 |
p | 粘贴复制内容 |
dd | 删除光标所在行 |
yy | 复制当前行 |
u | 撤销修改 |
/ | 进入搜索模式 |
底线命令模式
在命令模式下按 :进入底线模式
快捷键 | 功能 |
---|---|
wq | 保存并退出 |
q | 仅退出 |
q! | 强制退出 |
w | 保存 |
set nu | 显示行号 |
set paste | 设置粘贴模式,使外界的粘贴内容格式不变 |
5.Root用户
概述
无论是Windows、MacOS、Linux均采用多用户的管理模式进行权限管理。在Linux系统中,拥有最大权限的账户名为:root(超级管理员)。普通用户的权限,一般在其HOME目录内是不受限的,一 旦出了HOME目录,大多数地方,普通用户仅有只读和执行权限,无修改权限
命令:
切换用户
su [-] [用户名]
- -符号是可选的,表示是否在切换用户后加载环境变量(后续讲解)建议带上
- 参数:用户名,表示要切换的用户,用户名也可以省略,省略表示切换到root
- 切换用户后,可以通过exit命令退回上一个用户,也可以使用快捷键: ctrl+d
返回上一个用户
exit
使用普通用户,切换到其它用户需要输入密码,如切换到root用户使用root用户切换到其它用户,无需密码,可以直接切换。
sudo
在我们得知root密码的时候,可以通过su命令切换到root得到最大权限。但是我们不建议长期使用root用户,避免带来系统损坏。我们可以使用sudo命令,为普通的命令授权,临时以root身份执行。
语法:
sudo 其它命令
在其它命令之前,带上sudo,即可为这一条命令临时赋予root授权,但是并不是所有的用户,都有权利使用sudo,我们需要为普通用户配置sudo认证。
配置认证
-
切换到root用户,执行
visudo
命令,会自动通过vi编辑器打开:/etc/sudoers
-
在文件的最后添加:
用户名 ALL=(ALL) NOPASSWD: ALL
其中最后的NOPASSWD:ALL表示使用sudo命令,无需输入密码
-
最后通过 wq 保存
-
切换回普通用户
-
后续该普通用户执行的命令,均以root运行
用户、用户组
Linux系统中可以配置多个用户和配置多个用户组,并且用户可以加入多个用户组中。
Linux中关于权限的管控级别有2个级别,分别是:
- 针对用户的权限控制
- 针对用户组的权限控制
比如,针对某文件,可以控制用户的权限,也可以控制用户组的权限。
以下指令需root用户执行:
用户组管理
-
创建用户组
groupadd 用户组名
-
删除用户组(需root用户执行)
groupdel 用户组名
用户管理
-
创建用户
useradd [-g -d] 用户名
- 选项: -g 指定用户的组,不指定 -g,会创建同名组并自动加入,指定-g需要该组已经存在,如已存在同名组,则必须使用-g
- 选项: -d 指定用户HOME路径,不指定,HOME目录默认在: /home/用户名
-
删除用户
userdel [-r] 用户名
- 选项: -r,删除用户的HOME目录,不使用-r,删除用户时,HOME目录保留
-
查看用户所属组
id [用户名]
- 参数: 用户名,被查看的用户,如果不提供则查看自身
-
修改用户所属组
usermod -aG 用户组 用户名
将指定用户加入指定用户组
查看系统所有用户和用户组
-
查看所有用户
getent passwd
- 每个用户展示的信息,共有7份信息,分别是:
用户名 : 密码(x) : 用户ID : 组ID : 描述信息(无用) : HOME目录 : 执行终端 (默认bash)
- 每个用户展示的信息,共有7份信息,分别是:
-
查看所有用户组
getent group
- 包含3份信息,组名称 : 组认证(显示为x) :组ID
6.权限信息
查看权限
通过ls -l
可以以列表形式查看内容,并显示权限细节。 前面的三个部分分别表示:
-
文件、文件夹的权限控制信息
- 权限细节总共分为十个槽位
- 第一个槽位为: - 或 d 或 l ,- 表示文件,d 表示文件夹,l 表示软链接
- 后面九个每三个为一组(其中第一个为 r或-,第二个为 w 或 -,第三个为 x 或 - ),分别表示所属用户权限,所属用户组权限,其他用户权限。
- 举例:
drwxr-xr-x
,表示:- 这是一个文件夹,首字母d表示
- 所属用户(右上角图序号2)的权限是:有r有w有x,rwX
- 所属用户组(右上角图序号3)的权限是:有r无w有x,r-x
- 其它用户的权限是:有r无w有x,r-x
- rwx含义
- r(read)表示读权限,w(write)表示写权限,x(execute)表示执行权限,-表示无该权限
- 针对文件、文件夹的不同,rwx的含义有细微差别
- r,针对文件夹,可以查看文件夹内容,如ls命令
- w,针对文件夹,可以在文件夹内:创建、删除、改名等操作
- x,针对文件夹,表示可以更改工作目录到此文件夹,即cd进入。
- 权限细节总共分为十个槽位
-
文件、文件夹所属用户
-
文件、文件夹所属用户组
修改权限
chmod命令
我们可以使用chmod命令,修改文件、文件夹的权限信息。注意,只有文件、文件夹的所属用户或root用户可以修改。
语法:
chmod [-R] 权限 文件或文件夹
-
选项:-R,对文件夹内的全部内容应用同样的操作
-
示例:
chmod u=rwx,g=rx,o=x hello.txt
将文件权限修改为:rwxr-x--x
- 其中:u表示user所属用户权限,g表示group组权限,o表示other其它用户权限chmod -R
- u=rwx,g=rx,o=x test,将文件夹test以及文件夹内全部内容权限设置为:rwxr-x–x
权限的数字序号
权限可以用3位数字来代表,第一位数字表示用户权限,第二位表示用户组权限,第三位表示其它用户权限。数字的细节如下: r记为4,w记为2,x记为1,可以有:
- 0:无任何权限,即—
- 1:仅有x权限,即–x
- 2:仅有w权限,即-w-
- 3:有w和x权限,即,-wx
- 4:仅有r权限,即r–
- 5:有r和x权限,即r-x
- 6:有r和w权限,即rw-
- 7:有全部权限,即rwX
故chmod u=rwx,g=rx,o=x hello.txt
可以简化为chmod 751 hello.txt
chown命令
使用chown命令,可以修改文件、文件夹的所属用户和用户组。普通用户无法修改所属为其它用户或组,所以此命令只适用于root用户执行。
语法:
chown [-R] [用户] [:][用户组] [文件或文件夹]
-
选项,-R,同chmod,对文件夹内全部内容应用相同规则
-
选项,用户,修改所属用户
-
选项,用户组,修改所属用户组
示例:
chown root hello.txt
,将 hello.txt 所属用户修改为root
chown :root hello.txt
,将hello.txt所属用户组修改为root
7.各类实用快捷键
ctrl+c 强制停止
- Linux某些程序的运行,如果想要强制停止它,可以使用快捷键 ctrl+c
- 命令输入错误,也可以通过快捷键 ctrl+c,退出当前输入,重新输入
ctrl+d 退出或登出
- 可以通过快捷键:ctrl+d,退当前出账户的登录
- 或者退出某些特定程序的专属页面
注意:不能用于退出vi/vim
历史命令搜索
- 可以通过
history
命令,查看历史输入过的命令。可以结合grep进行筛选。 - 可以通过: ! 命令前缀,自动执行上一次匹配前缀的命令。如:
!py
搜索之前的命令中以py开头的最近的命令并且执行。 - 可以通过快捷键: ctrl+r, 输入内容去匹配历史命令。如果搜索到的内容是你需要的,那么回车键可以直接执行,否则通过键盘左右键,去匹配命令(不执行)
光标移动快捷键
- ctrl+a,跳到命令开头
- ctrl+e,跳到命令结尾
- ctrl+键盘左键,向左跳一个单词
- ctrl+键盘右键,向右跳一个单词
清屏
- 通过快捷键ctrl+l可以清空终端内容
- 通过命令clear得到同样效果
8.软件管理
下载
centos
Linux命令行内的”应用商店”,yum命令安装软件。
yum:RPM包软件管理器,用于自动化安装配置Linux软件,并可以自动解决依赖问题。RPM是linux安装包的格式,类似于Windows的exe,Mac的pkg。
语法:
yum [-y] [install | remove | search] 软件名称
- 选项: -y,自动确认,无需手动确认安装或卸载过程
- install: 安装 remove:卸载 search:搜索
注意:yum命令需要root权限并且需要联网
ubuntu
Ubuntu使用apt管理器来进行软件的安装
语法:
apt [-y] [install | remove | search] 软件名称
用法和yum一致,同样需要root权限和联网。
systemctl命令
Linux系统很多软件(内置或某些第三方)均支持使用systemctl命令控制:启动、停止、开机自启。能够被systemctl管理的软件,一般也称之为:服务
语法:
systemctl start | stop | status | enable | disable 服务名
- start 启动
- stop 关闭
- status 查看状态
- enable 开启开机自启
- disable 关闭开机自启
系统内置的服务比较多,比如:
- NetworkManager,主网络服务
- network,副网络服务
- firewalld,防火墙服务
- sshd,ssh服务(Finalshell远程登录Linux使用的就是这个服务)
软连接
在系统中创建软链接,可以将文件、文件夹链接到其它位置。类似Windows系统中的快捷方式。
语法:
1n -s 参数1 参数2
- -s选项,创建软连接
- 参数1: 被链接的文件或文件夹
- 参数2: 要链接去的目的地,即快捷方式
9.时间管理
date命令
通过date命令可以在命令行中查看系统的时间。
语法:
date [-d] [ +格式化字符串]
-
-d 按照给定的字符串显示日期,一般用于日期计算,如
date -d “+ 1 day
其中支持的时间标记为:
- year 年
- Month 月
- day 天
- hour 小时
- Minute 分钟
- second秒
-
格式化字符串: 通过特定的字符串标记,来控制显示的日期格式
- %Y 年
- %y 年份后两位数字
- %m 月份
- %d 日
- %H 小时
- %M 分钟
- %S 秒
- %s 自1970-01-0100:00:00 UTC 到现在的秒数
10.网络
IP地址
每一台联网的电脑都会有一个地址,用于和其它计算机进行通讯。IP地址主要有2个版本,V4版本和V6版本。IPv4版本的地址格式是:(a.b.c.d) ,其中abcd表示0~255的数字,如192.168.88.101就是一个标准的IP地址。
可以通过命令: ifconfig
,查看本机的ip地址,如无法使用该fig命令,可以安装:yum -y install net-tool
。
几个特殊IP地址:
- 127.0.0.1这个IP地址用于指代本机
- 0.0.0.0,特殊IP地址
- 可以用于指代本机
- 可以在端口绑定中用来确定绑定关系
- 在一些IP地址限制中,表示所有IP的意思,如放行规则设置为0.0.0.0,表示允许任意IP访问
主机名
每一台电脑除了对外联络地址(IP地址)以外,也可以有一个名字,称之为主机名无论是Windows或Linux系统,都可以给系统设置主机名。可以通过hostname
查看。
可以使用命令:hostnamectl set-hostname 主机名
,修改主机名(需root)
域名解析
IP地址实在是难以记忆,实际上,我们一直都是通过字符化的地址去访问服务器,很少指定IP地址,比如,我们在浏览器内打开:www.baidu.com
,会打开百度的网址其中,www.baidu.com
,是百度的网址,我们称之为:域名。
操作系统解析域名流程:
- 先查看本机的记录(私人地址本)
- Windows看:C:\Windows\SysteM32\driversletclhosts
- Linux看 :/etc/hosts
- 没有必要去记录IP地址再联网去DNS服务器(如114.114.114.114或8.8.8.8等)去查询。
- 最后通过IP地址打开网站。
固定IP
当前我们虚拟机的Linux操作系统,其IP地址是通过DHCP服务获取的。DHCP:动态获取IP地址,即每次重启设备后都会获取一次,可能导致IP地址频繁变更。
- 若远程连接Linux系统,如果IP地址经常变化我们就要频繁修改适配很麻烦。
- 若配置了虚拟机IP地址和主机名的映射,如果IP频繁更改,我们也需要频繁更新映射关系。
所以需要固定IP。
ping命令
可以通过ping命令,检查指定的网络服务器是否是可联通状态。
语法:
ping [-c num] ip或主机名
- 选项: -c ,检查的次数,不使用-c选项,将无限次数持续检查
- 参数: ip或主机名,被检查的服务器的ip地址或主机名地址
wget命令
wget是非交互式的文件下载器,可以在命令行内下载网络文件
语法:
wget [-b] url
- 选项:-b,可选,后台下载,会将日志写入到当前工作目录的wget-log文件
- 参数:url, 下载链接
curl命令
curl可以发送http网络请求,可用于:下载文件、获取信息等。
语法:
curl [-O] url
- 选项 -O,用于下载文件,当url是下载链接时,可以使用此选项保存文件
- 参数:url,要发起请求的网络地址
如curl cip.cc
可查询自己的ip地址。
端口
端口,是设备与外界通讯交流的出入口。端口可以分为:物理端口和虚拟端口两类
- 物理端口:又可称之为接口,是可见的端口,如USB接口,RJ45网口,HDMI端口等。
- 虚拟端口:是指计算机内部的端口,是不可见的,是用来操作系统和外部进行交互使用的。
计算机程序之间的通讯,通过IP只能锁定计算机,但是无法锁定具体的程序,通过端口可以锁定计算机上具体的程序,确保程序之间进行沟通。
Linux系统可以支持65535个端口,这6万多个端口分为3类进行使用:
- 公认端口:1~1023,通常用于一些系统内置或知名程序的预留使用,如SSH服务的22端口,HTTPS服务的443端口非特殊需要,不要占用这个范围的端口。
- 注册端口:1024~49151,通常可以随意使用,用于松散的绑定一些程序或服务。
- 动态端口:49152~65535,通常不会固定绑定程序,而是当程序对外进行网络链接时,用于临时使用。
查看端口占用:
可以通过Linux命令去查看端口的占用情况,使用nmap命令(安装nmap: yum -y install nmap
)
语法: nmap 被查看的IP地址
。
可以通过netstat命令,查看指定端口的占用情况,,安装netstat: yum -y install net-tools
,语法: netstat -anp|grep 端口号
。
11.进程管理
概述
程序运行在操作系统中,是被操作系统所管理的。进程中为管理运行的程序,每一个程序在运行的时候,便被操作系统注册为系统中的一个并会为每一个进程都分配一个独有的:进程ID(进程号)。
查看进程
可以通过ps命令查看Linux系统中的进程信息
语法:
ps [-e -f]
- 选项: -e,显示出全部的进程
- 选项: -f,以完全格式化的形式展示信息(展示全部信息)
- 一般来说,固定用法就是:
ps -ef
列出全部进程的全部信息,或者ps -ef | grep 关键字
过滤指定关键字进程信息
关闭进程
在Linux中,可以通过kill命令关闭进程。
语法:
kill [-9] 进程ID
- 选项: -9 ,表示强制关闭进程。不使用此选项会向进程发送信号要求其关闭,但是否关闭看进程自身的处理机制。
主机状态监控
可以通过top命令查看CPU、内存使用情况,类似Windows的任务管理器,默认每5秒刷新一次,语法:直接输入top即可,按q或ctrl+c退出。
top命令也支持选项:
选项 | 功能 |
---|---|
-p | 只显示某个进程的信息 |
-d | 设置刷新时间,默认是5S |
-c | 显示产生进程的完整命令,默认是进程名 |
-n | 指定刷新次数,比如top-n3,刷新输出3次后退出 |
-b | 以非交互非全屏模式运行,以批次的方式执行top,一般配合-n指定输出几次统计信息,将输出重定向到指定文件,比如 top -b -n 3 > /tmp/top.tmp |
-i | 不显示任何闲置(idle)或无用(zombie)的进程 |
-u | 查找特定用户启动的进程 |
12.其他
环境变量
环境变量是操作系统(Windows、Linux、Mac)在运行的时候,记录的一些关键性信息,用以辅助系统运行。在Linux系统中执行: env
命令即可查看当前系统中记录的环境变量环境变量是一种KeyValue型结构。
PATH记录了系统执行任何命令的搜索路径(路径之间以:隔开)。
压缩和解压
市面上有非常多的压缩格式:
- zip格式:Linux、Windows、MacOS,常用
- 7zip:Windows系统常用
- rar:Windows系统常用
- tar: Linux、MacOS常用
- gzip Linux、MacOs常用
tar命令
Linux和Mac系统常用有2种压缩格式,后缀名分别是:
-
.tar,称之为tarbal,归档文件,即简单的将文件组装到一个.tar的文件内,并没有太多文件体积的减少,仅仅是简单的封装
-
.gz,也常见为.tar .gz, gzip格式压缩文件,即使用gzip压缩算法将文件压缩到一个文件内,可以极大的减少压缩后的体积
针对这两种格式,使用tar命令均可以进行压缩和解压缩。
语法:
tar [-c-v-x-f-z -C] 参数1 参数2...参数N
- -c,创建压缩文件,用于压缩模式
- -v,显示压缩、解压过程,用于查看进度
- -x,解压模式
- -f,要创建的文件,或要解压的文件,-f选项必须在所有选项中位置处于最后一个
- -z, gzip模式,不使用-z就是普通的tarball格式
- -C,选择解压的目的地,用于解压模式
例:
-
将1.txt 2.txt 3.txt压缩到test.tar文件内
tar -cvf test.tar 1.txt 2.txt 3.txt
-
将1.txt 2.txt 3.txt压缩到test.tar.gz文件内,使用gzip模式
tar -zcvf test.tar.gz 1.txt 2.txt 3.txt
注意:
- -f选项,必须在选项组合体的最后一位
- -z选项,建议在开头位置
- -C选项单独使用,和解压所需的其它参数分开
zip 命令压缩文件
可以使用zip命令,压缩文件为zip压缩包。
语法:
zip [-r] 参数1 参数2...参数N
-
-r,被压缩的包含文件夹的时候,需要使用-r选项,和rm、cp等命令的-r效果一致
示例:
- zip test.zip a.txt b.txt c.txt,将a.txt b.txt c.txt压缩到test.zip文件内zip -
- rtest.zip test itheima a.txt,将test、itheima两个文件夹和a.txt文件,压缩到test.zip文件内
unzip命令解压文件
使用unzip命令,可以方便的解压zip压缩包。
语法:
unzip [-d] 参数
- -d,指定要解压去的位置,同tar的-C选项
- 参数,被解压的zip压缩包文件
示例:- unzip test.zip,将test.zip解压到当前目录
- unzip test.zip -d /home/itheima,将test.zip解压到指定文件夹内(/home/itheima)
tar [-c-v-x-f-z -C] 参数1 参数2...参数N
- -c,创建压缩文件,用于压缩模式
- -v,显示压缩、解压过程,用于查看进度
- -x,解压模式
- -f,要创建的文件,或要解压的文件,-f选项必须在所有选项中位置处于最后一个
- -z, gzip模式,不使用-z就是普通的tarball格式
- -C,选择解压的目的地,用于解压模式
例:
-
将1.txt 2.txt 3.txt压缩到test.tar文件内
tar -cvf test.tar 1.txt 2.txt 3.txt
-
将1.txt 2.txt 3.txt压缩到test.tar.gz文件内,使用gzip模式
tar -zcvf test.tar.gz 1.txt 2.txt 3.txt
注意:
- -f选项,必须在选项组合体的最后一位
- -z选项,建议在开头位置
- -C选项单独使用,和解压所需的其它参数分开
zip 命令压缩文件
可以使用zip命令,压缩文件为zip压缩包。
语法:
zip [-r] 参数1 参数2...参数N
-
-r,被压缩的包含文件夹的时候,需要使用-r选项,和rm、cp等命令的-r效果一致
示例:
- zip test.zip a.txt b.txt c.txt,将a.txt b.txt c.txt压缩到test.zip文件内zip -
- rtest.zip test itheima a.txt,将test、itheima两个文件夹和a.txt文件,压缩到test.zip文件内
unzip命令解压文件
使用unzip命令,可以方便的解压zip压缩包。
语法:
unzip [-d] 参数
- -d,指定要解压去的位置,同tar的-C选项
- 参数,被解压的zip压缩包文件
示例:- unzip test.zip,将test.zip解压到当前目录
- unzip test.zip -d /home/itheima,将test.zip解压到指定文件夹内(/home/itheima)