[关闭]
@mrz1 2017-12-28T06:38:41.000000Z 字数 12501 阅读 1176

2017-12-25课程笔记(数组 字符串 expect 启动流程)

笔记


回顾: 函数使用 交互式定义 三种方法
cat /etc/init.d/function
export -f function 声明成环境函数
位置函数 func 2 (){ }

启动流程
post -> mbrstage1 -> stage1.5-stage2/boo/grub -> grub-conf(kernel,initrd) -> /sbin/init -> /etc/inittab(定义了运行级别 id5 -> /etc/rc.d/rc.sysinit -> /etc/rc.N.d 服务脚本service 映射到/etc/init.d/ /etc/rc.d/rc.local -- login 有图形界面 加载....)

Created with Raphaël 2.1.2启动流程 mbrstage1 -> stage1.5-stage2/boo/grub -> grub-conf(kernel,initrd)/sbin/init/etc/inittab(定义了运行级别 id5 -> /etc/rc.d/rc.sysinit -> /etc/rc.N.d 服务脚本service 映射到/etc/init.d/ /etc/rc.d/rc.locallogin 有图形界面 加载....

数组

变量:存储单个元素的内存空间
数组:存储多个元素的连续的内存空间,相当于多个变量的集合

数组名和索引索引:
编号从0开始,属于数值索引
注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引,bash4.0版本之后开始支持
bash的数组支持稀疏格式(索引不连续)

声明数组:

  1. declare -a ARRAY_NAME
  2. declare -A ARRAY_NAME: 关联数组
  3. 注意:两者不可相互转换

只要能生成列表都能定义成数组 例子:

  1. file=(`ls /etc`) echo ${file[*]}
  2. num=({1..10}) echo ${num[*]}
  3. df=(`df`) echo ${df[*]}
  4. .....

数组赋值

数组元素的赋值
(1) 一次只赋值一个元素

  1. ARRAY_NAME[INDEX]=VALUE
  2. weekdays[0]="Sunday"
  3. weekdays[4]="Thursday"

(2) 一次赋值全部元素

  1. ARRAY_NAME=("VAL1" "VAL2" "VAL3" ...)

(3) 只赋值特定元素

  1. ARRAY_NAME=([0]="VAL1" [3]="VAL2" ...)

(4) 交互式数组值对赋值

  1. read -a ARRAY
  2. 例:
  3. [root@centos6 ~]#read -a num
  4. 1 2 3 4 6 7
  5. You have new mail in /var/spool/mail/root
  6. [root@centos6 ~]#echo ${num[*]}
  7. 1 2 3 4 6 7

显示所有数组:declare -a

引用数组

引用数组元素:

  1. ${ARRAY_NAME[INDEX]}
  2. 注意:省略[INDEX]表示引用下标为0的元素

引用数组所有元素:

  1. ${ARRAY_NAME[*]}
  2. ${ARRAY_NAME[@]}

数组的长度(数组中元素的个数):

  1. ${#ARRAY_NAME[*]}
  2. ${#ARRAY_NAME[@]}

删除数组中的某元素:导致稀疏格式

  1. unset ARRAY[INDEX]

删除整个数组:

  1. unset ARRAY

数组数据处理

引用数组中的元素:

  1. 数组切片:${ARRAY[@]:offset:number}
  2. offset: 要跳过的元素个数
  3. number: 要取出的元素个数
  4. 取偏移量之后的所有元素${ARRAY[@]:offset}
  5. [root@centos6 ~]#num=({1..10})
  6. [root@centos6 ~]#echo ${num[*]:3:4}
  7. 4 5 6 7
  8. [root@centos6 ~]#echo ${num[*]:3}
  9. 4 5 6 7 8 9 10

向数组中追加元素:

  1. ARRAY[${#ARRAY[*]}]=value
  2. [root@centos6 ~]#num=({1..10})
  3. [root@centos6 ~]#num[${#num[*]}]=11

关联数组:

  1. declare -A ARRAY_NAME
  2. ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2'...)
  3. 注意:关联数组必须先声明再调用
  4. 例:
  5. [root@centos6 ~]#declare -A arr1
  6. [root@centos6 ~]#arr1[a]=1
  7. [root@centos6 ~]#arr1[b]=2
  8. [root@centos6 ~]#arr1[c]=3
  9. [root@centos6 ~]#echo ${arr1[a]}
  10. 1
  11. [root@centos6 ~]#echo ${arr1[b]}
  12. 2
  13. [root@centos6 ~]#echo ${arr1[c]}
  14. 3

练习

1.入若干个数值存入数组中,采用冒泡算法进行升序或降序排序

2.将下图所示,实现转置矩阵matrix.sh

  1. 完成这样效果
  2. 1 2 3 1 4 7
  3. 4 5 6 => 2 5 8
  4. 7 8 9 3 6 9
  1. declare -A matrix=([00]=1 [01]=2 [02]=3 [10]=4 [11]=5 [12]=6 [20]=7 [21]=8 [22]=9)
  2. size=3
  3. for ((i=0;i<size;i++));do
  4. for ((j=0;j<size;j++));do
  5. echo -n "${matrix[$i$j]} "
  6. done
  7. echo
  8. done
  9. unset i
  10. unset j
  11. echo "-------------------------------"
  12. for ((i=0;i<size;i++));do
  13. for ((j=0;j<size;j++));do
  14. [ $i -eq $j ] && echo -n "${matrix[$i$j]} "
  15. if [ $i -ne $j ];then
  16. echo -n "${matrix[$j$i]} "
  17. fi
  18. done
  19. echo
  20. done

3.生成10个随机数保存于数组中,并找出其最大值和最小值
1

  1. #!/bin/bash
  2. declare -a rand
  3. for ((i=0;i<10;i++));do
  4. rand[$i]=$RANDOM
  5. [ $i -eq 0 ] && max=${rand[$i]} && min=${rand[$i]} && continue
  6. [ ${rand[$i]} -gt $max ] && max=${rand[$i]} && continue
  7. [ ${rand[$i]} -lt $min ] && min=${rand[$i]}
  8. done
  9. echo ${rand[*]}
  10. echo max:$max min:$min

2

  1. #!/bin/bash
  2. declare -a rand
  3. declare -i max=0
  4. declare i min=32767
  5. for i in {0..9}; do
  6. rand[$i]=$RANDOM
  7. echo ${rand[$i]}
  8. [ ${rand[$i]} -gt $max ] && max=${rand[$i]}
  9. [ ${rand[$i]} -lt $min ] && min=${rand[$i]}
  10. done
  11. echo "Max: $max Min:$min"

4.编写脚本,定义一个数组,数组中的元素是/var/log目录下所有以.log结尾的文件;统计出其下标为偶数的文件中的行数之和

  1. #!/bin/bash
  2. #declare -a files
  3. files=(/var/log/*.log)
  4. declare -i lines=0
  5. for i in $(seq0 $[${#files[*]}-1]); do
  6. if [ $[$i%2] -eq0 ];then
  7. let lines+=$(wc-l ${files[$i]} | cut -d' ' -f1)
  8. fi
  9. done
  10. echo "Lines: $lines."

字符串

字符串切片

  1. ${#var}:返回字符串变量var的长度
  2. ${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最后的部分,offset的取值在0 ${#var}-1 之间(bash4.2后,允许为负值)
  3. ${var:offset:number}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分
  4. ${var: -length}:取字符串的最右侧几个字符注意:冒号后必须有一空白字符
  5. ${var:offset:-length}:从最左侧跳过offset字符,一直向右取到距离最右侧lengh个字符之前的内容
  6. ${var: -length:-offset}:先从最右侧向左取到length个字符开始,再向右取到距离最右侧offset个字符之间的内容注意:-length前空格 -length一定比-offset centos6不支持 bash版本差异
  7. 例子
  8. [root@centos6 ~]#string=`echo {a..z}|tr -d " "`
  9. [root@centos6 ~]#echo $string
  10. abcdefghijklmnopqrstuvwxyz
  11. [root@centos6 ~]#echo ${#string}
  12. 26
  13. [root@centos6 ~]#echo ${string:3:4}
  14. defg
  15. [root@centos6 ~]#echo ${string:-3}
  16. xyz

字符串处理

基于模式取子串

  1. ${var#*word}:其中word可以是指定的任意字符
  2. 功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删除字符串开头至第一次出现word字符之间的所有字符
  3. ${var##*word}:同上,贪婪模式,不同的是,删除的是字符串开头至最后一次由word指定的字符之间的所有内容
  4. 示例:
  5. file="var/log/messages"
  6. ${file#*/}: log/messages
  7. ${file##*/}: messages
  8. url="https://www.baidu.com/?tn=90605295_hao_pg"
  9. ${url#*?}:tn=90605295_hao_pg
  1. ${var%word*}:其中word可以是指定的任意字符;
  2. 功能:自右而左,查找var变量所存储的字符串中,第一次出现的word, 删除字符串最后一个字符向左至第一次出现word字符之间的所有字符;
  3. file="/var/log/messages"
  4. ${file%/*}: /var/log
  5. ${var%%word*}:同上,只不过删除字符串最右侧的字符向左至最后一次出现word字符之间的所有字符;
  6. 示例:
  7. url=http://www.magedu.com:80
  8. ${url##*:}80
  9. ${url%%:*}http

查找替换

  1. ${var/pattern/substr}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substr替换之
  2. ${var//pattern/substr}:查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substr替换之
  3. ${var/#pattern/substr}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substr替换之
  4. ${var/%pattern/substr}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substr替换之
  5. [root@centos6 ~]#line=root:x:0:0:root:/root:/bin/bash
  6. [root@centos6 ~]#echo $line
  7. root:x:0:0:root:/root:/bin/bash
  8. [root@centos6 ~]#echo ${line/root/123}
  9. 123:x:0:0:root:/root:/bin/bash
  10. [root@centos6 ~]#echo ${line//root/123}
  11. 123:x:0:0:123:/123:/bin/bash
  12. [root@centos6 ~]#echo ${line/#root/123}
  13. 123:x:0:0:root:/root:/bin/bash
  14. [root@centos6 ~]#echo ${line/%bash/123}
  15. root:x:0:0:root:/root:/bin/123

查找并删除

  1. ${var/pattern}:删除var所表示的字符串中第一次被pattern所匹配到的字符串
  2. ${var//pattern}:删除var所表示的字符串中所有被pattern所匹配到的字符串
  3. ${var/#pattern}:删除var所表示的字符串中所有以pattern为行首所匹配到的字符串
  4. ${var/%pattern}:删除var所表示的字符串中所有以pattern为行尾所匹配到的字符串
  5. 例子
  6. [root@centos6 ~]#echo $line
  7. root:x:0:0:root:/root:/bin/bash
  8. [root@centos6 ~]#echo ${line/root}
  9. :x:0:0:root:/root:/bin/bash
  10. [root@centos6 ~]#echo ${line//root}
  11. :x:0:0::/:/bin/bash
  12. [root@centos6 ~]#echo ${line/#root}
  13. :x:0:0:root:/root:/bin/bash
  14. [root@centos6 ~]#echo ${line/#bash}
  15. root:x:0:0:root:/root:/bin/bash
  16. 字符大小写转换
  17. ${var^^}:把var中的所有小写字母转换为大写
  18. ${var,,}:把var中的所有大写字母转换为小写
  19. [root@centos6 ~]#echo ${line^^}
  20. ROOT:X:0:0:ROOT:/ROOT:/BIN/BASH
  21. [root@centos6 ~]#echo ${line,,}
  22. root:x:0:0:root:/root:/bin/bash

变量赋值

变量赋值

  1. 例:
  2. [root@centos6 ~]#str=''
  3. [root@centos6 ~]#var=${str-"expr"}
  4. [root@centos6 ~]#echo $var
  5. [root@centos6 ~]#unset str
  6. [root@centos6 ~]#var=${str-"expr"}
  7. [root@centos6 ~]#echo $var
  8. expr

高级变量用法-有类型变量

Shell变量一般是无类型的,但是bash Shell提供了declare和typeset两个命令用于指定变量的类型,两个命令是等价的

  1. declare [选项] 变量名
  2. -r 声明或显示只读变量
  3. -i 将变量定义为整型数
  4. -a 将变量定义为数组
  5. -A 将变量定义为关联数组
  6. -f 显示已定义的所有函数名及其内容
  7. -F 仅显示已定义的所有函数名
  8. -x 声明或显示环境变量和函数
  9. -l 声明变量为小写字母declare l var=UPPER
  10. -u 声明变量为大写字母declare u var=lower
  11. [root@centos7 ~]#declare -l var=ZZZZZZZZ
  12. [root@centos7 ~]#echo $var
  13. zzzzzzzz
  14. [root@centos7 ~]#declare -u var=zzzzzzzz
  15. [root@centos7 ~]#echo $var
  16. ZZZZZZZZ

eval命令

eval命令将会首先扫描命令行进行所有的置换,然后再执行该命令。该命令适用于那些一次扫描无法实现其功能的变量.该命令对变量进行两次扫描

示例:

  1. [root@server~]# CMD=whoami
  2. [root@server ~]# echo $CMD
  3. whoami
  4. [root@server ~]# eval $CMD
  5. root
  6. [root@server~]# n=10
  7. [root@server~]# echo {0..$n}
  8. {0..10}
  9. [root@server~]# eval echo {0..$n}
  10. 0 1 2 3 4 5 6 7 8 9 10

间接变量引用

如果第一个变量的值是第二个变量的名字,从第一个变量引用第二个变量的值就称为间接变量引用
variable1的值是variable2,而variable2又是变量名,variable2的值为value,间接变量引用是指通过variable1获得变量值value的行为
variable1=variable2
variable2=value

bash Shell提供了两种格式实现间接变量引用
eval tempvar=${!variable1}

示例:

  1. 1
  2. [root@server ~]# N=NAME
  3. [root@server ~]# NAME=wangxiaochun
  4. [root@server ~]# N1=${!N}
  5. [root@server ~]# echo $N1
  6. wangxiaochun
  7. [root@server ~]# eval N2=\$$N
  8. [root@server ~]# echo $N2
  9. wangxiaochun
  10. 2
  11. titel=gg
  12. gg=oo
  13. eval echo \$$titel
  14. ${!titel}

创建临时文件

  1. mktemp命令:创建并显示临时文件,可避免冲突
  2. mktemp[OPTION]... [TEMPLATE]
  3. TEMPLATE filenameXXX
  4. X至少要出现三个
  5. OPTION
  6. -d: 创建临时目录
  7. -p DIR或--tmpdir=DIR:指明临时文件所存放目录位置
  8. 示例:
  9. mktemp /tmp/testXXX
  10. tmpdir=`mktemp –d /tmp/testdirXXX`
  11. mktemp --tmpdir=/testdirtestXXXXXX
  12. mktemp -p /app/testdirtestXXXXXX //1
  13. mktemp -p /app/ testdirtestXXXXXX //2 这两个文件 目录和文件分开写也行

安装复制文件

  1. install命令:(cp chmod chown mkdir 命令集合)
  2. install [OPTION]... [-T] SOURCE DEST 单文件
  3. install [OPTION]... SOURCE... DIRECTORY
  4. install [OPTION]... -t DIRECTORY SOURCE...
  5. install [OPTION]... -d DIRECTORY...创建空目录
  6. 选项:
  7. -m MODE,默认755
  8. -o OWNER
  9. -g GROUP
  10. 示例:
  11. install -m 700 -o wang -g admins srcfile desfile
  12. install -m 700 -d /testdir/installdir

expect介绍

expect 是由Don Libes基于Tcl(Tool Command Language )语言开发的,主要应用于自动化交互式操作的场景,借助Expect处理交互的命令,可以将交互过程如:ssh登录,ftp登录等写在一个脚本上,使之自动化完成。尤其适用于需要对多台服务器执行相同操作的环境中,可以大大提高系统管理人员的工作效率
yum info expect 查看说明

expect命令

  1. expect 语法:
  2. expect [选项] [ -c cmds] [ [ -[f|b] ] cmdfile] [ args]
  3. 选项
  4. -c:从命令行执行expect脚本,默认expect是交互地执行的
  5. 示例:expect -c 'expect "\n" {send "pressed enter\n"}'
  6. -d:可以输出输出调试信息
  7. 示例:expect -d ssh.exp
  8. expect中相关命令
  9. spawn:启动新的进程
  10. send:用于向进程发送字符串
  11. expect:从进程接收字符串
  12. interact:允许用户交互
  13. exp_continue匹配多个字符串在执行动作后加此命令

expect

  1. expect最常用的语法(tcl语言:模式-动作)
  2. 单一分支模式语法:
  3. expect "hi" {send "You said hi\n"}
  4. 匹配到hi后,会输出"you said hi",并换行
  5. 例:
  6. [root@centos7 ~]#expect
  7. expect1.1> expect "hi" {send "You said hi\n"}
  8. hi
  9. You said hi
  10. 多分支模式语法:
  11. expect "hi" { send "You said hi\n" } "hehe" { send Hehe yourself\n" } "bye" { send "Good bye\n" }
  12. 匹配hi,hello,bye任意字符串时,执行相应输出。等同如下:
  13. expect {
  14. "hi" { send "You said hi\n"}
  15. "hehe" { send "Hehe yourself\n"}
  16. "bye" { send “Good bye\n"}
  17. }

示例scp

  1. #!/usr/bin/expect
  2. spawn scp /etc/fstab wang@192.168.27.6:/app
  3. expect {
  4. "yes/no" { send "yes\n";exp_continue }
  5. "password" { send "magedu\n" }
  6. }
  7. interact 允许用户交互
  8. expect eof 退出连接
  9. 二选一
  10. 执行 ./脚本 或者 expect 脚本

shell脚本调用expect

  1. #!/bin/bash
  2. ip=$1
  3. user=$2
  4. password=$3
  5. expect <<EOF
  6. set timeout 10
  7. spawn ssh $user@$ip
  8. expect {
  9. "yes/no" { send "yes\n";exp_continue }
  10. "password" { send "$password\n" }
  11. }
  12. expect "]#" { send "useradd hehe\n" }
  13. expect "]#" { send "echo magedu |passwd --stdin hehe\n" }
  14. expect "]#" { send "exit\n" }
  15. expect eof
  16. EOF
  17. #./ssh5.sh 192.168.8.100 root magedu

练习expect

  1. 利用expect ftp自动下载文件
  2. 杨辉三角

linux中的启动图片

我的ImageMagick使用心得

  1. yum install ImageMagick //安装
  2. convert -resize 640x480 -colors 14 win.jpg splash.xpm
  3. -resize //大小
  4. -colors //颜色
  5. win.xpm //源文件win.jpg转换成splash.xpm
  6. more splash.xpm //查看文件格式
  7. file splash.xpm //文件格式
  8. 压缩 splash.xpm -> gaip splash.xpm

/etc/grub/grub.conf

  1. [root@centos6 ~]#cat /boot/grub/grub.conf
  2. default=0
  3. timeout=5
  4. splashimage=(hd0,0)/grub/splash.xpm.gz
  5. hiddenmenu
  6. title CentOS 6 (2.6.32-696.el6.x86_64)
  7. root (hd0,0)
  8. kernel /vmlinuz-2.6.32-696.el6.x86_64 ro root=UUID=54ed9b7b-f7a9-40d4-8bbf-15faed977b03(根) rd_NO_LUKS rd_NO_LVM LANG=en_US.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun16 crashkernel=auto KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM rhgb(启动是否是图形界面) quiet(内核参数不显示去掉显示)
  9. initrd /initramfs-2.6.32-696.el6.x86_64.img
  10. title windows server 2016
  11. rootnoverify (hd0,2)
  12. chainloader +1
  13. You have new mail in /var/spool/mail/root
  14. cat /proc/cmdline //内核参数
  15. UUID
  16. rhgb(启动是否是图形界面)
  17. quiet(内核参数不显示去掉显示)
  18. loop 参数是8 修改内核参数添加更多 max_loop=100
  19. ls /dev/loop*

实验:删除/boot/grub 所有文件

修复需光盘引导 救援模式修复

网络

continue

ok

ok

点击shell start shell之后 
chroot /mnt/sysimage 切换跟
greb-install /dev/sda 修复完成

这里 修复好了 稍等下sync 因为它写到缓存 立即重启有可能会出现问题
但是唯独没有grub.conf
设置ip ip a a 172.18.0.100/24 dev eth0
编辑grub.conf文件

  1. default=0
  2. timeout=5
  3. titel centos6
  4. kernel /vmlinuz-2.6.32-696.el6.x86_64 ro root=uuid=xxxx
  5. initrd /initramfs-2.6.32-696.el6.x86_64.img
  6. r!ls /boot/vmlinuz-2.6.32-696.el6.x86_64 /boot/initramfs-2.6.32-696.el6.x86_64.img
  7. r!blkid /dev/sda2
  8. 完成. 重启

删除/boot全部

点击shell start shell之后
chroot /mnt/sysimage 切换跟
mount /dev/cdrom /mnt
rpm -ivh /mnt/Packages/kernel-2.6.32-696.el6.x86_64.rpm --force
greb-install /dev/sda 修复完成
这里 修复好了 稍等下sync 因为它写到缓存 立即重启有可能会出现问题
但是唯独没有grub.conf
因为没写grub.conf文件 现在重启
临时在这里填写启动后再补充完整

1

删除/boot全部 和/etc/fstab

因为把fstab文件破坏了,救援模式根都挂不上了。根挂不上
第一步:找根
猜根在哪 用blkid fdisk -l `fdisk -l /dev/sda 命令查看
之后去看大小 最大的一般是根
不行的话就一个一个挂载
mkdir /mnt/rootfs
mount /dev/sdaN/ /mnt/rootfs
ls 查看查看里面东西 有根包含的东西就是根

1

找到根之后编写/mnt/rootfs/etc/fstab文件

  1. cat > /mnt/rootfs/etc/fstab
  2. /dev/sda1/ /boot ext4 defaults 0 0
  3. /dev/sda2 / ext4 defaults 0 0
  4. /dev/sda3 /app ext4 defalts 0 0
  5. /dev/sda5 swap swap defalts 0 0

重要:之后必须重新启动让救援模式自动挂载分区
点击shell start shell之后

  1. mkdir /mnt/chrom
  2. mount /dev/sr0 /mnt/chrom
  3. rpm -ivh /mnt/Packages/kernel-2.6.32-696.el6.x86_64.rpm --root=/mnt/sysimage --force //引文没有切跟 所以要写--root=/mnt/sysimage
  1. chroot /mnt/sysimage 切换跟 //要装greb 必须切根
  2. greb-install /dev/sda 修复完成
  3. 这里 修复好了 稍等下sync 因为它写到缓存 立即重启有可能会出现问题
  4. 但是唯独没有grub.conf

编辑grub.conf文件

  1. default=0
  2. timeout=5
  3. titel centos6
  4. kernel /vmlinuz-2.6.32-696.el6.x86_64 ro root=uuid=xxxx
  5. initrd /initramfs-2.6.32-696.el6.x86_64.img
  6. r!ls /boot/vmlinuz-2.6.32-696.el6.x86_64 /boot/initramfs-2.6.32-696.el6.x86_64.img
  7. r!blkid /dev/sda2

现在重启 完成

实验:删除 /sbin/init

mv /sbin/init /app/ 这里先把/sbin/init文件移动到/app/下
重启reboot(启动不起来)

1

因为是只读方式所以重新挂载

  1. mount -o remount,rw /
  2. mount /dev/sda3/ /app
  3. mv /app/init /sbin
  4. exit 完成

加入app下没有了

  1. mount /dev/sr0 /mnt/ 挂载光盘
  2. rpm -ivh /mnt/Packages/kernel-2.6.32-696.el6.x86_64.rpm --force
  3. ls /sbin/init
  4. 也就可以了

逻辑卷删除

/etc/fstab /boot 删除
修复需光盘引导 救援模式修复

由于/etc/fstab文件被破坏,所以逻辑卷不能被挂载,此时必须先激活卷组,可以查看一下lv和vg,均处于不可用状态。

  1. 查看:lvs lvdisplay 逻辑卷 pvs 卷组
  2. 激活逻辑卷:vgchange ay
  3. 创建一个挂载点:mkdir /mnt/root
  4. 下面进行挂载:mount /dev/VolGroup/lv_root /mnt/root
  1. 现在开始恢复之前的fstab文件 ,自己手动写入文件内容导入到/etc/fstab,由于驱动也被破坏了,不能使用vim编辑器,所以只能用重定向导入。
  2. cat > /mnt/rootfs/etc/fstab
  3. /dev/sda1/ /boot ext4 defaults 0 0
  4. /dev/mapper/VolGroup/lv_root / ext4 defaults 0 0
  5. /dev/mapper/VolGroup-lv-swap swap swap defaults 0 0
  6. -------------------------------------------------
  7. swap写不写没关系 是为让你内存用的更多 如果没写 修复好之后在写的话需要 swapon -a 生效 swapon -s 查看是否生效 free 也能看
  8. mkdir /mnt/boot/
  9. mount /dev/sda1 /mnt/boot
  10. tail -n2 /etc/mtab > /mnt/root/fstab

重要:之后必须重新启动让救援模式自动挂载分区
点击shell start shell之后

  1. chroot /mnt/sysimage 切换跟 //要装greb 必须切根
  2. mkdir /mnt/chrom
  3. mount /dev/sr0 /mnt/chrom
  4. rpm -ivh /mnt/Packages/kernel-2.6.32-696.el6.x86_64.rpm --force //引文切跟了 所以不写--root=/mnt/sysimage
  5. greb-install /dev/sda 修复完成
  6. 这里 修复好了 稍等下sync 因为它写到缓存 立即重启有可能会出现问题
  7. 但是唯独没有grub.conf

之后 编辑grub.conf文件

  1. default=0
  2. timeout=5
  3. titel centos6
  4. kernel /vmlinuz-2.6.32-696.el6.x86_64 ro root=uuid=xxxx
  5. initrd /initramfs-2.6.32-696.el6.x86_64.img
  6. r!ls /boot/vmlinuz-2.6.32-696.el6.x86_64 /boot/initramfs-2.6.32-696.el6.x86_64.img
  7. r!blkid /dev/sda2

现在重启 完成

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注