文件的权限 - 使用 "+" 设置权限,使用 "-" 用于取消
- ls -lh 显示权限
- ls /tmp | pr -T5 -W$COLUMNS 将终端划分成5栏显示
- chmod ugo+rwx directory1 设置目录的所有人(u)、群组(g)以及其他人(o)以读(r )、写(w)和执行(x)的权限
- chmod go-rwx directory1 删除群组(g)与其他人(o)对目录的读写执行权限
- chown user1 file1 改变一个文件的所有人属性
- chown -R user1 directory1 改变一个目录的所有人属性并同时改变改目录下所有文件的属性
- chgrp group1 file1 改变文件的群组
- chown user1:group1 file1 改变一个文件的所有人和群组属性
- find / -perm -u+s 罗列一个系统中所有使用了SUID控制的文件
- chmod u+s /bin/file1 设置一个二进制文件的 SUID 位 - 运行该文件的用户也被赋予和所有者同样的权限
- chmod u-s /bin/file1 禁用一个二进制文件的 SUID位
- chmod g+s /home/public 设置一个目录的SGID 位 - 类似SUID ,不过这是针对目录的
- chmod g-s /home/public 禁用一个目录的 SGID 位
- chmod o+t /home/public 设置一个文件的 STIKY 位 - 只允许合法所有人删除文件
- chmod o-t /home/public 禁用一个目录的 STIKY 位
文件的特殊属性 - 使用 "+" 设置权限,使用 "-" 用于取消
- chattr +a file1 只允许以追加方式读写文件
- chattr +c file1 允许这个文件能被内核自动压缩/解压
- chattr +d file1 在进行文件系统备份时,dump程序将忽略这个文件
- chattr +i file1 设置成不可变的文件,不能被删除、修改、重命名或者链接
- chattr +s file1 允许一个文件被安全地删除
- chattr +S file1 一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘
- lsattr 显示特殊的属性
RPM 包 - (Fedora, Redhat及类似系统)
- rpm -ivh package.rpm 安装一个rpm包
- rpm -ivh --nodeeps package.rpm 安装一个rpm包而忽略依赖关系警告
- rpm -U package.rpm 更新一个rpm包但不改变其配置文件
- rpm -F package.rpm 更新一个确定已经安装的rpm包
- rpm -e package_name.rpm 删除一个rpm包
- rpm -qa 显示系统中所有已经安装的rpm包
- rpm -qa | grep httpd 显示所有名称中包含 "httpd" 字样的rpm包
- rpm -qi package_name 获取一个已安装包的特殊信息
- rpm -qg "System Environment/Daemons" 显示一个组件的rpm包
- rpm -ql package_name 显示一个已经安装的rpm包提供的文件列表
- rpm -qc package_name 显示一个已经安装的rpm包提供的配置文件列表
- rpm -q package_name --whatrequires 显示与一个rpm包存在依赖关系的列表
- rpm -q package_name --whatprovides 显示一个rpm包所占的体积
- rpm -q package_name --scripts 显示在安装/删除期间所执行的脚本l
- rpm -q package_name --changelog 显示一个rpm包的修改历史
- rpm -qf /etc/httpd/conf/httpd.conf 确认所给的文件由哪个rpm包所提供
- rpm -qp package.rpm -l 显示由一个尚未安装的rpm包提供的文件列表
- rpm --import /media/cdrom/RPM-GPG-KEY 导入公钥数字证书
- rpm --checksig package.rpm 确认一个rpm包的完整性
- rpm -qa gpg-pubkey 确认已安装的所有rpm包的完整性
- rpm -V package_name 检查文件尺寸、 许可、类型、所有者、群组、MD5检查以及最后修改时间
- rpm -Va 检查系统中所有已安装的rpm包- 小心使用
- rpm -Vp package.rpm 确认一个rpm包还未安装
- rpm2cpio package.rpm | cpio --extract --make-directories bin 从一个rpm包运行可执行文件
- rpm -ivh /usr/src/redhat/RPMS/
arch
/package.rpm 从一个rpm源码安装一个构建好的包
- rpmbuild --rebuild package_name.src.rpm 从一个rpm源码构建一个 rpm 包
YUM 软件包升级器 - (Fedora, RedHat及类似系统)
- yum install package_name 下载并安装一个rpm包
- yum localinstall package_name.rpm 将安装一个rpm包,使用你自己的软件仓库为你解决所有依赖关系
- yum update package_name.rpm 更新当前系统中所有安装的rpm包
- yum update package_name 更新一个rpm包
- yum remove package_name 删除一个rpm包
- yum list 列出当前系统中安装的所有包
- yum search package_name 在rpm仓库中搜寻软件包
- yum clean packages 清理rpm缓存删除下载的包
- yum clean headers 删除所有头文件
- yum clean all 删除所有缓存的包和头文件
APT 软件工具 (Debian, Ubuntu 以及类似系统)
- apt-get install package_name 安装/更新一个 deb 包
- apt-cdrom install package_name 从光盘安装/更新一个 deb 包
- apt-get update 升级列表中的软件包
- apt-get upgrade 升级所有已安装的软件
- apt-get remove package_name 从系统删除一个deb包
- apt-get check 确认依赖的软件仓库正确
- apt-get clean 从下载的软件包中清理缓存
- apt-cache search searched-package 返回包含所要搜索字符串的软件包名称
DEB 包 (Debian, Ubuntu 以及类似系统)
- dpkg -i package.deb 安装/更新一个 deb 包
- dpkg -r package_name 从系统删除一个 deb 包
- dpkg -l 显示系统中所有已经安装的 deb 包
- dpkg -l | grep httpd 显示所有名称中包含 "httpd" 字样的deb包
- dpkg -s package_name 获得已经安装在系统中一个特殊包的信息
- dpkg -L package_name 显示系统中已经安装的一个deb包所提供的文件列表
- dpkg --contents package.deb 显示尚未安装的一个包所提供的文件列表
- dpkg -S /bin/ping 确认所给的文件由哪个deb包提供