包的组成:
二进制文件, 库文件, 配置文件, 帮助文件
程序包管理器:
debian: deb 文件, dpkg 包管理器
RedHat: rpm 文件, rpm 包管理器
rpm 包命名方式:
name-VERSION-release.arch.rpm
例: bash-4.2.46-19.el7.x86_64.rpm
- VERSION: major.minor.release
- release:release.OS
常见的 arch:
x86: i386, i486, i586, i686
- x86_64: x64, x86_64, amd64
- powerpc: ppc
跟平台无关: noarch
解决依赖包管理工具:
yum:rpm 包管理器的前端工具
apt:deb 包管理器前端工具
zypper:suse 上的 rpm 前端管理工具
dnf:Fedora 18+ rpm 包管理器前端管理工具
查看二进制程序所依赖的库文件
ldd /PATH/TO/BINARY_FILE
管理及查看本机装载的库文件
ldconfig 加载配置文件中指定的库文件
/sbin/ldconfig -p 显示本机已经缓存的所有可用库文件名及文件路径
映射关系
配置文件:/etc/ld.so.conf, /etc/ld.so.conf.d/*.conf
缓存文件:/etc/ld.so.cache
包文件组成 (每个包独有)
RPM 包内的文件
RPM 的元数据, 如名称, 版本, 依赖性, 描述等
安装或卸载时运行的脚本
数据库(公共):/var/lib/rpm
程序包名称及版本
依赖关系
功能说明
包安装后生成的各文件路径及校验码信息
获取程序包的途径:
(1) 系统发版的光盘或官方的服务器
CentOS 镜像:
- https://www.centos.org/download/
- http://mirrors.aliyun.com/
- http://mirrors.sohu.com/
- http://mirrors.163.com/
(2) 项目官方站点
(3) 第三方组织:
- Fedora-EPEL:
- Extra Packages for Enterprise Linux
Rpmforge:RHEL 推荐, 包很全
搜索引擎:
- http://pkgs.org/
- http://rpmfind.net/
- http://rpm.pbone.net/
- https://sourceforge.net/
(4) 自己制作
? 注意: 第三方包建议要检查其合法性
来源合法性, 程序包的完整性
管理程序包的方式:
使用包管理器: rpm
使用前端工具: yum, dnf(centos8 版本开始)
安装:
- rpm {
- -i|--install
- } [install-options] PACKAGE_FILE...
- -v: verbose(显示详细过程)
- -vv:
-h: 以 #显示程序包管理执行进度
rpm -ivh PACKAGE(包裹)_FILE ...
--test: 测试安装, 但不真正执行安装, 即 dry run 模式
--nodeps: 忽略依赖关系
--replacepkgs(完整覆盖安装) | replacefiles (仅覆盖安装重复文件)
--nosignature: 不检查来源合法性
--nodigest: 不检查包完整性
--noscripts: 不执行程序包脚本
%pre: 安装前脚本 --nopre
%post: 安装后脚本 --nopost
%preun: 卸载前脚本 --nopreun
%postun: 卸载后脚本 --nopostun
rpm 包升级
- rpm {
- -U|--upgrade
- } [install-options] PACKAGE_FILE...
- rpm {
- -F|--freshen
- } [install-options] PACKAGE_FILE...
upgrade: 安装有旧版程序包, 则 "升级"
如果不存在旧版程序包, 则 "安装"
freshen: 安装有旧版程序包, 则 "升级"
如果不存在旧版程序包, 则不执行升级操作
- rpm -Uvh PACKAGE_FILE ...
- rpm -Fvh PACKAGE_FILE ...
--oldpackage: 降级
--force: 强制安装
包查询
- rpm {
- -q|--query
- } [select-options] [query-options]
- [select-options]
-a: 所有包
-f: 查看指定的文件由哪个程序包安装生成
-p rpmfile: 针对尚未安装的程序包文件做查询操作
--whatprovides CAPABILITY(能力, 功能): 查询指定的 CAPABILITY 由哪个包所提供
--whatrequires CAPABILITY: 查询指定的 CAPABILITY 被哪个包所依赖
rpm2cpio 包文件 | cpio -itv 预览包内文件
rpm2cpio 包文件 | cpio -id "*.conf" 释放包内文件
--changelog: 查询 rpm 包的 changelog
-c: 查询程序的配置文件
-d: 查询程序的文档
-i:information(信息)
-l: 查看指定的程序包安装后生成的所有文件
--scripts: 程序包自带的脚本
--provides: 列出指定程序包所提供的 CAPABILITY
-R: 查询指定的程序包所依赖的 CAPABILITY
常用查询用法:
-qi PACKAGE, -qf FILE, -qc PACKAGE, -ql PACKAGE, -qd PACKAGE
-qpi PACKAGE_FILE, -qpl PACKAGE_FILE, ...
-qa
包卸载:
- rpm {
- -e|--erase
- } [--allmatches] [--nodeps] [--noscripts] [--notriggers]
- [--test] PACKAGE_NAME ...
当包卸载时, 对应的配置文件不会删除, 以 FILENAME.rpmsave 形式保留
神奇的文件夹(用来自动挂载光盘)
操作步骤:(1) rpm -ivh /misc/cd/Packages/autofs-5.0.7-99.el7.x86_64.rpm(安装)
- systemctl start autofs (systemctl enable autofs 下次开机程序自启动)
- (2) cd /misc/cd/
(3) ls 会有 Packages 文件夹(6 7 版本中)
(4) df 查看 自动挂载成功
diff 文件 1 文件 2 用于两个文件的对比
包校验: rpm -K
yum
文件服务器:
- http://
- https://
- ftp://
- file://
yum 客户端配置文件:
/etc/yum.conf: 为所有仓库提供公共配置
/etc/yum.repos.d/*.repo: 为仓库的指向提供配置
作为 yum 源路径的前提: 在目录中必须有 repodata 文件夹
仓库指向的定义:
- [repositoryID]
- name=Some name for this repository
- baseurl=url://path/to/repository/ (仓库指向的路径)
- enabled={
- 1|0
- } (1 为启用 0 为禁用 默认启用)
- gpgcheck={
- 1|0
- } (1 为检查密钥 0 为不检查 默认不检查)
- gpgkey=URL (密钥路径)
自配 yum 出现问题的两点原因:(1)配置文件格式错误 例如 baseurl 路径错误
(2)缓存问题
显示仓库列表:
yum repolist
显示程序包:
yum list
升级程序包:
- yum update [package1] [package2] [...]
- yum downgrade package1 [package2] [...] (降级)
? 检查可用升级:
yum check-update
? 卸载程序包:
yum remove
清除缓存:
yum clean all
查看程序包 information(信息)
yum info [...]
查看 yum 事务历史
yum history
例: yum history info 6(查看历史记录中编号 6 的操作)
- yum history undo 6(撤销历史纪录中编号 6 的操作)
- yum history redo 6 (重新执行历史记录中 6 的操作)
日志 :/var/log/yum.log
查看指定的特性 (可以是某文件) 是由哪个程序包所提供: yum provides
编译安装
C 语言源代码编译安装三步骤:
1, ./configure
(1) 通过选项传递参数, 指定启用特性, 安装路径等; 执行时会参考用户的
指定以及 Makefile.in 文件生成 Makefile
(2) 检查依赖到的外部环境, 如依赖的软件包
2, make 根据 Makefile 文件, 构建应用程序
3, make install 复制文件到相应路径
开发工具:
autoconf: 生成 configure 脚本
automake: 生成 Makefile.in
注意: 安装前查看 INSTALL,README
管理分区
列出块设备
lsblk
创建分区使用:
fdisk 创建 MBR 分区
gdisk 创建 GPT 分区(GPT 创建分区只有主分区 )
fdisk -l [-u] [device...] 查看分区
fdisk /dev/sdb 管理分区
p 分区列表
t 更改分区类型
n 创建新分区
d 删除分区
v 校验分区
u 转换单位
w 保存并退出
q 不保存并退出
同步分区表
查看内核是否已经识别新的分区
cat /proc/partations
centos6 通知内核重新读取硬盘分区表
新增分区用
- partx -a /dev/DEVICE
- kpartx -a /dev/DEVICE -f: force
删除分区用
partx -d --nr M-N /dev/DEVICE
CentOS 5,7: 使用 partprobe
partprobe [/dev/DEVICE]
查前支持的文件系统: cat /proc/filesystems
创建文件系统
mkfs 命令:
- (1) mkfs.FS_TYPE /dev/DEVICE
- ext4
- xfs
- btrfs
- vfat
- (2) mkfs -t FS_TYPE /dev/DEVICE
-L 'LABEL' 设定卷标
mke2fs:ext 系列文件系统专用管理工具
-t {ext2|ext3|ext4} 指定文件系统类型
-b {1024|2048|4096} 指定块大小
-L 'LABEL' 设置卷标
-j 相当于 -t ext3
- mkfs.ext3 = mkfs -t ext3 = mke2fs -j = mke2fs -t ext3
- -i # 为数据空间中每多少个字节创建一个 inode; 不应该小于 block 大小
- -N # 指定分区中创建多少个 inode
-I 一个 inode 记录占用的磁盘空间大小, 128---4096
-m # 默认 5%, 为管理人员预留空间占总空间的百分比
-O FEATURE[,...] 启用指定特性
-O ^FEATURE 关闭指定特性
blkid: 块设备属性信息查看
blkid [OPTION]... [DEVICE]
-U UUID 根据指定的 UUID 来查找对应的设备
-L LABEL 根据指定的 LABEL 来查找对应的设备
e2label: 管理 ext 系列文件系统的 LABEL
e2label DEVICE [LABEL]
findfs : 查找分区
- findfs [options] LABEL=<label>
- findfs [options] UUID=<uuid>
tune2fs: 重新设定 ext 系列文件系统可调整参数的值
-l 查看指定文件系统超级块信息; super block
-L 'LABEL' 修改卷标
-m # 修预留给管理员的空间百分比
-j 将 ext2 升级为 ext3
-O 文件系统属性启用或禁用, -O ^has_journal
-o 调整文件系统的默认挂载选项,-o ^acl
-U UUID 修改 UUID 号
?dumpe2fs:
将磁盘块分组管理
-h: 查看超级块信息, 不显示分组信息
文件系统检测和修复
? 常发生于死机或者非正常关机之后
? 挂载为文件系统标记为 "no clean"
? 注意: 一定不要在挂载状态下修复
- ?fsck: File System Check
- fsck.FS_TYPE
- fsck -t FS_TYPE
-p 自动修复错误
-r 交互式修复错误
FS_TYPE 一定要与分区上已经文件类型
?e2fsck:ext 系列文件专用的检测修复工具
-y 自动回答为 yes
-f 强制修复
用 mount 命令挂载文件系统
? 挂载方法: mount DEVICE MOUNT_POINT
?mount: 通过查看 / etc/mtab 文件显示当前已挂载的所有设备
?mount [-fnrsvw] [-t vfstype] [-o options] device dir
device: 指明要挂载的设备;
(1) 设备文件: 例如 / dev/sda5
(2) 卷标:-L 'LABEL', 例如 -L 'MYDATA'
(3) UUID, -U 'UUID': 例如 -U '0c50523c-43f1-45e7-
85c0-a126711d406e'
(4) 伪文件系统名称: proc, sysfs, devtmpfs, configfs
dir: 挂载点
事先存在, 建议使用空目录
进程正在使用中的设备无法被卸载
mount 常用命令选项
?-t vsftype 指定要挂载的设备上的文件系统类型
?-r readonly, 只读挂载
?-w read and write, 读写挂载
?-n 不更新 / etc/mtab,mount 不可见
?-a 自动挂载所有支持自动挂载的设备(定义在了 / etc/fstab 文件
中, 且挂载选项中有 auto 功能)
?-L 'LABEL' 以卷标指定挂载设备
?-U 'UUID' 以 UUID 指定要挂载的设备
?-B, --bind 绑定目录到另一个目录上
? 查看内核追踪到的已挂载的所有设备
cat /proc/mounts
mount 常用命令选项
? -o options:(挂载文件系统的选项), 多个选项使用逗号分隔
async 异步模式 sync 同步模式, 内存更改时, 同时写磁盘
atime/noatime 包含目录和文件
diratime/nodiratime 目录的访问时间戳
auto/noauto 是否支持自动挂载, 是否支持 - a 选项
exec/noexec 是否支持将文件系统上运行应用程序
dev/nodev 是否支持在此文件系统上使用设备文件
suid/nosuid 是否支持 suid 和 sgid 权限
remount 重新挂载
ro 只读 rw 读写
user/nouser 是否允许普通用户挂载此设备,/etc/fstab 使用
acl 启用此文件系统上的 acl 功能
loop 使用 loop 设备
? defaults: 相当于 rw, suid, dev, exec, auto, nouser, async
卸载命令
? 查看挂载情况
findmnt MOUNT_POINT|device
查看正在访问指定文件系统的进程
- lsof MOUNT_POINT
- fuser -v MOUNT_POINT
? 终止所有在正访问指定的文件系统的进程
fuser -km MOUNT_POINT
? 卸载
- umount DEVICE
- umount MOUNT_POINT
挂载点和 / etc/fstab
? 配置文件系统体系
? 被 mount, fsck 和其它程序使用
? 系统重启时保留文件系统体系
? 可以在设备栏使用文件系统卷标
? 使用 mount -a 命令挂载 / etc/fstab 中的所有文件系统
文件挂载配置文件
? /etc/fstab 每行定义一个要挂载的文件系统
? 1, 要挂载的设备或伪文件系统
设备文件
LABEL:LABEL=""UUID:UUID=""
伪文件系统名称: proc, sysfs
? 2, 挂载点
? 3, 文件系统类型: ext4,xfs,iso9660,nfs,none
? 4, 挂载选项: defaults ,acl,bind
? 5, 转储频率: 0: 不做备份 1: 每天转储 2: 每隔一天转储
? 6, fsck 检查的文件系统的顺序: 允许的数字是 0 1 2
0: 不自检
1: 首先自检; 一般只有 rootfs 才用
2: 非 rootfs 使用
处理交换文件和分区
swap 交换分区是系统 RAM 的补充, Swap 分区支持虚拟内存. 当没有足够的
RAM 保存系统处理的数据时会将数据写入 swap 分区
挂载交换分区
? 基本设置包括:
? 创建交换分区或者文件
? 使用 mkswap 写入特殊签名
? 在 / etc/fstab 文件中添加适当的条目
? 使用 swapon -a 激活交换空间
? 启用: swapon
swapon [OPTION]... [DEVICE]
-a: 激活所有的交换分区
-p PRIORITY: 指定优先级
/etc/fstab 在第 4 列中: pri=value
? 禁用: swapoff [OPTION]... [DEVICE]
SWAP 的优先级
? 可以指定 swap 分区 0 到 32767 的优先级, 值越大优先级越高
? 如果用户没有指定, 那么核心会自动给 swap 指定一个优先级, 这个优先级从
-1 开始, 每加入一个新的没有用户指定优先级的 swap, 会给这个优先级减一
? 先添加的 swap 的缺省优先级比较高, 除非用户自己指定一个优先级, 而用户
指定的优先级 (是正数) 永远高于核心缺省指定的优先级(是负数)
使用光盘
创建 ISO 文件
- cp /dev/cdrom /root/CentOS.iso
- mkisofs -r -o /root/etc.iso /etc
常见工具
? 文件系统空间占用等信息的查看工具
df [OPTION]... [FILE]...
-H 以 10 为单位
-T 文件系统类型
- -h human-readable
- -i inodes instead of blocks
-P 以 Posix 兼容的格式输出
? 查看某目录总体空间占用状态
- du [OPTION]... DIR
- -h human-readable
- -s summary
- --max-depth=# 指定最大目录层级
工具 dd
dd 命令: convert and copy a file? 用法: dd if=/PATH/FROM/SRC of=/PATH/TO/DEST bs=# count=#
if=file 从所命名文件读取而不是从标准输入
of=file 写到所命名的文件而不是到标准输出
ibs=size 一次读 size 个 byte
obs=size 一次写 size 个 byte
bs=size block size, 指定块大小(既是是 ibs 也是 obs)
cbs=size 一次转化 size 个 byte
skip=blocks 从开头忽略 blocks 个 ibs 大小的块
seek=blocks 从开头忽略 blocks 个 obs 大小的块
count=n 复制 n 个 bs
conv=conversion[,conversion...] 用指定的参数转换文件
? 转换参数:
?ascii 转换 EBCDIC 为 ASCII
?ebcdic 转换 ASCII 为 EBCDIC
?lcase 把大写字符转换为小写字符
?ucase 把小写字符转换为大写字符
?nocreat 不创建输出文件
?noerror 出错时不停止
?notrunc 不截短输出文件
?sync 把每个输入块填充到 ibs 个字节, 不足部分用空 (NUL) 字符补齐
?Fdatasync 写完成前, 物理写入输出文件
备份 MBR
dd if=/dev/sda of=/tmp/mbr.bak bs=512 count=1
? 破坏 MBR 中的 bootloader
dd if=/dev/zero of=/dev/sda bs=64 count=1 seek=446
? 有一个大与 2K 的二进制文件 fileA. 现在想从第 64 个字节位置开始读取, 需要读
取的大小是 128Byts. 又有 fileB, 想把上面读取到的 128Bytes 写到第 32 个字节开
始的位置, 替换 128Bytes, 实现如下
dd if=fileA of=fileB bs=1 count=128 skip=63 seek=31 conv=notrunc
备份:
dd if=/dev/sdx of=/dev/sdy
将本地的 / dev/sdx 整盘备份到 / dev/sdy
dd if=/dev/sdx of=/path/to/image
将 / dev/sdx 全盘数据备份到指定路径的 image 文件
dd if=/dev/sdx | gzip>/path/to/image.gz
备份 / dev/sdx 全盘数据, 并利用 gzip 压缩, 保存到指定路径
? 恢复:
dd if=/path/to/image of=/dev/sdx
将备份文件恢复到指定盘
gzip -dc /path/to/image.gz | dd of=/dev/sdx
将压缩的备份文件恢复到指定盘
拷贝内存资料到硬盘
dd if=/dev/mem of=/root/mem.bin bs=1024
将内存里的数据拷贝到 root 目录下的 mem.bin 文件
? 从光盘拷贝 iso 镜像
dd if=/dev/cdrom of=/root/cd.iso
拷贝光盘数据到 root 文件夹下, 并保存为 cd.iso 文件
? 销毁磁盘数据
dd if=/dev/urandom of=/dev/sda1
利用随机的数据填充硬盘, 在某些必要的场合可以用来销毁数据, 执行此操作
以后,/dev/sda1 将无法挂载, 创建和拷贝操作无法执行
得到最恰当的 block size
- dd if=/dev/zero of=/root/1Gb.file bs=1024 count=1000000
- dd if=/dev/zero of=/root/1Gb.file bs=2048 count=500000
- dd if=/dev/zero of=/root/1Gb.file bs=4096 count=250000
通过比较 dd 指令输出中命令的执行时间, 即可确定系统最佳的 block size 大小
测试硬盘写速度
dd if=/dev/zero of=/root/1Gb.file bs=1024 count=1000000
测试硬盘读速度
dd if=/root/1Gb.file bs=64k | dd of=/dev/null
pv 管理工具
显示 pv 信息
pvs: 简要 pv 信息显示
pvdisplay
创建 pv
pvcreate /dev/DEVICE
删除 pv
pvremove /dev/DEVICE
vg 管理工具
显示卷组
vgs
vgdisplay
创建卷组
vgcreate [-s #[kKmMgGtTpPeE]] VolumeGroupName
管理卷组
- vgextend VolumeGroupName PhysicalDevicePath [PhysicalDevicePath...]
- vgreduce VolumeGroupName PhysicalDevicePath [PhysicalDevicePath...]
删除卷组
先做 pvmove, 再做 vgremove
lv 管理工具:
显示逻辑卷
lvs
Lvdisplay
创建逻辑卷
- lvcreate -L #[mMgGtT] -n NAME VolumeGroup
- lvcreate -l 60%VG -n mylv testvg
- lvcreate -l 100%FREE -n yourlv testvg
删除逻辑卷
lvremove /dev/VG_NAME/LV_NAME
重设文件系统大小
- fsadm [options] resize device [new_size[BKMGTEP]]
- resize2fs [-f] [-F] [-M] [-P] [-p] device [new_size]
- xfs_growfs /mountpoint
扩展和缩减逻辑卷
扩展逻辑卷:
- lvextend -L [+]#[mMgGtT] /dev/VG_NAME/LV_NAME
- resize2fs /dev/VG_NAME/LV_NAME
- lvresize -r -l +100%FREE /dev/VG_NAME/LV_NAME
缩减逻辑卷:
- umount /dev/VG_NAME/LV_NAME
- e2fsck -f /dev/VG_NAME/LV_NAME
- resize2fs /dev/VG_NAME/LV_NAME #[mMgGtT]
- lvreduce -L [-]#[mMgGtT] /dev/VG_NAME/LV_NAME
- mount
逻辑卷底层可以是硬盘 也可以是分区
创建逻辑卷前要更改 id 把 id 改成 8e
来源: http://www.bubuko.com/infodetail-3081894.html