磁盘管理+三剑客之awk

一、磁盘管理

Linux系统中磁盘管理就是将硬盘通过挂载的方式挂载到linux文件系统中。

1、挂载磁盘的步骤
1、磁盘分区
2、挂载 2、磁盘分区
fdisk:分区2TB以下的磁盘,最多可以分4个分区
gdisk:分区2TB以上的磁盘,最多可以分128个分区 3、添加一块磁盘
lsblk : 查看本机的磁盘
df -h : 查看本机的分区 4、磁盘分区
n : 新建一个分区
p : 打印分区表
w : 写入磁盘并退出
q : 退出
d : 删除一个分区 5、挂载磁盘分区
1、格式化文件系统
mkfs.xfs /dev/sdb1 6、总结
1、关机
2、添加硬盘
3、创建分区
fdisk /dev/sdb

gdisk /dev/sdb
4、格式化文件系统
mkfs.xfs /dev/sdb1
5、挂载
mount /dev/sdb1 /mnt

二、格式化命令awk

awk主要是用来格式化文本。

1、awk的语法

	awk [参数] [处理规则] [操作对象]

2、参数

	-F : 指定文本分隔符(默认是以空格作为分隔符)
awk -F'f' '{print $NF}' 9.txt
以空格分割: awk -F' ' '{print $NF}' 9.txt
案例:打印系统所有用户的解析器
awk -F: '{print $NF}' /etc/passwd

3、awk的生命周期

	grep、sed和awk都是读一行处理一行,直至处理完成。

	1、接收一行作为输入
2、把刚刚读入进来得到文本进行分解
3、使用处理规则处理文本
4、输入一行,赋值给$0,直至处理完成
5、把处理完成之后的所有的数据交给END{}来再次处理

4、awk中的预定义变量

	$0	: 代表当前行
