Linux 学习笔记

Linux 操作

学习视频链接:狂神说Linux

  • Ctrl + 鼠标滚动 - 放大和缩小字体
  • 上传文件使用 Xftp / VMware Tools

关机

  • 关机指令:shutdown;

    sync 	 # 将数据由内存同步到硬盘中
    shutdown   # 关机指令,可以通过 man shutdown 来看一下帮助文档
    
    shutdown -h 10   # 10分钟后关机
    shutdown -h now  # 立刻关机
    shutdown -h 20:25  # 系统将在20:25关机
    shutdown -h +10  # 10分钟后关机
    shutdown -r now  # 系统立马重启
    shutdown -r +10  # 系统十分钟后重启
    reboot           # 重启
    halt             # 关闭系统 等同于 shutdown -h now / poweroff
    
    首先运行 sync 命令,把内存中的数据写到磁盘中。
    

系统目录结构

  • 一切皆文件

  • 根目录 / ,所有文件皆挂载在这个节点下

    ls /
    
  • 目录解释:

/bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令。

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

/dev : dev是Device(设备)的缩写, 存放的是Linux的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的。

/etc: 这个目录用来存放所有的系统管理所需要的配置文件和子目录。

/home:用户的主目录,在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。

/lib:这个目录里存放着系统最基本的动态连接共享库,其作用类似于Windows里的DLL文件。

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

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

/mnt:系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在/mnt/上,然后进入该目录就可以查看光驱里的内容了。

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

/proc:这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。

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

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

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

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

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

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

/usr/bin: 系统用户使用的应用程序。

/usr/sbin: 超级用户使用的比较高级的管理程序和系统守护程序。

/usr/src: 内核源代码默认的放置目录。

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

/run:是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。
  • /www:存放服务器网站相关的资源,环境,网站的项目

常用的基本命令

目录管理

  • 绝对路径:路径的全称 / 相对路径

    白 - 文件 / 蓝 - 文件夹
    
    1.
    cd :切换目录命令
    cd .. :返回上一级目录
    ./ :当前目录
    
    2.
    ls :列出目录 - 最常被使用的
    -a 参数 :all,查看全部的文件,包含隐藏文件
    -l 参数 :列出所有的文件,包含文件的属性和权限,没有隐藏文件
    
    3.
    cd 目录名 (绝对路径都是以 / 开头,相对路径 - 对于当前目录该如何查找 ../../)
    pwd 显示当前用户所在的目录
    
    4.
    mkdir 创建目录
    mkdir -p test1/test2/test3 - 递归创建目录
    
    5.
    rmdir 删除目录 - 仅能删除空的目录,删除多个目录需要添加 -p 参数
    rmdir -p test1/test2/test3 - 删除层叠目录
    
    6.
    cp 复制文件或目录
    cp install.sh kuangstudy
    若有文件重复,选择覆盖(y)或者放弃(n)
    
    7.
    rm 移除文件或者目录
    -f :忽略不存在的文件,不会出现警告,强制删除
    -r :递归删除目录
    -i :互动,询问是否删除
    rm -rf / # 将系统中所有的文件删除
    
    8.
    mv 移动文件或者目录 / 重命名文件
    -f :强制
    -u :只替换已经更新过的目录
    mv kuangstudy kuangstudy2 - 重命名文件夹
    

基本属性

d : 目录文件
- : 文件
l : 链接文档 (link file) - 具有指向文件
b : 装置文件里面的可供储存的接口设备(可随机存取装置)
c : 串行端口设备,如键盘、鼠标(一次性读取装置)

r : 可读 - read 	1/4/7
w : 可写 - write 	2/5/8
x : 可执行 - execute 	3/6/9

用户按照组分类,一个用户属于一个或多个组
文件所有者以外的用户可以分为 文件所有者的同组用户 + 其他用户
Linux系统按照 文件所有者(属主)、文件所有者同组用户(属组)、其他用户 规定了不同的文件访问权限

chgrp : 更改文件属组
chgrp [-R] 属组名 文件名
-R : 递归更改文件属组,即更改一个文件下所有文件的属性

chown : 更改文件属主,也可以同时更改文件属组
chown [-R] 属主名 文件名
chown [-R] 属主名:属组名 文件名

chmod : 更改文件 9 个属性
Linux文件属性设置方法:数字 + 符号
Linux文件基本权限:owner + group + others (rwx)
r:4 / w:2 / x:1
[-rwxrwx---] :owner - 7 / group - 7 / others - 0
chmod 777 filename - 给文件赋予所有用户可读可写可执行

