week5 作业
week5 作业
1.描述GPT是什么,应该怎么使用?
描述GPT之前要简单了解MBR分区,MBR(Main Boot Record)叫做主引导记录,其位于磁盘的最前端,由一段代码组成,共占用512个字节。是计算机开机时读取的首个磁盘扇区,由三部分组成:
- 主引导程序即主引导记录(MBR)(占446个字节),启动代码
- 分区表(DPT,Disk Partition Table)由四个分区表构成,每个占用16字节,共占用64字节
- 结束标志 55aa
由此可见,利用MBR分区最多只能有4个分区,每个分区的最大容量为2T,因此出现了GPT分区。
GPT:GUID(Globals Unique Identifiers) partition table ,全局唯一标识分区表,实体硬盘的分区表的结构布局的标准,区别于MBR。支持128个分区,使用64位,支持8Z( 512Byte/block )64Z ( 4096Byte/block)。

由四部分组成:保护MBR区、EFI信息区(GPT头)、分区表、GPT分区区域、备份区域;
- 保护MBR分区(LBA0) :MBR分区过度GPT分区,防止无法识别MBR分区。实际上,EFI根本用不上这个分区表。
- GPT头:起始于磁盘的LBA1,通常也只占用这个单一扇区。其作用是定义分区表的位置和大小。GPT头还包含头和分区表的校验和,这样就可以及时发现错误。
- 分区表:分区表区域包含分区表项。这个区域由GPT头定义,一般占用磁盘LBA2~LBA33扇区。分区表中的每个分区项由起始地址、结束地址、类型值、名字、属性标志、GUID值组成。分区表建立后,128位的GUID对系统来说是唯一的。
- GPT分区区域:最大的区域,由分配给分区的扇区组成。这个区域的起始和结束地址由GPT分区表定义。
- 备份区域:备份区域位于磁盘的尾部,包含GPT头和分区表的备份。它占用GPT结束扇区和EFI结束扇区之间的33个扇区。其中最后一个扇区用来备份1号扇区的EFI信息,其余的32个扇区用来备份LBA2~LBA33扇区的分区表。
GPT只是一种分区方式,使用gdisk工具进行分区,分区后的使用还是要格式化,挂载。
注意:要想使用GPT分区表必须是UEFI BIOS环境,UEFI和GPT相辅相成的,二者缺一不可
UEFI:全称“统一的可扩展固件接口”(Unified Extensible Firmware Interface), 是一种详细描述类型接口的标准。这种接口用于操作系统自动从预启动的操作环境,加载到一种操作系统上。
2.创建一个10G的分区,并格式化为ext4文件系统。要求:
(1)block大小为2048k,预留空间为20%,卷标为MYDATA;
(2)挂载至/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳;
(3)可开机自动挂载。
首先,fdisk 一个10G的分区。
mke2fs -t ext4 -b 2048 -m 20 -L MYDATA /dev/sdb1 # 格式化分区
mount -o noexec,noatime /dev/sdb1 /mydata
vim /etc/fstab # 修改配置文件
UUID=103878ff-76c0-4f88-ac51-5fbc9828b39d /mydata ext4 defaults,noexec,noatime 0 0 # fstab配置文件中添加此条
3.创建1个大小为10G的swap分区,并启用
有两种设备可以作为swap分区:
①磁盘设备,一般单独一个新磁盘的第一个分区作为swap分区,因为靠外侧的磁道性能更好;
fdisk 一个10G的分区
注意:将分区类型改为82 -swap类型
②loop设备,
dd if=/dev/zero of=/data/swaptest bs=100M count=100 创建大小为10G名字为swaptest的文件
后面的操作相同如下:
mkswap /dev/sdb1
vim /etc/fstab # 修改配置文件,加入刚刚格式化的swap分区
swapon -a 启用swap分区
也可以不写入配置文件,直接
swapon /dev/sdb1 # 这样下次开机时该swap分区自动取消。
4.编写脚本计算/etc/passwd文件中第10个和第20个的用户ID之和。
#!/bin/bash
ID1=`getent passwd | head -n10 | tail -n1 | cut -d: -f3`
ID2=`getent passwd | head -n20 | tail -n1 | cut -d: -f3`
sumID=$[$ID1+$ID2]
echo $sumID
5.将当前计算机名保存至hostName中,主机名如果为空,或者为localhost.localdomain则设置为www.magedu.com
#!/bin/bash
hostName=`hostname`
[ -z "$hostName" -o "$hostName" == "localhost.localdomain" -o "hostName" == "localhost" ] && hostname www.magedu.com
6.编写脚本,通过一个命令行参数传入一个用户,判断id号是奇数还是偶数。
#!/bin/bash
[ $# -ne 1 ] && echo "please input only one args " && exit
id $1 &>/dev/null || echo "$1 is not exist,creating the user $1 now,please wait a minute "
sleep 2
useradd $1 && echo "user $1 is cteated "
uid=`grep "\<$1\>" /etc/passwd | cut -d: -f3`
yushu=$[ $uid%2 ]
[ $yushu -eq 0 ] && echo "此用户的id号为偶数" || echo “此用户的id号为奇数”
输出结果测试:
[root@CentOS7 data]#bash yushuUID.sh sst
useradd: user 'sst' already exists
“此用户的id号为奇数”
[root@CentOS7 data]#bash yushuUID.sh sst3
sst3 is not exist,creating the user sst3 now,please wait a minute
user sst3 is cteated
此用户的id号为偶数
7.lvm基本应用以及扩展缩减实现。
LVM基本运用参考此博文LVM
week5 作业的更多相关文章
- 《Linux内核分析》 week5作业-system call中断处理过程
一.使用gdb跟踪分析一个系统调用内核函数 1.在test.c文件中添加time函数与采用c语言内嵌汇编的time函数.具体实现请看下图. 2.然后在main函数中添加MenuConfig函数,进行注 ...
- Daily Scrum (2015/10/26)
今晚由于我们组成员就团队Week5作业的个人贡献分开会协商,所以把今天的编码工作往后延迟了.考虑到有些成员代码还没理解够,正好TFS的代码阅读分配的工作时间还没进行完,所以在会议之后我们让成员回寝自由 ...
- 个人博客作业week5
请阅读下述关于敏捷开发方法文章,并在个人博客上写一篇读后感. Martin Fowler: http://martinfowler.com/agile.html 截止时间:10月20日前.
- 团队作业Week5之团队贡献分的分配
一.团队贡献分的分配规则 首先,我们团队共有5个人,平均每个人50分,所以我们团队的总分为5*50=250,我们先把50分分成以下几份: 序号 贡献类型 权重 分数 1 代码贡献 40% 20 * 5 ...
- 个人阅读作业Week5
一.总结体会 团队项目已经进行了很多周,我们团队从刚开始的基础薄弱到现在的大家都可以运用Android来编写程序,共同完成一个app的开发使用. 刚开始做团队项目之时,我们团队就开了一个会,确定了以后 ...
- 团队作业Week5
每个团队开一个讨论会,协商讨论团队贡献分的分配方式.每个团队的团队贡献分为50分/人.每个人分数不能相同,请详细说明分数的分配规则. 可参考这个博客. 截止时间:2014-10-27
- 团队博客作业Week5 --- 团队贡献分--分配规则
团队会议 时间:公元2015年10月26日22时3分20秒 地点:宿舍楼716房间 与会人员:陈谋,李剑锋,卢惠民,刘夕霆,仉伯龙,潘成鼎. 会议内容:今天的组会主要讨论的是项目团队贡献分的计算方式, ...
- Spark小课堂Week5 Scala初探
Spark小课堂Week5 Scala初探 Scala是java威力加强版. 对Java的改进 这里会结合StreamingContext.scala这个代码说明下对Java的改进方面. 方便测试方式 ...
- 《Using Python to Access Web Data》 Week5 Web Services and XML 课堂笔记
Coursera课程<Using Python to Access Web Data> 密歇根大学 Week5 Web Services and XML 13.1 Data on the ...
随机推荐
- 【深入理解JVM】类加载器与双亲委派模型 (转)
出处: [深入理解JVM]类加载器与双亲委派模型 加载类的开放性 类加载器(ClassLoader)是Java语言的一项创新,也是Java流行的一个重要原因.在类加载的第一阶段“加载”过程中,需要通过 ...
- 前端之BOM,DOM
前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交互,我们需要继续学习BOM和DO ...
- 数据结构(三) 树和二叉树,以及Huffman树
三.树和二叉树 1.树 2.二叉树 3.遍历二叉树和线索二叉树 4.赫夫曼树及应用 树和二叉树 树状结构是一种常用的非线性结构,元素之间有分支和层次关系,除了树根元素无前驱外,其它元素都有唯一前驱. ...
- java实现的LinkedLilst
package javabean.adt.List; import java.util.ConcurrentModificationException; import java.util.Iterat ...
- 简单搭建http服务器-HttpListener使用
使用HTTPListener可以简单搭建一个Http服务器,对于本地使用很是方面,想起之前使用了WebSocket来与本地网页通讯的例子,也是可以改为使用HTTPListener来做的.看下HTTPL ...
- CPU如何区分溢出和自然进位?
CPU如何区分溢出和自然进位? 之前学习补码的时候倒是学会了基本概念,但是最近又接触时发现还有不清楚的地方,所以又研究了下 今天的核心问题的"CPU是如何区分高位自然舍弃和溢出的?" ...
- 14 Scrapy中selenium的应用
在通过scrapy框架进行某些网站数据爬取的时候,往往会碰到页面动态数据加载的情况发生,如果直接使用scrapy对其url发请求,是绝对获取不到那部分动态加载出来的数据值.但是通过观察我们会发现,通过 ...
- Vue之动态class写法总结
对象方法 最简单的绑定 :class="{ 'active': isActive }" 判断是否绑定一个active :class="{'active':isActive ...
- ECharts模拟百度迁徙实例
本实例原始信息: 作者:anix 演示地址:Echarts模拟迁徙 源码地址:GitHub-ananix-qianxi 前言 "百度地图春节人口迁徙大数据"(简称"百度迁 ...
- Python 2中万恶的字符编码
Python2中如果文件存在中文,必须要指定#-*- coding:utf8 -*-或#coding:utf8,否则会报错.那这是为什么呢? 一.原理解析 我们知道,在计算机发展初期,计算机只能识别字 ...