磁盘管理+三剑客之awk
磁盘管理+三剑客之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的更多相关文章
- Linux中磁盘管理与三剑客之awk初识
昨日内容回顾 1.用两种方法实现 将文件中以 # 开头的行 把 # 去掉 sed -r 's/^ *#//g' /etc/fstab cat /etc/fstab | tr -d '^#' 2.将文件 ...
- 磁盘分区 & Linux 三剑客之 awk
今日内容 磁盘分区 Linux 三剑客之 awk 内容详细 一.磁盘分区 磁盘分区 --> 挂载 步骤 1.关机 2.添加硬盘 3.创建分区 fdisk /dev/sdb or gdisk /d ...
- Linux:Day7(下) 磁盘管理、文件系统管理
Linux入门 Linux系统管理: 磁盘管理.文件系统管理 RAID基本原理.LVM2 网络管理:TCP/IP协议.Linux网络属性配置 程序包管理:rpm,yum 进程管理:htop,glanc ...
- (转)Linux磁盘空间监控告警 && Linux磁盘管理
Linux磁盘空间监控告警 http://blog.csdn.net/github_39069288/article/details/73478784-----------Linux磁盘管理 原文:h ...
- Centos下磁盘管理的常用命令记录(如查找大文件)
Centos下磁盘管理的常用命令记录 查看系统磁盘空间占用,使用命令: df -h 结果: 查看磁盘inode使用情况,如果inode用完了,磁盘就没法写入新的内容了: df -i 结果: 如何查找磁 ...
- linux 系统磁盘管理体系
目录 linux 系统磁盘管理体系 一.磁盘的基本概念 二.磁盘的内部结构 三.磁盘的外部结构 四.磁盘的接口及类型 五.fdisk磁盘分区实践 六.gdisk 分区 七.parted 高级分区工具. ...
- liunx 磁盘管理命令记录
Linux磁盘管理好坏管理直接关系到整个系统的性能问题. Linux磁盘管理常用三个命令为df.du和fdisk. df:列出文件系统的整体磁盘使用量 du:检查磁盘空间使用量 fdisk:用于磁盘分 ...
- Windows Server 2012 磁盘管理之 简单卷、跨区卷、带区卷、镜像卷和RAID-5卷
今天给客户配置故障转移群集,在Windows Server 2012 R2的系统上,通过iSCSI连接上DELL的SAN存储后,在磁盘管理里面发现可以新建 简单卷.跨区卷.带区卷.镜像卷.RAID-5 ...
- Linux常用命令学习7---(磁盘管理df du、磁盘的分区和格式化fdisk parted)
1.磁盘管理 在服务器的维护中,我们需要关心服务器的磁盘使用了多少.还有多少的剩余空间.某个文件有多大.某个文件夹内的所有文件在一起一共占用的多少空间……问题.以便我们在合适的时机为服务器添加硬 ...
随机推荐
- 初识python: 递归函数
定义: 在函数内,可以调用其他函数,如果一个函数在内部调用自己,返回值中包含函数名,这个函数就是递归函数. 特性: 1.必须要有明确的结束条件: 2.每进入更深一层递归时,问题规模相对上次递归都应该有 ...
- js字符串数组['1','2','3']转number
let arr = ['1','2','3']; arr.split(',').map(Number);
- Hive的连接和运行模式
原文链接: https://www.toutiao.com/i6771018203687551495/ Hive的连接 启动hadoop的时候将history也启动,如果出问题,可以方便我们后续定位 ...
- Yum安装Maven
一.安装 wget http://repos.fedorapeople.org/repos/dchen/apache-maven/epel-apache-maven.repo -O /etc/yum. ...
- Git创建分支进行开发
一.业务场景 自己当前开发的项目算是一个中型项目,整个项目都是由自己一个人开发完成,主要有两个子项目,一个是小程序的后台,一个是小程序的后台管理系统. 因为从一开始就只有我一个人在进行开发,所以自己平 ...
- MySQL使用时间作为判断条件
背景:在开发过程中,我们经常需要根据时间作为判断条件来查询数据,例如:当月,当日,当前小时,几天内...... 1. 当月 我们只需要使用一个mysql的MONTH(date)函数即可实现.(注意判断 ...
- 基于springboot的定时任务实现(非分布式)
1. 核心注解 在springboot项目中我们可以很方便地使用spring自己的注解@Scheduled和@EnableScheduling配合来实现便捷开发定时任务. @EnableSchedul ...
- 基于 Keras 实现图像风格转移
Style Transfer 这个方向火起来是从2015年Gatys发表的Paper A Neural Algorithm of Artistic Style(神经风格迁移) , 这里就简单提一下论 ...
- 网络协议学习笔记(四)传输层的UDP和TCP
概述 传输层里比较重要的两个协议,一个是 TCP,一个是 UDP.对于不从事底层开发的人员来讲,或者对于开发应用的人来讲,最常用的就是这两个协议.由于面试的时候,这两个协议经常会被放在一起问,因而我在 ...
- MATLAB中拟合算法刚入门
%%%1.拟合问题:(做预测,主要使用的范围是样本比较小,拟合效果会好,样本比较多,拟合的效果就不是很好) 1.应用预测的场景:已经知道10年的样本,预测第11年以内的数据 2.用拟合的到关系式:样本 ...