文件内容查看

  • Linux 系统中使用以下命令来查看文件的内容:
cat :由第一行开始显示文件内容
tac :由最后一行开始显示文件内容
nl  :显示的时候,顺道输出行号!
more :一页一页的显示文件内容 (空格代表下翻页 / 回车代表向下看一行 / :f 行号配置)
less :一页一页的显示文件内容,可以往前翻页 (空格下翻页,上下键代表翻动页面 - pageDown / pageUp,退出 q 命令)
		  查找字符串 / - 向下查询,? - 向上查询,n - 向下搜寻下一个,N - 向上寻找下一个
head :只看头几行 (通过 -n 参数显示 头几行)
tail :只看尾巴行 (通过 -n 参数显示 倒几行)
man :查看各个命令的使用文档,如 man cp

网络配置目录:`cd /etc/sysconfig/network-scripts`
ifconfig :查看网络配置
cat ifcfg-ens32 : 读取配置文件
nl  ifcfg-ens32 : 显示行号,读取配置文件

Linux 链接

  • 硬链接:A——B,假设B是A的硬链接,那么他们两个指向了同一个文件!允许一个文件拥有多个路径,用户可以通过这种机制建立硬链接到一些重要文件上,防止误删!
  • 软链接:类似 Windows 下的快捷方式,删除源文件后,快捷方式也无法访问。
创建连接 ln 命令
touch :创建文件 - touch f1    /    ln f1 f2 - 硬链接     /     ln -s f1 f3 - 软链接(符号链接)
echo  :输入字符串,也可以输入到文件中 - echo "i love you" >>f1 		(给f1文件中写入一些字符串)
cat f1 - i love you / cat f2 - i love you / cat f3 - i love you
删除 f1 之后,可以查看 f2,无法查看 f3

Vim 编辑器

vim hello.txt :若文件不存在,则新建文件;若文件已存在,则编辑文件。

  • 命令模式(Command mode):
    • i - 切换到输入模式,以输入字符
    • x - 删除当前光标所在处的字符
    • : - 切换到底线命令模式,以在最底一行输入命令。如果是编辑模式,需要先退出 - Esc
  • 输入模式(Insert mode):
    • 字符按键以及Shift组合,输入字符
    • Enter,回车键,换行
    • BACK SPACE,退格键,删除光标前一个字符
    • DEL,删除键,删除光标后一个字符
    • 方向键,在文本中移动光标
    • HOME/END,移动光标到行首 / 行尾
    • Page Up / Page Down,上 / 下翻页
    • Insert,切换光标为输入 / 替换模式,光标将变成竖线 / 下划线
    • ESC,退出输入模式,切换到命令模式
  • 底线命令模式(Last line mode):
    • q - 退出程序
    • w - 保存文件
  1. 新建或者编辑文件,按i进入编辑模式,编写内容,完成后退出编辑模式,Esc,退出之后进入底线命令模式,:wq保存退出。

第一部分:一般模式可用的光标移动、复制粘贴、搜索替换等

