现在的位置: 首页 > 综合 > 正文

Linux笔记

2013年10月16日 ⁄ 综合 ⁄ 共 16704字 ⁄ 字号 评论关闭
(一)
用户环境
#locale    显示系统语言环境       语言环境参数保存在/etc/sysconfig/i18n文件里
LANG最主要
#locale –a       查看系统对语言的支持情况
#LANG=zh_CN.GB2312       使系统支持以中文形式显示
kudzu      用来检测硬件
services kudzu start       重新检测硬件,让系统自动识别新硬件
硬件信息保存在/etc/sysconfig/hwconf文件
由kudzu产生
 
修改系统服务启动脚本
chkconfig kudzu –list     检查某个服务状态(包括各个级别0~6的状态)
setup       配置系统服务,一个综合配置工具
chkconfig –list | more   检查系统所有服务的状态
所有服务通过init启动
有些是通过xinetd服务启动的,如rsync
启动rsync
chkconfig rsync on
当执行service xinetd restart时,其实是执行/etc/init.d/xinetd这个脚本
而这个脚本会去检查自己的配置目录/etc/xinetd.d
/etc/rc0.d~/etc//rc6.d     里面的文件连接到../init.d/具体的服务,如/etc/iit.d/kudzu
S开头为启动,K为不启动
/etc/rc0.d~/etc/rc6.d ---àrc.d/rc0.d~rc6.d
设置系统服务ntsysv命令(同setup)
(二)
系统管理常用命令
1.       useradd redhat
2.       passwd redhat
3.       su –
4.       exit
5.       df –h 分区情况
6.       du –sh  /*      统计文件或目录使用空间的大小
7.       fdisk –l  /dev/sda
8.       netconfig         配置网络参数
9.       ifconfig           显示网络配置信息
10.   service network restart
11.   route –n          查看路由信息(默认路由)
12.   ping –b 192.168.0.255    扫描整个网段(检查活动主机)
13.   ifconfig eth0 10.0.0.254 netmask 255.255.255.0   修改IP地址
14.   ifconfig eth0显示指定网卡参数
15.   修改IP信息后会删除默认路由,需手工添加
route add default gw 192.168.0.1
16.   ifconfig route 修改过的参数不会保存,重启后会消失
要用service network restart命令把参数保存到文件ifcfg-eth0
/etc/sysconfig/network-scripts/ifcfg-eth0
可以vi直接修改该文件,然后service network restart 重新启用网络服务
17.   redhat-config-network-tui是redhat独有的配置工具,当用这个命令配置网络参数后,会写入到
/etc/sysconfig/networking/profiles/目录里,并且比network-scripts/ifcfg-eth0优先,所以用过这
个工具配置就不要再使用netconfig,或者先将profiles目录清空
 
(三)
文件系统的维护
ext2/ext3通过数据块储存文件
格式化文件系统:
mkfs.ext3 –b 4096 –i 8192 –m 5 /dev/sdb4
-b    数据块大小
-i     inode节点表示的字节数(或数据块大小)
-m 5              为管理员保留的磁盘管理空间5%    
ls –lh /mnt/u
du –sh /mnt/u
df –lh
#tune2fs –l /dev/sdb1            打印文件系统属性
#df
tune2fs 调整ext2/ext3文件系统特性的工具
-l     查看文件系统信息
-m   保留块百分比
-c <count>     设置强制自检的挂载次数
-i <n day>      设置强制自检的间隔时间
-j                   ext2转成ext3
 
tune2fs –c -1 /dev/sdb1               不管挂载多小次都不自检
tune2fs –c -1 –i 0 /dev/sdb1  让分区永远不自检
#mkfs.ext2 /dev/sdb4    格式化成ext2
#tune2fs –j /dev/sdb4     转换为ext3
#df –T                         查看分区信息
判断间ext2还是ext3:
tune2fs –l /dev/sdb1 | grep features
看Filesystem features: has_journal
是否有has_journal,有则是ext3文件系统
 
grep –i “name”       不区分大小写
df –T 分区类型
fsck        检查文件系统数据完整性的工具
用法一、fsck –t ext2 /dev/sdb1
       二、fsck.ext3 /dev/sdb1
#more /etc/fstab
如发现挂载选项有1或2,那么应该进行自检了
#fsck.ext3 –y /dev/sdb1        自动修复错误
 
(四)
管理磁盘文件系统
mount 设备名 挂载点
mount /dev/fd0 /mnt/floppy
光驱(IDE) /dev/cdrom  (à/dev/hdx)
光驱(SCSI)/dev/scdN      (N=0,1…)
硬盘(IDE) /dev/hdX        (X=a,b,c…)
硬盘(SCSI)/dev/sdX        (X=a,b,c…)
U盘               /dev/sdX        (X=a,b,c…)
 
弹出光盘#eject
收回#eject –t
因为USB设备内置USB-SCSI转换接口,所以被认为是SCSI硬盘
#mkdir /mnt/u
#mount /dev/sda1 /mnt/u
默认内核已支持SCSI和USB接口
#modprobe usb-storage         检查usb-storage模块是否已加载,否则无法自动识别USB设备
 
#mount –t vfat /dev/hda2 /mnt/c
#mount –t ntfs /dev/hda3 /mnt/d   需重新编译内核才能支持NTFS
#mount –t iso9660 /dev/cdrom /mnt/cdrom
#mount –t vfat –o iocharset=gb2312 /dev/sdb1 /mnt/u
常用字符编码有gb2312和utf8
#mount /dev/sdb2 /mmt/d –o iocharset=utf8,ro,uid=redhat,umask=0077
 
(五)
使用磁盘配额
默认系统内核已支持quota
mount –o usrquota,grpquota /dev/sdb1 /mnt/d1 或
mount –o remount,usrquota,grpquota /
#init 1     (进入单用户环境)
#quotacheck –cvuga      或 quotacheck –cvag  /dev/sdb1
#quotaon –a 激活
#edquota –u redhat        进VI编缉用户配额
编缉用户可用的字节数,软性的,硬性的,文件数,软件性的,硬性的
quota –u redhat
quota –t          配置过期时间
quotaoff /mnt/sdb1       关闭磁盘配额
quotaon /mnt/sdb1         开启
 
关于putty 0.58的简单设置
1.       修改语言环境 LANG=zh_CN.utf8
2.       修改传输数据的字符集translationàUTF8
3.       修改外观appearance字体font为新宋体
 
ls –ld       显示文件属主,详细信息
 
(六)
samba软件包使用
Fedora core/Redhat Linux提供的软件包
samba                   samba服务器软件包
samba-client          samba客户端工具
samba-common     通用工具和库
 
安装rpmdb-fedora/rpmdb-redhat软件包(一般在第三张光盘)
但在FC5已找不到这个软件包
安装了rpmdb可以解决依赖性问题
#rpm –ivh rpmdb-fedora*.rpm
#rpm –ivh --aid samba*.rpm  装了rpmdb才有效
 
1.#rpm –ivh cups-libs*.rpm   第一张光盘
2.#rpm –ivh samba*.rpm      第一张光盘(client,common)
3.#rpm –ivh samba*.rpm      第二张光盘
#rpm –qa |grep samba           查看所有软件包列表
#rpm –ql samba | more         查讯某个软件列表
 
samba客户端工具
smbtree
作用:显示局域网中的所有共享主机和目录列表(默认使用当前用户登录)
用法:smbtree [-b] [-D] [-U username%password]
-D   表示只显示工作组名,不显示主机
-b 使用广播查询列表,不用WINS服务器
-D和-U 不能共用,因为不可能用同一个用户登录域上所有主机
 
nmblookup
作用:显示一台主机的nethios主机名
nmblookup my-server    查询服务器的IP
nmblookup \*                查询所有活动的主机的IP
 
smbclient
作用:显示/登录局域网中的共享文件夹
用法:smbclient –L host
         smbclient //host/share
         smbclient –L 192.168.0.22 –U redhat%redhat  以redhat用户登录并显示共享目录
         smbclient //192.168.0.22/linux –U redhat%redhat   
登入目录,查看目录内容,通过put,get上下载文件
 
smbtar
远程备份网上邻居中的文件
smbtar –s win2000 –u redhat –p redhat –x chinalab –t itlab.tar
 
将共享目录挂载到本地目录,然后再访问
mount.cifs //192.168.0.22/linux /mnt –o username=redhat%redhat
 
tar tvf  lab.tar              显示备份包里的文件
 
samba服务器配置
1.修改配置文件/etc/samba/smb.conf
       workgroup = WORKGROUP
       security = share
[docs]
       path = /usr/share/doc
       comment = share documents  #说明共享目录
       public = yes
2.重启smb服务器
       #service smb restart
       #chkconfig smb on        让smb每次自动启动
3.测试
       #smbclient –L localhost
 
chkconfig smb –list              查看服务的启动状态
 
SMB       提供名称解释服务
NMB       提供数据传输服务
两个总是一起工作的
 
samba文件服务器
(WINS)在网上邻居看不到主机列表,可以在地址栏直接输入IP如\\192.168.0.1查看共享目录
网上邻居看到的主机列表,主要有三个来源:
一、是配置文件lmhosts,主机名与IP的对应关系
二、是通过浏览服务器
三、是通过广播方式获取主机列表
 
(七)
linux访问网上邻居
1.挂载方法
       #mount –t smbfs //192.168.0.1/linux /mnt   
或   #mount.cifs //192.168.0.1/linux /mnt
2.#smbclient //192.168.0.1/linux –U redhat%123
 
访问控制
public = yes           允许所有人访问
        = no             不允许匿名访问
1.共享目录设置有效用户
[redhat]
       path = /var/redhat
       comment = redhat’s files
       valid users = <username> <@groupname>
2.创建samba用户
       #useradd username        新建一个系统用户
       #smbpasswd –a username     将用户加入到samba中
3.用户账号映射
[global]
       username map = /etc/samba/smbusers
4.修改smbusers文件,添加虚拟用户名
       redhat = tom jack
5.需重启smb服务读取映射文件
 
HOME目录
[global]
       comment = Home Directories
       validusers = %S            %S目录属主
       browseable = no           不允许浏览home目录
       writable = yes               允许写
       valid users = 有效用户列表
       write list = 可写用户列表
       create mask = 0660              定义创建文件的默认权限
       directory mask = 0770 定义创建目录的默认权限
 
chown redhat /var/redhat 改变目录属主
ls –lh       显示目录里各个文件的详细信息
ls –ld /usr/redhat    只显示目录本身的详细信息
 
#testparm              测试配置默认文件smb.conf的正确性
#testparm /etc/samba/smb.conf my-server 192.168.0.1
测试客户机能访问服务器的哪些目录
 
[redhat]
       path = /var/redhat
       comment = redhat’s files
       public = no
       valid users = <username> <@groupname>
       write list  = <username> <@groupname>
       create mask = 0660
       directory mask = 0770
注意:客户端所有请求访问身份在服务器端都会映射成登录账号的身份
 
(八)
如何关闭selinux
/usr/sbin/setenforce 0    关闭
/usr/sbin/setenforce 1    开启
或在/etc/selinux/config中改
SELINUXTYPE=permissive        关闭,disabled也可以
 
samba配置文件
/etc/samba/smb.conf
[global]
       workgroup = WORKGROUP               组或域名
       server string = samba server                服务器描述
       netbios name = redhat                         指定samba服务器名
       security = share/user/server                 share不需验证用户,user要验证
       ;password server = <server>
       需与security=server配合使用
       log file = /var/log/samba/log.%m          %m指客户机的netbios名,日志按客户机名分类
       encrypt passwords = yes                          
加密密码,windows客户机一般使用加密密码,所以为yes.如果不加密直接用明文密码,可改为no,但
windows客户机需修改注册表指定不加密
       smb passwd file = /etc/samba/smbpasswd
上面两句要一起使用!
       include = /etc/samba/smb.conf.%m      包含外部配置文件,如根据不同的客户机名称,定义
不同的共享资源
       ;interfaces = 192.168.0.0/24                samba应用在哪个接口上,默认是在所有网卡,
所有接口上
       ;name resolve order =  wins lmhosts bcaast              名称解释顺序
       ;wins support = yes                                   自己作为WINS服务器,并提供给客
户机查询
       ;wins server = w.x..y.z                       与WINS配合使用,作为WINS服务器,请求会
发送到w.x.y.z
 
lmhosts文件(保存客户机IP与名称的对应关系)
左边IP          右边名称
127.0.0.1        localhost
 
wins support,wins server             不能同时使用
wins server    说明本身作为客户机,而指定一台wins服务器的IP
 
(九)
samba的安全级别
[global]
       security = <level>
1.share
       windows用户不需要认证就能访问共享列表
2.user
       windows客户机需输入用户才能访问共享名列表,服务器上需建立用户账号
3.server
       客户端需输入合法用户帮能访问,但认证过程在另一服务器进行,用户账号保存在认证的那台服
务器上。
share,user只对windows客户机有效,linux客户机在user级别不用密码也能访问共享名列表。security只
保护主机的共享名列表,具体到目录的访问则由目录的规则决定。
 
#hostname      查看主机名
#nmblookup    my-server       查询主机IP(与samba netbios name有关)
#man smb.conf      查看相关帮助
vi搜索技巧:
       /%m              先输入”/”再输入要查找的字符串
       /redhat    如查找”redhat”字符串
       shift+G   跳到文件尾
 
默认服务器名与机器DNS的第一部分相同
如Fedora.cyrich.com则这台samba服务器的名称就是Fedora
 
访问控制
一、全局控制
[global]
       hosts deny = ALL
       hosts allow = 192.168.0.
二、局部访问控制
[docs]
       hosts deny = 192.168.0.
       hosts allow = 192.168.0.1
[redhat]
       hosts allow = 192.168.0.
       host deny = 192.168.0.1       (失效)
允许优先!!
hosts 后面的格式语法,可以通过man 5 host.access查看帮助
1.点开头 .edu.cn
2.点结尾 192.168.0.
3.192.168.0.0/255.255.255.0
  192.168.0.0/24
4.ALL  LOCAL UNKNOWN       DNS不能解析的
5./开头   指定一个文件
6.hosts allow = 192.168.0.0 EXCEPT  192.168.0.1
允许192.168.0网段主机访问,但192.168.0.1除外
 
技巧:
#tail /etc/samba/smb.conf
显示文件最后的十行
vi中shift+D删除一行
 
(十)
应用案例
要求:
1.所有员工都能够在公司内流动办公,但不管在哪台电脑上工作,都要把自己的文件数据保存在samba文
件服务器上。
2.市场部,技术部都各有自己的目录,同一个部门的人共同拥有一个共享目录,其他部门的人都只能访问
在服务器上自己个人的home目录
3.所有用户都不允许使用服务器上的shell
分析:
1.需要samba作为文件服务器,为所有用户创建账号和目录,用户默认都 在服务器上有一个home目录,只
有认证通过才能看到。
2.需为市场部和技术部创建不同的组sales和tech,并且分配目录,把所有市场部员工加入sales组,技术
部员工加入tech组,通过samba共享sales和tect
3.建立用户账号时,不分配shell
案例实施:
1.为所有用户创建账号和目录,不分配shell,假设市场部有tom,jack,技术部有red,blue,总经理ceo,财
务finance
2.建组sales和tech,把所有市场部员工加入sales组,技术部员工加入tect组
3.创建两个目录/home/sales和/home/tech,并修改两个目录的权限,分别属于sales组和tect组
4.通过samba共享/home/sales和/home/tect
5.测试
如有错误,检查
/etc/samba/smbpasswd         确定账户
/etc/samba/smbusers            查看映射文件
tail /var/log/samba/redhat.log        查看/var/log/samba/目录下的日志
 
具体操作:
#vi /etc/samba/smb.conf              安全级别为user
#groupadd sales
#groupadd tech
#useradd –g sales –s /bin/false tom
#useradd –g sales –s /bin/false jack
#smbpasswd –a tom
#smbpasswd –a jack
#for user in red blue
>do
>    useradd –g tech –s /bin/false  $user
>     smbpasswd –a $user
>     done
 
#useradd ceo
#useradd finance
#smbpasswd –a ceo
#smbpasswd –a finance
#mkdir /home/sales /home/tech
#chgrp sales   /home/sales
#chgrp tech    /home/tech
#chmod 770 /home/sales
#chmod 770 /home/tech
#chmod g+s /home/sales              防止权限发生混乱
#chmod g+s /home/tech
#vi /etc/samba/smb.conf
[global]
       path = /home/sales
       comment = sales
       public = no
       valid users = @sales
       write list = @sales
       create mask = 0770
       directory mask = 0770
[tech]
       path = /home/tech
       comment = tech
       public = no
       valid users = @tech
       write list = @tech
       create mask = 0770
       directory mask = 0770
 
linux测试
1.smbclient –L 192.168.0.22 –U tom%tom
2.mount.cifs //192.168.0.22/ceo –o username ceo%ceo
windows客户机映射网络驱动器,再设定“我的文档”位置,就可随时随地将文件保存在samba服务器上
十一)

安全的动态磁盘策略

linux内核可以模拟RAID控制器,用来管理硬盘,但只支持级别0,1,4,5
RAID0 又称striping
把连续的数据访问分散到多个磁盘上来提高存储性能,速度最快,但最危险。
RAID1 又称Mirror或Mirroring
最大限度的保证用户数据的可用性和可修复性,用户数据100%自动复制到另外一个硬盘上,速度稍慢,因为要同时写多个硬盘。
RAID5    最少需三个硬盘
不对存储的数据时行备份,而把数据和对应的奇偶校验信息分别存储在不同的磁盘上,当一个磁盘数据发生损坏后,利用剩下的数据和相应的奇偶校验信息去恢复被损坏的数据。
RAID0+1       也称RAID10
结合RAID0和RAID1的优点,很多公司在应用
 
Linux中的软件RAID
1.默认内核已支持软件RAID控制器
2.需用到raidtools工具来创建管理RAID设备,但Fedora Core5不使用这个,而用mdadm工具。
3.软件RAID设备文件名:/dev/mdN        (N=0,1,2…)
4.软件RAID设备可以当分区看待,需格式化后挂载
#mkfs.ext3     /dev/md1
#mount /dev/md1 /opt
 
使用mdadm来创建和管理RAID
RAID0
       添加硬盘
       RAID设备的成员是硬盘分区,需先对硬盘分区,分区不能在同一物理硬盘上
       #fdisk /dev/sdb
       n创建主分区,t分区类型fd,w写保存
       #fdisk /dev/sdc
       #mdadm –Cv /dev/md0 –l0 –n2 /dev/sdb1 /dev/sdc1
              -C,--create             创建一个新的阵列
              -v,verbose             显示细节
              /dev/md0               阵列设备的名称
              -l,--level=              阵列级别,如0,1,4,5,6
              -n,--raid-devices=   阵列活动数目
              /dev/sd[bc]1          阵列包含的设备列表
       #more /proc/mdstat              查看阵列状态
       #mkfs.ext3 /dev/md0     创建文件系统
       #mount /dev/md0 /mnt/raid
       让系统自动挂载,修改/etc/fstab,添加
       /dev/md0       /mnt/raid        ext3 defaults 0 0
 
RAID5 故障模拟
       前面已创建了一个RAID5设备md0
       #mdadm –Cv /dev/md0 –l5 –n3 –x1 –c128 /dev/sd[b,c,d,e]1
       1.将/dev/sdb1标记为已损坏的设备
       #mdadm /dev/md0 –f  /dev/sdb1
       这时阵列开始重构和恢复数据
       2.移除损坏的设备
       #mdadm /dev/md0 –r /dev/sdb1
       3.将新设备添加到阵列
       注意,一:对硬盘正确分区,二:添加设备名要与被移除的一致,如sdb1
       #mdadm /dev/md0 –a /dev/sdb1
      
生成配置文件/etc/mdadm.conf
格式如下:
DEVICE /dev/sdb1 /dev/sdc1 /dev/sdd1 /dev/sde1 ARRAY /dev/md10 level=raid10 num-devices=4 UUID=12334343dkfj
 
其中UUID信息通过#mdadm –D /dev/md10得到
#mdadm –Ds 扫描该文件信息
 
常用阵列维护命令
1.启用阵列
       #mdadm –As /dev/md0
       -A    启用已存在的阵列
       -s    以/etc/mdadm.conf为依据
       没有创建mdadm.conf文件,则采用如下方法启用
       #mdadm –A /dev/md0 /dev/sd[bc]1
2.停止阵列
       #mdadm –S /dev/md0
3.显示阵列详细信息
       #mdadm –D /dev/md0
 
(十二)
 
LVM逻辑卷管理器
PV (physical volume)物理卷
VG (Volume Group)卷组
LV (Logical Volume)逻辑卷
 
1.fdisk /dev/sdb
       分区sdb1,sdb2,sdb3
       分区类型8e(Linux LVM)
       如果系统在使用sdb,需要重启,以便系统重新读取sdb的分区表信息
2.#pvcreate /dev/sdb[1-3]     初始化物理卷
3.#vgscan                            扫描物理卷,创建卷组数据库
4.#vgcreate vg0 /dev/sdb1 /dev/sdb2           用sdb1,sdb2创建卷组vg0
  #vgdisplay vg0                                      查看卷组vg0的信息
5.#lvcreate –n data –L 10M vg0                  从vg0中创建一个新的名为data,大小10M的逻辑卷
6.#mkfs.ext3 /dev/vg0/data                        格式化
7.#mount /dev/vg0/data /mnt
  #lvdisplay /dev/vg0/data                          查看逻辑卷data的分区情况
  #lvcreate –n test –l 5 vg0                        创建逻辑卷用-l指定块数,默认块大小4MB,即分配逻辑卷20MB大小
创建完逻辑卷一定要mkfs.ext3格式化才能使用
  #lvscan                                                 扫描逻辑卷,看它们的活动情况
 
#lvextend –L +20M /dev/vg0/data                扩大逻辑卷20M,要先umount分区,再扩大
#e2fsck –f /dev/vg0/data                                   强行检查data逻辑卷
#resize2fs /dev/vg0/data                             重新定义分区大小
以上三步要按顺序进行
 
#pvscan                                                   查看系统目前的物理卷情况
#vgextend vg0 /dev/sdb2                            扩大卷组vg0,将分区sdb3加入卷组
#pvmove /dev/sdb1                                          移除物理卷
#vgreduce vg0 /dev/sdb1                           从卷组中删除sdb1
pvmove将数据移走,但sdb1还在vg0内,还是属于卷组分区,vgreduce将sdb1从vg0中删除
创建卷组时,默认的PE大小4MB,允许的LV最大256G
#vgcreate –s 8M vg1 /dev/sdb1
-s    指定PE块大小
通过改变PE块大小,从而改变卷组允许支持的逻辑卷最大容量
 
技巧:
#clear      清屏
#df –lh    显示系统现在的分区挂载情况
 
建立快照(备份数据)
#lvcreate –s –L 52M –n snap /dev/vg0/data
-s    表示快照
-L    快照大小要大于或等于被创建的逻辑卷data
-n    快照名称
快照不用格式化即可使用
 
删除逻辑卷步骤LVàVGàPV
1.umount所有LV
2.lvremove /dev/vg0/data      (通过lvscan查看)如有快照,先移除快照再移除逻辑卷。
3.#vgremove vg0
使用过程中,如有错误,可查看系统日志
#tail /var/log/message
 
(十三)
综合应用案例
要求:使用三个硬盘存储数据,保证数据安全性的同时还能让磁盘窨根据需要动态的缩放
设备sdb sdc sdd
1.将三个硬盘组成RAID5,实现安全性
2.在阵列md0上创建物理卷,卷组,逻辑卷
3.将数据转移到逻辑卷
 
具体操作:
1.fdisk 三个硬盘,分区类型fd,最后得到sdb1,sdc1,sdd1
2.创建raid设备
#mdadm –Cv /dev/md0 –l5 –n3 /dev/sd[b,c,d]1
3.#pvcreate /dev/md0           在阵列上初始化物理卷
4.#vgcreate vg /dev/md0
5.#lvcreate –n home –L 100M vg
#lvcreate –n var –L 100M vg
#mkfs.ext3 /dev/vg/home
#mkfs.ext3 /dev/vg/var
#mkdir /mnt/home
#mkdir /mnt/var
#mount /dev/vg/home /mnt/home
#mount /dev/vg/var /mnt/var
#cp –a /home/* /mnt/home
#cp –a /var/*  /mnt/var
#df –lh
6.#vi /etc/fstab 添加
/dev/vg/home         /home     ext3 defaults 0 0
/dev/vg/var            /var         ext3 defaults 0 0
7.#vi /etc/mdadm.conf   创建文件,以便系统启动时能够自动识别raid设备,内容如下:
DEVICE /dev/sdb1 /dev/sdc1 /dev/sdd1 ARRAY /dev/md0 level=raid5 num-devices=3 UUID=123545:erdfj3:dkf3jd
(UUID具体通过mdadm –D /dev/md0获取)
8.reboot
 
上面已正确地将数据移植到LVM上,下面将/分区移植到LVM上
#lvcreate –n root –L 200M vg
#mkfs.ext3 /dev/vg/root
#mount /dev/vg/root /mnt
#cd /mnt
#mkdir proc tmp var home opt cdrom media mnt srv selinux
#cd /
#cp –a bin dev etc lib sbin root usr sys /mnt &
当操作的过程时间太长,可按ctrl+z,再输入bg,让它后台运行
技巧:
#rm –rf /mnt/bin    强行删除目录
#\ls         不高亮显示
RAID5的磁盘容量利用率为2/3
 
利用mkinitrd创建一个虚拟的磁盘映像文件
#mkdir /boot/test
#mkinitrd –v –preload raid5 –preload lvm-m0d /boot/test/initrd-lvm-$(uname-r)img $(uname –r)
在里面添加加载根分区所需的raid设备文件,驱动程序,命令mdadm等
#cd /boot/test
#mv initrd-lvm-2.6.15-1.2054_FC.img initrd-lvm-2.6.15-1.2054_FC.img.gz
#gunzip init-lvm-2.6.15-1.2054_FC.img.gz
#cpio –idv < init-lvm-2.6.15-1.2054_FC.img
#rm initrd-lvm-2.6.15-1.2054_FC.img
添加设备文件,复制文件时要注意-a参数
#cp –a /dev/vg dev
#cp –a /dev/mapper dev
#cp –a /dev/md0 dev
#cp –a /dev/sd[abcd] dev
#cp –a /dev/sd[abcd]1 dev
#vi init 添加,一定要在mkblkders后面添加,系统启动后执行的第一个脚本,自动激活磁盘阵列
       mdadm –As                 
       vgscan
       vgchange –a y
       修改加载的root分区
       mount –o defaults --ro -t ext3 /dev/vg/root /sysroot
#cp /sbin/vgscan bin
#cp /sbin/vgchange bin
#cp /sbin/mdadm bin
#ldd bin/mdadm     查看该命令所需的库文件
#cp /lib/libc.so.6 lib              (字母o)添加命令所需库文件
#cp /lib/ld-linux.so.1 lib
上面的mdadm -As会根据配置文件mdadm.conf激活阵列,所以将/etc/mdadm.conf拷过来
#cp /etc/mdadm.conf etc             (之前已经手工创建了mdadm.conf),添加配置文件
最后确认/boot/test目录里的文件准备打包
#cd /boot/test
#find -print | cpio -oc > /boot/initrd-lvm-$(uname -r).img
#cd /boot
#gzip initrd-lvm-2.6.15-1.2054_FC.img -c > init-lvm-2.6.15-1.2054_FC.img.gz
这样将文件恢复成一个虚拟磁盘映像文件
 
修改引导配置
#vi /boot/grub/grub.conf
修改defaults=1
添加
title Fedora LVM
       root (hd0,0)
       kernel /boot/vmlinuxz-2.6.15-1.2054_FC ro root=/dev/vg/root  
       和/boot目录里的vmlinuxz对应,注意root=/dev/vg/root的修改
       initrd /boot/initrd-lvm-2.6.15-1.2054_FC.img.gz
保存退出
#mount /dev/vg/root /mnt
#cd /mnt
#vi etc/fstab    修改
/dev/vg/root    /      ext3 defaults   1 1
这样系统启动就会将/dev/vg/root 作为主分区使用
完成所有修改
#reboot
从启后ls /boot应该没有东西,因为物理boot在sda1分区里
可以#mount /dev/sda1 /mnt 再看看里面的boot内容
证明已经成功的转移了根分区,完成了案例提出的要求。
 
在进行这个实验时,主要是对磁盘映像文件的修改,修改init文件时,要注意加载模块的顺序,先创建块设备,才能使用块文件。
使用mkinitrd创建文件后,要注意用file命令查看文件类型,从而进一步对映像文件进行解压,提取等操作。当修改完磁盘映像文件initrd后,要知道如何打包、压缩。注意如何使用cpio命令。
 
(十四)
 
Linux下使用U盘
#ls /dev   确认设备已识别
#mount -o iocharset=gb2312 /dev/sda1
more后ctrl+F向下翻页(或空格)ctrl+b(上滚)
ls -a        显示隐藏文件(以.开头的文件)
文件权限rws        s表示执行这个程序的使用者,临时拥有和所有者一样的权力身份来执行该程序
cp -r 源  目的      -r参数表示连子目录一起拷贝
rm -i            确认删除
       -r            删除子目录
       -f            强制删除
du    磁盘或目录使用了多少空间
df    磁盘或目录剩余可用空间
cat >file1        等价你输入文字,输完后ctrl+C或ctrl+D结束
>>符号表示在文件尾附加,>符号表示创建新文件
less  可上下滚动文件内容
which     在$PATH设置的目录查找文件
 
FTP服务器
FTP使用TCP协议
21端口传输控制信息
20端口传输数据
验证信息采用明文传输
匿名用户anonymous
binary模式传输程序、图片等二进制文件
ascii模式舆文本文件
安装vsftpd
1.下载源代码vsftpd-2.0.5.tar.gz
2.编译源程序,可参考帮助文件INSTALL
       #tar zxvf vs

抱歉!评论已关闭.