专栏首页洁癖是一只狗Linux常用命令(三)

Linux常用命令(三)

RPM 包(适用于CentOS、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 显示在安装/删除期间所执行的脚本

rpm -q package_name --changelog 显示一个rpm包的修改历史

rpm -qf /usr/bin/ls 确认所给的文件由哪个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 软件包升级器(适用于CentOS、Redhat 等类似系统)

yum 与rpm 不同的是, yum 在安装软件包的过程中可以解决包的依赖关系

与查询有关的yum命令:

yum info package_name 显示安装包的详细信息

yum list 显示所有已经安装和可以安装的程序包

yum list package_name 显示指定程序包的安装情况

yum search <keyword> 在rpm仓库中搜寻软件包

yum check-update 列出系统中所有可更新的软件清单

与安装/卸载有关的yum命令:

yum update 升级系统中所有包同时也升级软件和系统内核

yum upgrade 只升级系统中所有包,不升级软件和系统内核

yum install package_name 仅安装指定的软件

yum update package_name 仅更新指定的软件

yum remove package_name 仅删除指定的软件

与有清除缓存有关的yum命令:

yum clean package1 清除缓存目录下的软件包

yum clean headers 清除缓存目录下的头文件

yum clean all 清除缓存目录下的软件包及旧的头文件

用户和群组 groupadd group_name 创建一个新用户组

groupdel group_name 删除一个用户组

groupmod -n new_group_name old_group_name 重命名一个用户组

id user1 显示用户的ID,以及所属群组的ID

useradd user1 创建一个新用户

useradd -c "For test use" -g admin -d /home/user1 -s /bin/bash user1 新建一个属于 "admin" 用户组的用户(为测试使用), 家目录为/home/user1,登录的shll 为bash

userdel -r user1 删除一个用户并删除其家目录

usermod -c "For test use" -g newtestgroup user1 修改用户属性, 修改用户user1 的所属组为newtestgroup

passwd 修改当前用户的密码

passwd user1 修改一个用户的密码 (只允许root执行)

非root用户执行此操作会报错

change -l user1 显示用户账户和密码的有效期限。

chage -E 2019-12-31 user1 设置用户密码的过期时间(从永不过期改成user1 的密码到2019-12-31日过期)

pwck 检查用户密码文件“/etc/passwd”和“/etc/shadow”的完整性,将验证结果送到标砖输出。提示用户删除格式不正确或有其他不可更正错误的条目。检查以验证每个条目是否具有:正确的字段数、唯一有效的用户名、有效的用户和组标识符、有效的主组、有效的家目录、有效的登录shell。

grpck 检查/etc/group文件和/etc/gshadow文件,检查数据是否正确存放,每条记录是否都包含足够的信息,是否有一个唯一的组名,是否包含正确的用户,是否正确设置了组的管理员等。

newgrp group_name 登陆进一个新的群组以改变新创建文件的预设群组(适用于一个用户有两个及两个以上群组的情况)

文件的权限 - 使用 "+" 设置权限,使用 "-" 用于取消

ls /tmp | pr -T5 -W$COLUMNS 将终端划分成5栏显示

chmod ugo+rwx dir1 设置目录的所属者(u)、所属组(g)以及其他人(o)有读(r )、写(w)和执行(x)的权限。 此命令等价于chmod a+rwx dir1 和 chmod 777 dir1。

chmod go-rwx dir1 删除群组(g)与其他人(o)对目录的读写执行权限

chown user1 file1 改变一个文件的所有者

chown -R user1 dir1 改变一个目录的所有者属性并同时改变改目录下所有文件的属性

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 位

chmod g-s /home/public 禁用一个目录的 SGID 位

chmod o+t /home/public 设置一个文件的 STIKY 位

chmod o-t /home/public 禁用一个目录的 STIKY 位

补充: 对特殊权限SUID、SGID以及STIKY 位权限说明:

二进制文件

目录

SUID

此用户将继承此程序的所有者权限

无意义

SGID

此用户将继承此程序的所有组权限

此目录下所有用户新建文件都自动继承此目录的用户组

Sticky

无意义

目录中每个用户只能仅能删除、移动或重命名自己的文件或目录(防误删)

文件的特殊属性 — 使用 "+" 设置权限,使用 "-" 用于取消

通过chattr命令修改属性能够提高系统的安全性,但是它并不适合所有的目录。chattr命令不能保护/、/dev、/tmp、/var目录。lsattr命令是显示chattr命令设置的文件属性。这两个命令是用来查看和改变文件、目录属性的,与chmod这个命令相比,chmod只是改变文件的读写、执行权限,更底层的属性控制是由chattr来改变的。

chattr +a file1 只允许以追加方式读写文件

chattr +c file1 允许这个文件能被内核自动压缩/解压

chattr +d file1 在进行文件系统备份时,dump程序将忽略这个文件

chattr +i file1 设置成不可变的文件,不能被删除、修改、重命名或者链接

chattr +s file1 允许一个文件被安全地删除

chattr +S file1 一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘

chattr +u file1 若文件被删除,系统会允许你在以后恢复这个被删除的文件

lsattr 显示特殊的属性

打包和压缩文件

bunzip2 file1.bz2 解压一个叫做 'file1.bz2'的文件

bzip2 file1 压缩一个叫做 'file1' 的文件

gunzip file1.gz 解压一个叫做 'file1.gz'的文件

gzip file1 压缩一个叫做 'file1'的文件

gzip -9 file1 最大程度压缩

rar a file1.rar test_file 创建一个叫做 'file1.rar' 的包

rar a file1.rar file1 file2 dir1 同时压缩 'file1', 'file2' 以及目录 'dir1'

rar x file1.rar 解压rar包

unrar x file1.rar 解压rar包

tar -cvf archive.tar file1 创建一个非压缩的 tarball

tar -cvf archive.tar file1 file2 dir1 创建一个包含了 'file1', 'file2' 以及 'dir1'的tar 包

tar -tf archive.tar 显示一个tar包中的内容

tar -xvf archive.tar 释放一个tar包

tar -xvf archive.tar -C /tmp 将压缩包释放到 /tmp目录下

tar -cjvf archive.tar.bz2 dir1 创建一个bzip2格式的压缩包

tar -xjvf archive.tar.bz2 解压一个bzip2格式的压缩包

tar -czvf archive.tar.gz dir1 创建一个gzip格式的压缩包

tar -xzvf archive.tar.gz 解压一个gzip格式的压缩包

zip file1.zip file1 创建一个zip格式的压缩包

zip -r file1.zip file1 file2 dir1 将几个文件和目录同时压缩成一个zip格式的压缩包

unzip file1.zip 解压一个zip格式压缩包

磁盘空间

df -hT 显示已经挂载的分区列表和文件系统使用的空间情况

ls -lSr |more 以尺寸大小排列文件和目录 (从小到大排序)

ls -lS |more 以尺寸大小排列文件和目录 (从大到小排序)

du -sh * | sort -nr | head -n 10 以容量大小为依据依次显示文件和目录的大小(从大到小排序)

du -sk * | sort -rn 以容量大小(统一单位为KB)为依据依次显示文件和目录的大小(从大到小排序,单位为KB)

du -sm * | sort -n 以容量大小(统一单位为MB)为依据依次显示文件和目录的大小(从小到大排序,单位为MB)

du -sh awx 估算目录 'awx' 已经使用的磁盘空间'

挂载一个文件系统

mount /dev/sd2 /mnt/sda2 挂载一个叫做sda2的盘,挂载前要确定挂载点'/ mnt/sda2'已经存在

umount /dev/sda2 卸载一个叫做sda2的盘 (要先从挂载点'/ mnt/sda2'退出)

fuser -km /mnt/sda2 当设备繁忙时强制卸载

umount -n /mnt/sda2 运行卸载操作而不写入 /etc/mtab 文件 ,当文件为只读或当磁盘写满时非常有用

mount /dev/fd0 /mnt/floppy 挂载一个软盘

mount /dev/cdrom /mnt/cdrom 挂载一个cdrom或dvdrom

mount /dev/hdc /mnt/cdrecorder 挂载一个cdrw或dvdrom

mount /dev/hdb /mnt/cdrecorder 挂载一个cdrw或dvdrom

mount -o loop file.iso /mnt/cdrom 挂载一个文件或ISO镜像文件

mount -t vfat /dev/hda5 /mnt/hda5 挂载一个Windows FAT32文件系统

mount /dev/sda1 /mnt/usbdisk 挂载一个usb 捷盘或闪存设备

mount -t nfs 172.16.30.56:/testnfs /testnfs_client 挂载一个NFS 网络文件共享

mount -t cifs -o username=user,password=pass //WinClient/share /mnt/share 挂载一个windows网络共享

本文分享自微信公众号 - 洁癖是一只狗(rookie-dog),作者:小土豆

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-08-18

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 面试Mybatis之基本操作(collection和association)

    我们把级联关系基本操作都已经演示完毕,为了让大家更加深刻,我们在再介绍一下基本的概念。

    小土豆Yuki
  • Mysql为什么会抖一下呢

    在之前我们说过酒店记账的故事,其中酒店掌柜记账的的黑板就类似我们的redo log,而掌柜的记账本就是数据文件,掌柜的记忆就是内存。

    小土豆Yuki
  • Docker Swarm介绍及搭建集群

    一 前言 相信Docker 技术大家都有所了解, 单个Docker 能发挥的作用毕竟有限,也不便于管理,所以Docker要组集群来使用才能发挥强大的技术优势。既...

    小土豆Yuki
  • Linux安装软件方法总结

    相比于windows系统,Linux安装程序就比较复杂了,很多需要root用户才能安装。常见的有以下几种安装方法

    震八方紫面昆仑侠
  • 利用事件委托弥补观察者模式不足

    前两篇我们自己首先实现了一个观察者模式,我们再利用Java自带的接口和类实现了观察者模式,但其实两种观察者模式存在不足的地方。之前两种观察者模式的观察者(订阅者...

    用户1148394
  • python之抓取微信公众号文章系列2

    微信公众号历史的所有文章(来源???) 每篇文章的阅读量和点赞量(电脑上浏览文章只显示内容,没有阅读量、点赞量、评论……)

    周小董
  • Postgresql 监控你说了不算,谁说了算(3 pgwatch)

    之前几期的监控肯能有人不大认同,你这一个是特殊时期分析问题的,一个是分析日志的,我要的是正常人用的那种监控,正常人的那种

    AustinDatabases
  • 算法-重建二叉树

    题目: 输入某二叉树的前序遍历与中序遍历结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果均无重复数字,前序遍历序列为{},中序遍历序列为{},则重...

    chaibubble
  • 3分钟极简掌握matplotlib绘图原理

    matplotlib是基于Python语言的开源项目,旨在为Python提供一个数据绘图包。我将在这篇文章中介绍matplotlib API的核心对象,并介绍如...

    double
  • Kafka基础知识索引

    从 0.9 版本开始,Kafka 的标语已经从“一个高吞吐量,分布式的消息系统”改为”一个分布式流平台“。

    用户6070864

扫码关注云+社区

领取腾讯云代金券