移动光标的方法
h 或 向左箭头键(←)光标向左移动一个字符
j 或 向下箭头键(↓)光标向下移动一个字符
k 或 向上箭头键(↑)光标向上移动一个字符
l 或 向右箭头键(→)光标向右移动一个字符
[Ctrl] + [f]屏幕『向下』移动一页,相当于 [Page Down]按键 (常用)
[Ctrl] + [b]屏幕『向上』移动一页,相当于 [Page Up] 按键 (常用)
[Ctrl] + [d]屏幕『向下』移动半页
[Ctrl] + [u]屏幕『向上』移动半页
+光标移动到非空格符的下一行
-光标移动到非空格符的上一行
n< space>那个 n 表示『数字』,例如 20 。按下数字后再按空格键,光标会向右移动这一行的 n 个字符。
0 或功能键[Home]这是数字『 0 』:移动到这一行的最前面字符处 (常用)
$ 或功能键[End]移动到这一行的最后面字符处(常用)
H光标移动到这个屏幕的最上方那一行的第一个字符
M光标移动到这个屏幕的中央那一行的第一个字符
L光标移动到这个屏幕的最下方那一行的第一个字符
G移动到这个档案的最后一行(常用)
nGn 为数字。移动到这个档案的第 n 行。例如 20G 则会移动到这个档案的第 20 行(可配合 :set nu)
gg移动到这个档案的第一行,相当于 1G 啊!(常用)
n< Enter>n 为数字。光标向下移动 n 行(常用)
搜索替换
/word向光标之下寻找一个名称为 word 的字符串。例如要在档案内搜寻 vbird 这个字符串,就输入 /vbird 即可!(常用)
?word向光标之上寻找一个字符串名称为 word 的字符串。
n这个 n 是英文按键。代表重复前一个搜寻的动作。举例来说, 如果刚刚我们执行 /vbird 去向下搜寻 vbird 这个字符串,则按下 n 后,会向下继续搜寻下一个名称为 vbird 的字符串。如果是执行 ?vbird 的话,那么按下 n 则会向上继续搜寻名称为 vbird 的字符串!
N这个 N 是英文按键。与 n 刚好相反,为『反向』进行前一个搜寻动作。例如 /vbird 后,按下 N 则表示『向上』搜寻 vbird 。
删除、复制与粘贴
x, X在一行字当中,x 为向后删除一个字符 (相当于 [del] 按键), X 为向前删除一个字符(相当于 [backspace] 亦即是退格键) (常用)
nxn 为数字,连续向后删除 n 个字符。举例来说,我要连续删除 10 个字符, 『10x』。
dd删除游标所在的那一整行(常用)
nddn 为数字。删除光标所在的向下 n 行,例如 20dd 则是删除 20 行 (常用)
d1G删除光标所在到第一行的所有数据
dG删除光标所在到最后一行的所有数据
d$删除游标所在处,到该行的最后一个字符
d0那个是数字的 0 ,删除游标所在处,到该行的最前面一个字符
yy复制游标所在的那一行(常用)
nyyn 为数字。复制光标所在的向下 n 行,例如 20yy 则是复制 20 行(常用)
y1G复制游标所在行到第一行的所有数据
yG复制游标所在行到最后一行的所有数据
y0复制光标所在的那个字符到该行行首的所有数据
y$复制光标所在的那个字符到该行行尾的所有数据
p, Pp 为将已复制的数据在光标下一行贴上,P 则为贴在游标上一行!举例来说,我目前光标在第 20 行,且已经复制了 10 行数据。则按下 p 后, 那 10 行数据会贴在原本的 20 行之后,亦即由 21 行开始贴。但如果是按下 P 呢?那么原本的第 20 行会被推到变成 30 行。(常用)
J将光标所在行与下一行的数据结合成同一行
c重复删除多个数据,例如向下删除 10 行,[ 10cj ]
u复原前一个动作。(常用)
[Ctrl]+r重做上一个动作。(常用)

第二部分:一般模式切换到编辑模式的可用的按钮说明

进入输入或取代的编辑模式
i, I进入输入模式(Insert mode):i 为『从目前光标所在处输入』, I 为『在目前所在行的第一个非空格符处开始输入』。(常用)
a, A进入输入模式(Insert mode):a 为『从目前光标所在的下一个字符处开始输入』, A 为『从光标所在行的最后一个字符处开始输入』。(常用)
o, O进入输入模式(Insert mode):这是英文字母 o 的大小写。o 为『在目前光标所在的下一行处输入新的一行』;O 为在目前光标所在处的上一行输入新的一行!(常用)
r, R进入取代模式(Replace mode):r 只会取代光标所在的那一个字符一次;R会一直取代光标所在的文字,直到按下 ESC 为止;(常用)
[Esc]退出编辑模式,回到一般模式中(常用)

第三部分:一般模式切换到指令行模式的可用的按钮说明

指令行的储存、离开等指令
:w将编辑的数据写入硬盘档案中(常用)
:w!若文件属性为『只读』时,强制写入该档案。不过,到底能不能写入, 还是跟你对该档案的档案权限有关啊!
:q离开 vi (常用)
:q!若曾修改过档案,又不想储存,使用 ! 为强制离开不储存档案。
注意一下啊,那个惊叹号 (!) 在 vi 当中,常常具有『强制』的意思~
:wq储存后离开,若为 :wq! 则为强制储存后离开 (常用)
ZZ这是大写的 Z 喔!若档案没有更动,则不储存离开,若档案已经被更动过,则储存后离开!
:w [filename]将编辑的数据储存成另一个档案(类似另存新档)
:r [filename]在编辑的数据中,读入另一个档案的数据。亦即将 『filename』 这个档案内容加到游标所在行后面
:n1,n2 w [filename]将 n1 到 n2 的内容储存成 filename 这个档案。
:! command暂时离开 vi 到指令行模式下执行 command 的显示结果!例如 『:! ls /home』即可在 vi 当中看 /home 底下以 ls 输出的档案信息!
:set nu显示行号,设定之后,会在每一行的前缀显示该行的行号
:set nonu与 set nu 相反,为取消行号!

