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 作业的更多相关文章

  1. 《Linux内核分析》 week5作业-system call中断处理过程

    一.使用gdb跟踪分析一个系统调用内核函数 1.在test.c文件中添加time函数与采用c语言内嵌汇编的time函数.具体实现请看下图. 2.然后在main函数中添加MenuConfig函数,进行注 ...

  2. Daily Scrum (2015/10/26)

    今晚由于我们组成员就团队Week5作业的个人贡献分开会协商,所以把今天的编码工作往后延迟了.考虑到有些成员代码还没理解够,正好TFS的代码阅读分配的工作时间还没进行完,所以在会议之后我们让成员回寝自由 ...

  3. 个人博客作业week5

    请阅读下述关于敏捷开发方法文章,并在个人博客上写一篇读后感. Martin Fowler:  http://martinfowler.com/agile.html 截止时间:10月20日前.

  4. 团队作业Week5之团队贡献分的分配

    一.团队贡献分的分配规则 首先,我们团队共有5个人,平均每个人50分,所以我们团队的总分为5*50=250,我们先把50分分成以下几份: 序号 贡献类型 权重 分数 1 代码贡献 40% 20 * 5 ...

  5. 个人阅读作业Week5

    一.总结体会 团队项目已经进行了很多周,我们团队从刚开始的基础薄弱到现在的大家都可以运用Android来编写程序,共同完成一个app的开发使用. 刚开始做团队项目之时,我们团队就开了一个会,确定了以后 ...

  6. 团队作业Week5

    每个团队开一个讨论会,协商讨论团队贡献分的分配方式.每个团队的团队贡献分为50分/人.每个人分数不能相同,请详细说明分数的分配规则. 可参考这个博客. 截止时间:2014-10-27

  7. 团队博客作业Week5 --- 团队贡献分--分配规则

    团队会议 时间:公元2015年10月26日22时3分20秒 地点:宿舍楼716房间 与会人员:陈谋,李剑锋,卢惠民,刘夕霆,仉伯龙,潘成鼎. 会议内容:今天的组会主要讨论的是项目团队贡献分的计算方式, ...

  8. Spark小课堂Week5 Scala初探

    Spark小课堂Week5 Scala初探 Scala是java威力加强版. 对Java的改进 这里会结合StreamingContext.scala这个代码说明下对Java的改进方面. 方便测试方式 ...

  9. 《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 ...

随机推荐

  1. springboot 用redis缓存整合spring cache注解,使用Json序列化和反序列化。

    springboot下用cache注解整合redis并使用json序列化反序列化. cache注解整合redis 最近发现spring的注解用起来真的是很方便.随即产生了能不能吧spring注解使用r ...

  2. mysql jdbc url

    地址为jdbc:mysql://localhost:3306/mymiaosha?characterEncoding=utf-8时访问时可能会出现下图提示 地址改为jdbc:mysql://local ...

  3. (二)Java秒杀项目之实现登录功能

    一.数据库设计 CREATE TABLE `miaosha_user` ( `id` ) NOT NULL COMMENT '用户ID,手机号码', `nickname` ) NOT NULL, `p ...

  4. node工具之node-ip

    node-ip node.js用来获取id地址的工具 use var ip = require('ip'); ip.address() // my ip address ip.isEqual('::1 ...

  5. spring boot zuul集成kubernetes等第三方登录

    介绍一下,在单点登录平台集成kubernetes登录,集成其它系统的登录原理是一样的,如grafana, nacos, jenkins等. POM引用: <dependency> < ...

  6. 客户端相关知识学习(一)之混合开发,为什么要在App中使用H5页面以及应用场景、注意事项

    混合开发 随着移动互联网的高速发展,常规的开发速度已经渐渐不能满足市场需求.原生H5混合开发应运而生,目前,市场上许多主流应用都有用到混合开发,例如支付宝.美团等.下面,结合我本人的开发经验,简单谈一 ...

  7. MySQL太慢?试试这些诊断思路和工具

    MySQL 慢怎么办 如果遇到 MySQL 慢的话,你的第一印象是什么,MySQL 数据库如果性能不行,你是如何处理的? 我咨询了一些同行, 得到了以下反馈: 第一反应是再试一次 第二个反应是优化一下 ...

  8. 18 Python之初识面向对象

    1. 类与对象 class Car: #类名首字母大写,严格遵守驼峰命名规范 pass #造车 c = Car() #类名() #创建对象 ##出场之后进行改装 c.color = "红色& ...

  9. 1.css选择器

    1.引入外部样式表的格式: <link rel=”stylesheet” type=”text/css” href=”../css/style1.css”> 2.样式表第一行应注明编码类型 ...

  10. 前端框架:Angular React 和 Vue的比较

    前端这几年的技术发展很快,细分下来,主要可以分成四个方面: 1.开发语言技术,主要是ES6&7,coffeescript,typescript等: 2.开发框架,如Angular,React, ...