admin管理员组文章数量:1597475
Linux学习笔记(自用)
该笔记由尚硅谷的"3天上手LInux"视频整理而成,若有侵权,请联系作者删除
文章目录
- Linux学习笔记(自用)
- 1. 概述
- 2. 下载
- 3.文件与目录结构
- 4.VI/VIM编辑器
- 5.网络配置
- 6.系统管理
- 7.远程登录
- 8.文件目录类
- 9. 时间日期类
- 10.用户管理类
- 11.文件权限类
- 12.磁盘分区类
- 13.进程线程类
- 14. 软件包管理
- 14.1 RPM(RedHat Package Manager)
- 14.2 YUM
1. 概述
计算机硬件–>操作系统核心层kernel(硬件接口层)–>命令解释层(shell)–>外围应用层
Linux发行版本:
-
Red Hat(不太关注桌面,性能稳定强悍)
- RedHatEnterpriseLinux(RHEL)
- fedoro(免费)
- CentOS(免费)
-
debian(有非常好用的桌面)
- ubuntu
2. 下载
VMawre:VMware官网地址链接
CentOS:使用阿里镜像站下载的地址链接
创建虚拟机需要主机开启虚拟化,如果没打开,需要在BIOS设置里面把对应的虚拟化选项开启
打开终端的两种方式:
1.打开仿真终端:右键桌面打开终端,在命令行中输入init 3(3是运行级别的意思)
2.打开底层终端(大黑屏):ctrl+alt+f2~f6,然后登陆,此时鼠标消失,如果想使用鼠标就ctrl+alt;
3.退出终端回到图形化界面:ctrl+fn+alt+f1或init 5、
[root@redis100 ~]#
# 用户root和主机名redis100
# ~是当前所在的位置(当前用户的主文件夹),#是输入命令的提示符号
3.文件与目录结构
-
/bin [重点] (/usr/bin 、 /usr/local/bin):Binary的缩写, 存放着最经常使用的命令
-
/sbin (/usr/sbin 、 /usr/local/sbin):Super User,存放着系统管理员使用的系统管理程序
-
/home [重点]:存放普通用户的主目录,在Linux中每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。
-
/root [重点]:该目录为系统管理员,也称作超级权限者的用户主目录。
-
/usr/local [重点]:这是另一个给主机额外安装软件所安装的目录。一般是通过编译源码方式安装的程序。
-
/var [重点]: 这个目录中存放着在不断扩充着的东西,习惯将经常被修改的目录放在这个目录下。包括各种日志文件。
-
/media [重点]:linux系统会自动识别一些设备,例如U盘、光驱等等,当识别后,linux会把识别的设备挂载到这个目录下。
-
/mnt [重点]:系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将外部的存储挂载在/mnt/上,然后进入该目录就可以查看里的内容了。 d:/myshare
-
/etc [重点]:所有的系统管理所需要的配置文件和子目录 my.conf。
-
/usr [重点]: 这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似与windows下的program files目录。
-
/boot [重点]:存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件
-
/lib:系统开机所需要最基本的动态连接共享库,其作用类似于Windows里的DLL文件。几乎所有的应用程序都需要用到这些共享库。
-
/lost+found:该目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
-
/proc:这个目录是一个虚拟的目录,它是系统内存的映射,访问这个目录来获取系统信息
-
/srv:service缩写,该目录存放一些服务启动之后需要提取的数据
-
/sys:这是linux2.6内核的一个很大的变化。该目录下安装了2.6内核中新出现的一个文件系统 sysfs。
-
/tmp:这个目录是用来存放一些临时文件的。
-
/dev:类似于windows的设备管理器,把所有的硬件用文件的形式存储。
-
/opt:这是给主机额外安装软件所摆放的目录。如安装ORACLE数据库就可放到该目录下。默认为空。
-
/selinux [security-enhanced linux] 360:SELinux是一种安全子系统,它能控制程序只能访问特定文件 。
4.VI/VIM编辑器
三种模式:
-
正常模式:不能直接编辑文本
主要操作是:删除、复制、粘贴,在正常模式下使用u是撤回操作
-
编辑模式:在一般模式下使用i、a或b,进入编辑模式
主要操作:编辑文本
-
命令模式:在一般模式下使用:或者/,然后进行命令操作
:wq、:q:退出、:ql、:w:保存
退出编辑模式、命令模式,回到正常模式:ESC
退出VI/VIM编辑器::q
切换输入法:super(windows)+空格
:set nu :显示行号
:set nonu:去除行号显示
具体操作:
A.正常模式:
语法 | 功能描述 |
---|---|
yy | 复制光标当前行 |
y数字y | 复制光标(包含当前行)后几行 |
yw | 复制一个词(要从单词首字母开始使用) |
u | 撤销上一步 |
dd | 删除光标当前行 |
d数字d | 删除光标(含)后多少行 |
x | del |
X | Backspace |
p | 箭头移动到目的行粘贴,粘贴到光标的下一行 |
B.编辑模式
语法 | 功能描述 |
---|---|
i | 开始于当前光标前 |
a | 当前光标后 |
o | 当前光标行的下一行 |
I(shift+i) | 光标所在行最前 |
C.命令模式
语法 | 功能描述 |
---|---|
:w | 保存 |
:q | 退出编辑模式 |
:wq | 保存并退出 |
:q! | 不保存强制退出 |
/要查找的词 | n查找下一个,N往上查找 |
5.网络配置
ping:测试主机和虚拟机能否连接通信
VMnet8:pc主机虚拟出来的网卡,接到虚拟子网的路由上,使pc主机与虚拟机属于同一网段内,使主机能够与VM(虚拟机)通信
修改静态IP:为每个虚拟机(服务器的ip)赋予一个固定值,更改静态ip是在子网的ip,不是以太网的ip
(以太网的ip是外部上网的ip,所以更改的是VMnet8的ip)
(设置静态IP主要是为了方便连接时不用去查询ip)
- 如何在虚拟机里指定静态ip:
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.系统管理
计算机中,一个正在执行的程序或命令,被叫做进程(process)
启动之后一直存在、常驻内存的进程,一般称作服务(service),具体执行这些服务的进程叫做守护进程
- service服务管理(CentOS6版本 -了解即可)
基本语法:service 服务名 start|stop|restart|status
查看服务的方法:/etc/init.d/服务名,指令:ls /etc/init.d/
- systemctl(CentOS7版本 -重点掌握)
基本语法:systemctl start|stop|restart|status 服务名
查看服务的方法:/usr/lib/systemd/system,指令:/usr/lib/systemd/system
- 指令:setup,配置服务的开机自启动选项
[*] 表示当前服务开机自启动,
[ ] 表示当前服务开机不会启动,空格可以对其做更改
- 常用指令:
查看所有服务能否开机自启动的信息:systemctl list-unit-files
设置开机自启动:systemctl enable 服务名
设置开机不启动:systemctl disable 服务名
- 系统的启动过程
开机----BIOS自检和启动----/boot中获取引导文件和kernal中的内容进行系统初始化----启动init进程----判断运行级别----启动运行级别对应的服务
- CentOS6中的7种运行级别 [级别越高功能越强大(6除外)]
运行级别0:系统停机状态,系统默认运行级别不能设为0,否则不能正常启动
运行级别1:单用户工作状态,只允许root用户登录,禁止远程登录,所以只能root用户在实体的物理机上进行系统的维护,做一些相关权限更改以及比较重要的系统管理的操作,类似于windows下的安全模式。
运行级别2:多用户状态(没有NFS:网络文件系统),不支持网络
运行级别3:完全的多用户状态(有NFS),登录后进入控制台命令行模式
运行级别4:系统未使用,保留
运行级别5:X11控制台,登录后进入图形GUI模式
运行级别6:系统正常关闭并重启,默认运行级别不能设为6,否则不能正常启动
CentOS7的运行级别简化为:
multi-user.target 等价于原运行级别3(多用户有网,无图形界面)
graphical.target 等价于原运行级别5(多用户有网,有图形界面)
(target表示为一组服务的集合)
查看当前运行级别的指令:systemctl get-default
修改当前运行级别的指令:systemctl set-default TARGET.target(TARGET可以是multi-user或graphical)
语法 | 功能描述 |
---|---|
sync | 将数据由内存同步到硬盘中 |
halt | 停机,关闭系统,但不关闭电源 |
poweroff | 关机,断电 |
reboot | 重启,等同于shutdown -r now |
shutdown now | 立刻关机 |
shutdown | [选项] 时间 |
选项:
-H 相当于–halt,停机
-r=reboot,重启
-c 取消关机
7.远程登录
做完网络配置就可以尝试进行远程的登录,操作自己的服务器(虚拟机)
最经典最简单的远程登录方式ssh:ssh root@redis100
也可以使用远程登录工具Xshell等,都是基于ssh协议进行免密登录。
-
上传下载文件:使用Xshell的配套工具xftp(基于FTP协议:远程的传输文件的工具)
-
常用基本shell命令(重要)
shell可以看作是一个命令解释器,为我们提供了交互式的文本控制台界面。我们可以通过终端控制台来输入命令,由shell进行解释并最终交给内核执行
一部分基础功能的系统命令是直接内嵌在shell内的,比如cd,exit,系统加载启动之后会随着shell一起加载,常驻系统内存中,这部分命令被称为“内置(built-in)命令”;
相应的其他命令被称为"外部命令",比如ls。使用type去区分内置命令和外部命令
A.man 获得帮助信息
基本语法:man [命令或配置文件] ,比如查看ls命令的帮助信息:man ls
B.help获得shell内置命令的帮助信息
基本语法:help 命令 (功能描述:获得shell内置命令的帮助信息),比如查看cd命令的帮助信息:help cd(man -f cd)
常用快捷键 | 功能 |
---|---|
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 -P 跳转到实际物理路径,而非快捷方式路径
- mkdir 创建一个新目录,Make directory 建立目录
基本语法:mkdir [选项] 要创建的目录选项
说明:-p 创建多层目录
eg:mkdir xiyou(创建一个目录)
mkdir -p xiyou/dssz/meihouwang(创建一个多级目录)
- rmdir 删除一个空的目录,Remove directory 移除目录
基本语法:rmdir 要删除的目录
eg: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,功能:移动文件
- cat 查看文件内容,从第一行开始显示
基本语法:cat [选项] 要查看的文件
选项说明:-n 显示所有行的行号,包括空行
经验技巧:一般查看比较小的文件,一屏幕能显示全的
实例实操:查看文件内容并显示行号:cat -n houge.txt
- more 文件内容分屏查看器
more指令是一个基于VI编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容
基本语法:more 要查看的文件
操作 | 功能说明 |
---|---|
空白键(space) | 代表向下翻一页 |
Enter | 代表向下翻一行 |
q | 代表立刻离开more,不再显示该文件内容 |
f | 向下滚动一屏 |
b | 返回上一屏 |
= | 输出当前行的行号 |
:f | 输出文件名和当前行的行号 |
- less 分屏显示文件内容
less指令用来分屏查看文件内容,功能与more类似,但是比more指令更加强大,支持各种显示终端。
less指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要动态加载内容,对于显示大型文件具有较高效率
基本语法:less 要查看的文件
操作 | 功能说明 |
---|---|
空白键 | 向下翻动一页 |
[pagedown] | 向下翻动一页 |
[pageup] | 向上翻动一页 |
/字串 | 向下搜寻[字串]的功能;n:向下查找,N:向上查找 |
?字串 | 向上搜寻[字串]的功能;n:向上查找,N:向下查找 |
- echo 输出内容到控制台
基本语法:echo [ 选项] [输出内容]
选项:
-e 支持反斜线控制的字符转换
\ 输出\本身
\n 换行符
\t 制表符,也就是tab键
- head 显示文件开头部分内容,默认情况下head指令显示文件的前10行内容
基本语法:head 文件,功能:查看文件头10行内容
head -n 行数 文件,功能:查看文件头n行内容
- tail 输出文件尾部内容,默认情况下tail指令显示文件的后10行内容
基本语法:tail 文件,功能:查看文件尾部10行内容
tail -n 行数 文件,功能:查看文件尾部n行内容
tail -f 文件,功能:实时追踪该文档的所有更新,ctrl+s暂时的停止监控,ctrl+q继续监控,ctrl+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 字符串时间
eg:设置系统当前时间:date -s “2022-05-15 17:49:35”
- cal 查看日历
基本语法:cal [选项],不加选项时,显示本月日历
选项说明:具体某一年 显示这一年的日历
eg:cal 1997
10.用户管理类
linux系统本身是一个多用户多任务的分时操作系统,里面可能会有很多人都用同一台机器进行操作,甚至可能是同时登陆同时操作的,所以需要有用户管理,对于不同的人给予相应的身份
- useradd 添加新用户
基本语法:
useradd 用户名,功能:添加新用户
useradd -g 组名 用户名,功能:添加新用户到某个组
实例实操:添加一个新用户
useradd chc
- 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
- usermod 修改用户
基本语法:usermod -g 用户组 用户名
选项 :-g ,功能:修改用户的初始登录组,给定的组必须存在。默认组 id 是 1
用户组管理命令:每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。
组的增加、删除和修改实际上就是对/etc/group文件的更新。
-
groupadd 新增组,基本语法:groupadd 组名
-
groupdel 删除组,
-
groupmod 修改组
基本语法:groupmod -n 新组名 老组名
选项:-n<新组名> 指定工作组的新组名
- cat /etc/group 查看创建了哪些组
11.文件权限类
- ll查看的详细信息分别是:
文件类型与权限 链接数 文件属主 文件属组 文件大小 建立或最近修改的时间 文件名字
如果查看到是文件:链接数指的是硬链接个数。
如果查看的是文件夹:链接数指的是子文件夹个数。
如果没有权限,就会出现减号[ - ]而已。
从左至右用0-9这些数字来表示:
0 首位表示类型,在Linux中第一个字符代表这个文件是目录、文件或链接文件等
- 代表文件
d 代表目录
l 链接文档(link file)
c 字符类型的设备文件,比如鼠标、键盘
b 块设备文件,比如硬盘
第1-3位确定属主(该文件的所有者)拥有该文件的权限。
r:读,w:写,x:执行
第4-6位确定属组(所有者的同组用户)拥有该文件的权限。
r:读,-:无,x:执行
第7-9位确定其他用户拥有该文件的权限 。
r:读,-:无,x:执行
rwx 作用文件和目录的不同解释
作用到文件:
[ r ]代表可读(read): 可以读取,查看
[ w ]代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件。
[ x ]代表可执行(execute):可以被系统执行
作用到目录:
[ r ]代表可读(read): 可以读取,ls查看目录内容
[ w ]代表可写(write): 可以修改,目录内创建+删除+重命名目录
[ x ]代表可执行(execute):可以进入该目录
- chmod 改变权限
第一种方式变更权限:chmod [{ugoa}{±=}{rwx}] 文件或目录
=:是给权限赋值,+:是增加权限,-:是减少权限
比如:chmod u+x 文件
第二种方式变更权限:chmod [mode=421 ] [文件或目录]
r=4,w=2,x=1,rwx=4+2+1=7
- chown 改变所有者
基本语法:
chown [选项] [最终用户] [文件或目录]
选项:
-R 递归改变文件所有者或所有组
eg:
改变文件所有者(属主):chown 用户 文件名
改变文件所有者和所属组(属组):chown 用户名:用户组 文件名
- chgrp 改变所属组
基本语法:chgrp [最终用户组] [文件或目录]
- find 查找文件或者目录,find指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件显示在终端。
基本语法:
find [搜索范围] [选项]
选项:
-name<查询方式> 按照指定的文件名查找模式查找文件
-user<用户名> 查找属于指定用户名的所有文件
-size<文件大小> 按照指定的文件大小查找文件。
eg:
按文件名:根据名称查找/目录下的filename.txt文件。
find cui/ -name "*.txt"
按拥有者:查找/opt目录下,用户名称为-user的文件。
find cui/ -user chc
按文件大小:在/home目录下查找大于200m的文件(+n 大于 -n小于 n等于)
find /home -size +204800
- locate 快速定位文件路径
locate 指令利用事先建立的系统中所有文件名称及路径的 locate 数据库实现快速定位给定的文件。
Locate 指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更新 locate时刻。
基本语法:
locate [搜索文件]
由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用 updatedb 指令更新locate数据库。
- grep 过滤查找及“|” 管道符
管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理
基本语法:
grep 选项 查找内容 源文件
选项:
-n 显示匹配行及行号。
eg:
查找某文件在第几行:ls | grep -n test
- gzip/gunzip 压缩和解压缩
基本语法:
gzip 文件
gunzip 文件.gz
说明:
(1)只能压缩文件不能压缩目录
(2)不保留原来的文件
(3)同时多个文件会产生多个压缩包
- zip/unzip 压缩和解压缩
基本语法:
zip [选项] XXX.zip 将要压缩的内容
unzip [选项] XXX.zip (功能描述:解压缩文件)
zip选项:-r 压缩目录
unzip选项:-d<目录> 指定解压后文件的存放目录
说明:
zip 压缩命令在windows/linux都通用,可以压缩目录且保留源文件
- tar 打包
基本语法:
tar [选项] XXX.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层
eg:
查看当前用户主目录占用的磁盘空间大小,du -sh
- df 查看磁盘空间使用情况,disk free 空余磁盘
基本语法:
df [选项]
选项:
-h ,以人们交易阅读的GBytes,MBytes,KBytes等格式自行显示
eg:
查看磁盘使用情况:df -h
-
lsblk 查看设备挂载情况
基本语法:lsblk
选项:-f,查看详细的设备挂载情况,显示文件系统信息
- mount/umount 挂载/卸载
Linux中每个分区都是用来组成整个文件系统的一部分,它在用一种叫做“挂载”的处理方法,它整个文件系统中包含了一整套的文件和目录,并将一个分区和一个目录联系起来,要载入的那个分区将使它的存储空间在这个目录下获得。
挂载前准备:必须要有光盘或者已经连接镜像文件
基本语法:
mount [-t vfstype] [-o options] device dir (功能描述:挂载设备)
umount 设备文件名或挂载点 (功能描述:卸载设备)
参数说明:
-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)
eg:
挂载光盘镜像文件:
mkdir /mnt/cdrom,建立挂载点
mount -t iso9660 /dev/cdrom /mnt/cdrom
# 设备/dev/cdrom挂载到挂载点/mnt/cdrom中
ll /mnt/cdrom
卸载光盘镜像文件:umount /mnt/cdrom
- fdisk 分区(该命令必须在root用户下才能使用)
基本语法:
fdisk -l # 查看磁盘分区详情,显示所有硬盘的分区列表
fdisk 磁盘设备名 # 对新增硬盘进行分区操作
说明:
Linux 分区
Device:分区序列
Boot:引导
Start:从X磁柱开始
End:到Y磁柱结束
Blocks:容量
Id:分区类型ID
System:分区类型
分区操作按键说明
m:显示命令列表
p:显示当前磁盘分区
n:新增分区
w:写入分区信息并退出
q:不保存分区信息直接退出
13.进程线程类
进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地址空间,并占用一定的系统资源。
- ps 查看当前系统进程状态,process status 进程状态
基本语法:
ps aux | grep xxx,功能:查看系统中所有进程
ps -ef | grep xxx,功能:可以查看子父进程之间的关系
选项:
a 列出带有终端的所有用户的进程
x 列出当前用户的所有进程,包括没有终端的进程
u 面向用户友好的显示风格
-e 列出所有进程
-u 列出某个用户关联的所有进程
-f 显示完整格式的进程列表
功能说明:
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:产生此进程的命令名
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
- netstat 显示网络状态和端口占用信息
基本语法:
netstat -anp | grep 进程号 (功能描述:查看该进程网络信息)
netstat –nlp | grep 端口号 (功能描述:查看网络端口号占用情况)
选项:
-a 显示所有正在监听(listen)和未监听的套接字(socket)
-n 拒绝显示别名,能显示数字的全部转化成数字
-l 仅列出在监听的服务状态
-p 表示显示哪个进程在调用
- crontab 系统定时任务
crontab 服务管理:重新启动 crond 服务 systemctl restart crond
crontab 定时任务设置
基本语法:crontab [选项]
选项:
-e 编辑 crontab 定时任务
-l 查询 crontab 任务
-r 删除当前用户所有的 crontab 任务
14. 软件包管理
14.1 RPM(RedHat Package Manager)
RedHat软件包管理工具,类似windows里面的setup.exe,是Linux这系列操作系统里面的打包安装工具
-
查询命令(rpm -qa)
基本语法:rpm -qa (功能描述:查询q所安装的所有a rpm软件包)
由于软件包比较多,一般都会采取过滤。rpm -qa | grep rpm软件包
eg:查询firefox软件安装情况:rpm -qa | grep firefox
- 卸载命令(rpm -e)
基本语法:rpm -e RPM软件包 rpm -e --nodeps 软件包
选项:
–nodeps 卸载软件时,不检查依赖。(这样的话,那些使用该软件包的软件在此之后可能就不能正常工作了)
- 安装命令(rpm -ivh)
基本语法:rpm -ivh RPM包全名
选项:
-i install,安装
-v verbose,显示详细信息
-h hash,进度条
–nodeps 安装前不检查依赖
14.2 YUM
YUM(全称为 Yellow dog Updater, Modified)是一个在 Fedora 和 RedHat 以及 CentOS中的 Shell 前端软件包管理器。
基于 RPM 包管理,能够从指定的服务器自动下载 RPM 包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次次下载、安装。
YUM类似于我们java开发中的maven工具,可以从镜像网站上下载应用程序,并直接安装
- 常用命令
基本语法:yum [选项] [参数]
选项:-y,对所有提问都回答yes
参数:
install,安装rpm软件包
update,更新rpm软件包
check-update,检查是否有可用的更新rpm软件包
remove,删除指定的rpm软件包
list,显示软件包信息
clean,清理yum过期的缓存
deplist,显示yum软件包的所有依赖关系
eg:采用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 文件
cp CentOS-Base.repo CentOS-Base.repo.backup
3、下载网易163 或者是 aliyun 的 repos 文件,任选其一
wget http://mirrors.aliyun/repo/Centos-7.repo //阿里云
wget http://mirrors.163/.help/CentOS7-Base-163.repo //网易163
4、使用下载好的 repos文件替换默认的 repos文件
mv CentOS7-Base-163.repo CentOS-Base.repo
5、清理旧缓存数据,缓存新数据
yum clean all
yum makecache # 把服务器的包信息下载到本地电脑缓存起来
6、测试
yum list | grep firefox
yum -y install firefox
版权声明:本文标题:Linux学习笔记(自用) 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://m.elefans.com/dianzi/1728287170a1152305.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论