账号管理

  • 用户账号的添加、删除与修改
  • 用户口令的管理
  • 用户组的管理
  1. 添加用户
useradd 选项 用户名

参数说明:

  • 选项 :

    • -c comment 指定一段注释性描述。
    • -d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。
    • -g 用户组 指定用户所属的用户组。
    • -G 用户组,用户组 指定用户所属的附加组。
    • -m 使用者目录如不存在则自动建立。
    • -s Shell文件 指定用户的登录Shell。
    • -u 用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。
  • 用户名 :

    • 指定新账号的登录名。
  • 测试:

  • # 此命令创建了一个用户kuangshen,其中-m选项用来为登录名kuangshen产生一个主目录 /home/kuangshen
    [root@kuangshen home]# useradd -m kuangshen
    
  • 增加用户账号就是在/etc/passwd文件中为新用户增加一条记录,同时更新其他系统文件如/etc/shadow, /etc/group等。

  1. 删除用户
  • 删除用户账号就是要将/etc/passwd等系统文件中的该用户记录删除,必要时还删除用户的主目录。
  • 删除一个已有的用户账号使用userdel命令,其格式如下:
userdel 选项 用户名
  • 常用的选项是 -r,它的作用是把用户的主目录一起删除。
[root@kuangshen home]# userdel -r kuangshen
  • 此命令删除用户kuangshen在系统文件中(主要是/etc/passwd, /etc/shadow, /etc/group等)的记录,同时删除用户的主目录。
  1. 修改用户
  • 修改用户账号就是根据实际情况更改用户的有关属性,如用户号、主目录、用户组、登录Shell等。
  • 修改已有用户的信息使用usermod命令,其格式如下:
usermod 选项 用户名
  • 常用的选项包括-c,-d,-m,-g,-G,-s,-u,-o等,这些选项的意义与useradd命令中的选项一样,可以为用户指定新的资源值。
# usermod -s /bin/ksh -d /home/z –g developer kuangshen
  • 此命令将用户kuangshen的登录Shell修改为ksh,主目录改为/home/z,用户组改为developer。
  1. 切换用户

    1. 切换用户的命令为:su username

    2. 从普通用户切换到root用户,还可以使用命令:sudo su

    3. 在终端输入exitlogout或使用快捷方式ctrl+d,可以退回到原来用户,其实ctrl+d也是执行的exit命令

    4. 在切换用户时,如果想在切换用户之后使用新用户的工作环境,可以在suusername之间加-,例如:【su - root】

    5. hostname - 查看主机名

    $ 表示普通用户

    # 表示超级用户,也就是root用户

  2. 用户的密码配置问题

    • 一般通过root配置,需要输入密码

    • 超级用户:

      passwd username:
      new password:
      re  password:
      
    • 普通用户:

      passwd
      (current) UNIX password:
      new password:             # 密码不能太过于简单
      re  password:
      
  3. 锁定账户

passwd -l murphy 				# 锁定之后这个用户就不能登录了
passwd -d murphy        # 没有密码了,也不能登录了

用户组管理

  • 属主 、 属组,每一个用户都有一个用户组,系统可一对一个用户组中的所有用户进行集中管理,(开发,测试,运维,root).
  • 不同Linux系统对用户组的规定有所不同,如Linux下的用户属于与他同名的用户组,这个用户组在创建用户时同时创建了.
  • 用户组的管理涉及用户组的添加, 删除和修改.==组的添加,删除和修改实际上就是对/etc/group文件的更新.
  1. 创建一个用户组 - groupadd

    groupadd murphy 
    cat /etc/group
    
    创建完用户组后可以得到一个组的ID,这个ID是可以指定的! -g 520, 如果不指定则自增 1
    
  2. 删除用户组 - groupdel

    groupdel murphy
    cat /etc/group
    
  3. 修改用户组的权限信息和名字 - groupmod -g -n

    group -g 666 -n newmurphy murphy
    修改 murphy 用户组 id 为 666,重命名为 newmurphy
    
  4. 用户切换用户组

    # 登录当前用户 murphy
    $ newgrp root
    
  5. 文件的查看

    /etc/passwd
    用户名:口令(登录密码,我们不可见):用户标识号:组标识号:注释性描述:主目录:登录Shell
    
    这个文件中的每一行都代表这一个用户,我们可以从这里看出这个用户的主目录在那里,可以看到属于哪一个组!
    登录口令: 把真正的加密后的用户口令字存放到/etc/shadow文件中,保证我们密码的安全性!
    用户组的所有信息都存放在/etc/group文件中
    