[root@localhost ~]# awk -F: '{print $0, "---"}' /etc/passwd
'''也就是显示每一行,并且在每一行的后面添加 ---
$n :代表第n列
[root@localhost ~]# awk -F: '{print $1}' /etc/passwd
$1:显示文本每一行第一列内容
NF :记录当前行的字段数
[root@localhost ~]# awk -F: '{print NF}' /etc/passwd
NF:批量显示文本内每一行有多少列 >>> 7 [root@localhost ~]# awk -F: '{print $NF}' /etc/passwd
$NF:显示文本内所有以冒号:分割的最后一列内容
NR :用来记录行号
[root@localhost ~]# awk -F: '{print NR}' /etc/passwd
NR:总共多少行,一行一行的显示行号(第几行)
FS :指定文本内容分隔符(默认是空格)
[root@localhost ~]# awk 'BEGIN{FS=":"}{print $NF, $1}' /etc/passwd
等同于:[root@localhost ~]# awk -F: '{print $NF,$1}' /etc/passwd
作用:显示由冒号:分割的第一列和最后一列内容
FS 的优先级要高于 -F
OFS:
'''OFS :指定打印分隔符(默认空格)'''
[root@localhost ~]# awk -F: 'BEGIN{OFS=" >>> "}{print $NF, $1}' /etc/passwd
作用:将最后一列和第一列之间以 >>> 分割
默认情况:
[root@localhost ~]# awk -F: 'BEGIN{OFS}{print $NF, $1}' /etc/passwd
结果:就是以空格分割了。

5、awk处理规则的执行流程

	BEGIN{}			1.先执行
'''BEGIN中的内容是在awk开始扫描输入之前执行,一般用来初始化或设置全局变量'''
// 2.第二执行
{} 填写处理规则 3.第三执行
END{} 4.最后执行
'''而END之后的操作将在扫描完全部的输入之后执行。'''

6、awk中的函数

	print	: 打印
printf :格式化打印
举例:[root@linux ~]# awk -F: '{printf "|%-20s|\n",$NF}' /etc/passwd
结果>>>:将最后一列左对齐 并以 | 包围, | 内容 |
即: |/sbin/nologin | %s : 字符串
%d :数字
- :左对齐
+ :右对齐
15 : 至少占用15字符
[root@localhost ~]# awk -F: 'BEGIN{OFS=" | "}{printf "|%+15s|%-15s|\n", $NF,$1}' /etc/passwd
结果:最后一列和第一列内容以 | 分割,并且左右对齐。
即: | /sbin/nologin|nginx |

7、awk中的定位(表达式)

	1、正则表达式

	要求1:将含有root的每一行内容打印出来
[root@localhost ~]# awk -F: '/root/{print $0}' /etc/passwd
要求2:将开头是root的每一行内容打印出来
[root@localhost ~]# awk -F: '/^root/{print $0}' /etc/passwd
要求3:将开头是nginx的且含有996的一行内容打印出来 2、比较表达式 >
<
>=
<=
~ 正则匹配
!~ 正则匹配(取反) 案例:要求打印属组ID大于属主ID的行
[root@localhost ~]# awk -F: '$4 > $3{print $0}' /etc/passwd 案例:结尾包含bash
[root@localhost ~]# awk -F: '$NF ~ /bash/{print $0}' /etc/passwd 案例:结尾不包含bash
[root@localhost ~]# awk -F: '$NF !~ /bash/{print $0}' /etc/passwd 3、逻辑表达式 && : 逻辑与
[root@localhost ~]# awk -F: '$3 + $4 > 2000 && $3 * $4 > 2000{print $0}' /etc/passwd
[root@localhost ~]# awk -F: '$3 > 1000 && $4 < 2000{print $0}' /etc/passwd
[root@localhost ~]# awk -F: '/nginx/&&/996/{print $0}' /etc/passwd || :逻辑或
[root@localhost ~]# awk -F: '$3 + $4 > 2000 || $3 * $4 > 2000{print $0}' /etc/passwd
[root@linux ~]# awk -F: '$3 > 1000 || $4 < 2000{print $0}' /etc/passwd ! :逻辑非(取反)
[root@localhost ~]# awk -F: '!($3 + $4 > 2000){print $0}' /etc/passwd
[root@linux ~]# awk -F: '!($3 > 1000 && $4 < 2000){print $0}' /etc/passwd 4、算术表达式 +
-
*
/
% 案例:要求属组 + 属主的ID 大于 2000
[root@localhost ~]# awk -F: '$3 + $4 > 2000{print $0}' /etc/passwd
案例:要求属组 * 属主的ID 大于 2000
[root@localhost ~]# awk -F: '$3 * $4 > 2000{print $0}' /etc/passwd
案例:要求打印偶数行
[root@localhost ~]# awk -F: 'NR % 2 == 0{print $0}' /etc/passwd
案例:要求打印奇数行
[root@localhost ~]# awk -F: 'NR % 2 == 1{print $0}' /etc/passwd 5、条件表达式 ==
>
<
>=
<= 案例:要求打印第三行
[root@localhost ~]# awk -F: 'NR == 3{print $0}' /etc/passwd 6、范围表达式 [root@localhost ~]# awk -F: '/^root/,/^ftp/{print $0}' /etc/passwd

8、流程控制 if for while

	只存在循环之中。
if
[root@localhost ~]# awk -F: '{if($3>$4){print "大于"}else{print "小于或等于"}}' /etc/passwd 但分支结构: if(){}
双分支结构: if(){}else{}
多分支结构: if(){}else if(){}else{}
示例:
[root@linux ~]# awk -F: '{if($3==1){print "等于啦"}else if($3<50){print "咦~好要小哎"}else{print "竟然是大的"}}' /etc/passwd for
[root@localhost ~]# awk -F: '{for(i=10;i>0;i--){print $0}}' /etc/passwd for(i="初始值";条件判断;游标){}
游标:每次处理变量的,这里是每次递减1 while [root@localhost ~]# awk -F: '{i=1; while(i<10){print $0, i++}}' /etc/passwd
while(条件判断){} 每隔5行,打印一行横线
-------------------------------------------------------------------------
[root@localhost ~]# awk -F: '{if(NR%5==0){print "----------------"}print $0}' /etc/passwd

磁盘管理+三剑客之awk的更多相关文章

  1. Linux中磁盘管理与三剑客之awk初识

    昨日内容回顾 1.用两种方法实现 将文件中以 # 开头的行 把 # 去掉 sed -r 's/^ *#//g' /etc/fstab cat /etc/fstab | tr -d '^#' 2.将文件 ...

  2. 磁盘分区 & Linux 三剑客之 awk

    今日内容 磁盘分区 Linux 三剑客之 awk 内容详细 一.磁盘分区 磁盘分区 --> 挂载 步骤 1.关机 2.添加硬盘 3.创建分区 fdisk /dev/sdb or gdisk /d ...

  3. Linux:Day7(下) 磁盘管理、文件系统管理

    Linux入门 Linux系统管理: 磁盘管理.文件系统管理 RAID基本原理.LVM2 网络管理:TCP/IP协议.Linux网络属性配置 程序包管理:rpm,yum 进程管理:htop,glanc ...

  4. (转)Linux磁盘空间监控告警 && Linux磁盘管理

    Linux磁盘空间监控告警 http://blog.csdn.net/github_39069288/article/details/73478784-----------Linux磁盘管理 原文:h ...

  5. Centos下磁盘管理的常用命令记录(如查找大文件)

    Centos下磁盘管理的常用命令记录 查看系统磁盘空间占用,使用命令: df -h 结果: 查看磁盘inode使用情况,如果inode用完了,磁盘就没法写入新的内容了: df -i 结果: 如何查找磁 ...

  6. linux 系统磁盘管理体系

    目录 linux 系统磁盘管理体系 一.磁盘的基本概念 二.磁盘的内部结构 三.磁盘的外部结构 四.磁盘的接口及类型 五.fdisk磁盘分区实践 六.gdisk 分区 七.parted 高级分区工具. ...

  7. liunx 磁盘管理命令记录

    Linux磁盘管理好坏管理直接关系到整个系统的性能问题. Linux磁盘管理常用三个命令为df.du和fdisk. df:列出文件系统的整体磁盘使用量 du:检查磁盘空间使用量 fdisk:用于磁盘分 ...

  8. Windows Server 2012 磁盘管理之 简单卷、跨区卷、带区卷、镜像卷和RAID-5卷

    今天给客户配置故障转移群集,在Windows Server 2012 R2的系统上,通过iSCSI连接上DELL的SAN存储后,在磁盘管理里面发现可以新建 简单卷.跨区卷.带区卷.镜像卷.RAID-5 ...

  9. Linux常用命令学习7---(磁盘管理df du、磁盘的分区和格式化fdisk parted)

    1.磁盘管理    在服务器的维护中,我们需要关心服务器的磁盘使用了多少.还有多少的剩余空间.某个文件有多大.某个文件夹内的所有文件在一起一共占用的多少空间……问题.以便我们在合适的时机为服务器添加硬 ...

随机推荐

  1. python_三元运算

    条件三元运算 # 三元条件运算,如果条件为真则返回x,如果条件为假则返回y x = 3 y = 5 ret = x if x > y else y print(ret) # 返回 y值 for循 ...

  2. mysql数据库主从复制教程

    mysql主从复制教程 架构规划: 192.168.201.150 master 主节点 192.168.201.154 slave 从节点 1. 修改mysql的配置文件(主节点,从节点都要修改) ...

  3. 聊聊docker那些端口问题

    今天来系统聊一聊docker的端口,常见的有容器内程序端口.容器端口.主机端口.Dockerfile中EXPOSE端口.docker-compose和docker run中的port等. 貌似很多端口 ...

  4. Go语言系列之标准库os

    os包提供了操作系统的系列函数,这些接口不依赖平台.设计为Unix风格的,错误处理是go风格的:调用失败会返回错误值而非错误码.通常错误值里包含更多信息. os包的接口在所有操作系统中都是一致的.非公 ...

  5. C# 开源一个基于 yarp 的 API 网关 Demo,支持绑定 Kubernetes Service

    关于 Neting 刚开始的时候是打算使用微软官方的 Yarp 库,实现一个 API 网关,后面发现坑比较多,弄起来比较麻烦,就放弃了.目前写完了查看 Kubernetes Service 信息.创建 ...

  6. kali linux2020 虚拟机改root密码

    kali在2020版的更新中,好多小伙伴登不进root账号,这里来教大家怎样改root账户的密码 1.当我们打开虚拟机看到这个界面的时候,按e进入编辑模式 2.在编辑模式中,"quite s ...

  7. 查看Linux系统信息

    1.查看内核 [root@localhost etc]# uname -aLinux localhost.localdomain 3.10.0-514.el7.x86_64 #1 SMP Tue No ...

  8. http8种请求方式

    根据HTTP标准,HTTP请求可以使用多种请求方法. HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法. HTTP1.1新增了五种请求方法:OPTIONS, PUT, DELE ...

  9. /etc/crontab和crontab -e的区别

    (1) /etc/crontab是系统级别的crontab,系统的设置等,这种方法只有root用户能用 crontab -e是用户级的crontab,会被写到 /var/spool/cron 目录下, ...

  10. python关于一些地址存储问题的知识

    在一个类型进行转换后不能马上进行操作.要先进行存储否则操作无效 原理一个类型转换后成为一个新的类型但是没有人接受它属于空值所以做任何操作都无效 li=[] print(li.append) 也是报错的 ...