磁盘管理

  1. df - 列出文件系统整体的磁盘使用量
  2. du - 检查磁盘空间使用量

**df**

  • df命令参数功能:检查文件系统的磁盘空间占用情况。可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息。
  • 语法:
df [-ahikHTm] [目录或文件名]
  • 选项与参数:

    • -a :列出所有的文件系统,包括系统特有的 /proc 等文件系统;
    • -k :以 KBytes 的容量显示各文件系统;
    • -m :以 MBytes 的容量显示各文件系统;
    • -h :以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;
    • -H :以 M=1000K 取代 M=1024K 的进位方式;
    • -T :显示文件系统类型, 连同该 partition 的 filesystem 名称 (例如 ext3) 也列出;
    • -i :不用硬盘容量,而以 inode 的数量来显示
  • 测试:

# 将系统内所有的文件系统列出来!
# 在 Linux 底下如果 df 没有加任何选项
# 那么默认会将系统内所有的 (不含特殊内存内的文件系统与 swap) 都以 1 Kbytes 的容量来列出来!
[root@kuangshen /]# df
Filesystem     1K-blocks   Used Available Use% Mounted on
devtmpfs          889100       0    889100   0% /dev
tmpfs             899460     704    898756   1% /dev/shm
tmpfs             899460     496    898964   1% /run
tmpfs             899460       0    899460   0% /sys/fs/cgroup
/dev/vda1       41152812 6586736  32662368  17% /
tmpfs             179896       0    179896   0% /run/user/0
# 将容量结果以易读的容量格式显示出来
[root@kuangshen /]# df -h
Filesystem     Size Used Avail Use% Mounted on
devtmpfs       869M     0 869M   0% /dev
tmpfs           879M 708K 878M   1% /dev/shm
tmpfs           879M 496K 878M   1% /run
tmpfs           879M     0 879M   0% /sys/fs/cgroup
/dev/vda1       40G  6.3G   32G  17% /
tmpfs           176M     0 176M   0% /run/user/0
# 将系统内的所有特殊文件格式及名称都列出来
[root@kuangshen /]# df -aT
Filesystem     Type       1K-blocks   Used Available Use% Mounted on
sysfs         sysfs               0       0         0    - /sys
proc           proc                0       0         0    - /proc
devtmpfs       devtmpfs       889100       0    889100   0% /dev
securityfs     securityfs          0       0         0    - /sys/kernel/security
tmpfs         tmpfs          899460     708    898752   1% /dev/shm
devpts         devpts              0       0         0    - /dev/pts
tmpfs         tmpfs          899460     496    898964   1% /run
tmpfs         tmpfs          899460       0    899460   0% /sys/fs/cgroup
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/systemd
pstore         pstore              0       0         0    - /sys/fs/pstore
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/freezer
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/cpuset
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/hugetlb
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/blkio
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/net_cls,net_prio
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/memory
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/pids
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/cpu,cpuacct
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/devices
cgroup         cgroup              0       0         0    - /sys/fs/cgroup/perf_event
configfs       configfs            0       0         0    - /sys/kernel/config
/dev/vda1     ext4         41152812 6586748  32662356  17% /
systemd-1      -                   -       -         -    - /proc/sys/fs/binfmt_misc
mqueue         mqueue              0       0         0    - /dev/mqueue
debugfs       debugfs             0       0         0    - /sys/kernel/debug
hugetlbfs     hugetlbfs           0       0         0    - /dev/hugepages
tmpfs         tmpfs          179896       0    179896   0% /run/user/0
binfmt_misc   binfmt_misc         0       0         0    - /proc/sys/fs/binfmt_misc
# 将 /etc 底下的可用的磁盘容量以易读的容量格式显示

[root@kuangshen /]# df -h /etc
Filesystem     Size Used Avail Use% Mounted on
/dev/vda1       40G  6.3G   32G  17% /

du

  • Linux du命令也是查看使用空间的,但是与df命令不同的是Linux du命令是对文件和目录磁盘使用的空间的查看,还是和df命令有一些区别的,这里介绍Linux du命令。
  • 语法:
du [-ahskm] 文件或目录名称
  • 选项与参数:

    • -a :列出所有的文件与目录容量,因为默认仅统计目录底下的文件量而已。
    • -h :以人们较易读的容量格式 (G/M) 显示;
    • -s :列出总量而已,而不列出每个各别的目录占用容量;
    • -S :不包括子目录下的总计,与 -s 有点差别。
    • -k :以 KBytes 列出容量显示;
    • -m :以 MBytes 列出容量显示;
  • 测试:

# 只列出当前目录下的所有文件夹容量(包括隐藏文件夹):
# 直接输入 du 没有加任何选项时,则 du 会分析当前所在目录的文件与目录所占用的硬盘空间。
[root@kuangshen home]# du
16./redis
8./www/.oracle_jre_usage  # 包括隐藏文件的目录
24./www
48.                        # 这个目录(.)所占用的总量
# 将文件的容量也列出来
[root@kuangshen home]# du -a
4./redis/.bash_profile
4./redis/.bash_logout    
....中间省略....
4./kuangstudy.txt # 有文件的列表了
48.
# 检查根目录底下每个目录所占用的容量
[root@kuangshen home]# du -sm /*
0/bin
146/boot
.....中间省略....
0/proc
.....中间省略....
1/tmp
3026/usr  # 系统初期最大就是他了啦!
513/var
2666/www
  • 通配符 * 来代表每个目录。
  • df 不一样的是,du 这个命令其实会直接到文件系统内去搜寻所有的文件数据。

磁盘挂载与卸除

  • 根文件系统之外的其他文件要想能够被访问,都必须通过“关联”至根文件系统上的某个目录来实现,此关联操作即为“挂载”,此目录即为“挂载点”,解除此关联关系的过程称之为“卸载”
  • Linux 的磁盘挂载使用mount命令,卸载使用umount命令。
  • 磁盘挂载语法:
mount [-t 文件系统] [-L Label名] [-o 额外选项] [-n] 装置文件名 挂载点
  • 测试:
# 将 /dev/hdc6 挂载到 /mnt/hdc6 上面!
[root@www ~]# mkdir /mnt/hdc6
[root@www ~]# mount /dev/hdc6 /mnt/hdc6
[root@www ~]# df
Filesystem           1K-blocks     Used Available Use% Mounted on
/dev/hdc6              1976312     42072   1833836   3% /mnt/hdc6
  • 磁盘卸载命令 umount 语法:
umount [-fn] 装置文件名或挂载点
  • 选项与参数:
    • -f :强制卸除!可用在类似网络文件系统 (NFS) 无法读取到的情况下;
    • -n :不升级 /etc/mtab 情况下卸除。
    • 卸载/dev/hdc6
[root@www ~]# umount /dev/hdc6

进程管理

文件:读写执行(查看,创建,删除,移动,复制,编辑) | 权限(用户,用户组)|系统(磁盘,进程)

  • 基本概念

    • 在Linux中,每一个程序都是有自己的一个进程,每个进程都有一个id
    • 每一个进程都会有一个父进程!
    • 进程可以有两种存在方式:前台 / 后台
    • 一般的话服务都是后台运行的,基本的程序都是前台运行的!
  • 命令

    • ps - 查看当前系统中正在执行的各种进程的信息!
    • ps -xx
      • -a :显示当前终端进行的所有的进程信息(当前的进程)
      • -u :以用户的信息显示进程
      • -x :显示后台运行进程的参数
    # 查看所有的进程
    ps -aux | grep mysql
    
    # | - 在 linux 中称为 管道符  A|B - A操作结果输出来操作B命令
    # grep - 查找文件中符合条件的字符串
    

    ps -xx | grep 进程名字 + 过滤进程信息 —— 重要

    ps -ef可以查看到父进程的信息

    `ps -ef | grep mysql` - 看父进程我们一般可以通过目录树结构来查看
    
    # 进程树
    pstree -pu
    				-p 显示父ID
    				-u 显示用户组
    

    结束进程:杀掉进程,等价于 Win 结束任务

    • kill -9 进程ID - 强制结束该进程
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xmurphymurphy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值