linux-命令

、free -mh # 查看内存总大小等信息

、ls  # 查看一个目录中的所有文件,就是list的缩写

、ls -Z  # 参数大写的Z就是用来查看标签

、ls -l  # 将当前目录下的所有文件列出,详细的信息包括权限,用户组、创建时间、名称,可以缩写就是ll

、ls -l /temp  # 列出根目录下的temp文件夹下的文件列表,也可以缩写 ll -d

、ls -ld /temp  # 查看目录的信息

、ls --help   # 查看帮助,所有的指令后面跟 --help 会提示帮助,help不能缩写

、ls -al  # 查看隐藏文件和隐藏目录,就是目录或文件前面带 . 的

、ls -R  # 递归方式,显示所有包含所有子目录的内容

、ll -d /bin  # 查看目录的特性,详细信息

、usernod -L user  # 锁定指定用户,user就是用户名

、clear  # 清空屏幕

、ssh root@IP(hostname)  # ssh登录其他主机,ssh + 用户名 + @ + IP地址或者主机名

、mkdir back_$(date +%Y:%m:%d)  # 创建备份目录,使用当前时间,就是命令嵌套命令

、passwd  # 修改密码

、passwd user # 修改指定用户的密码,执行指令必须是root用户

、passwd -l user  # 锁定指定用户无法登录,执行指令必须是root用户

、passwd -u user # 解锁指定用户,执行指令必须是root用户

、data  # 显示时间。参数前必须用+号 (date +%Y:%m:%d)

date –s '1987-05-02 10:10:10'  # 修改时间

、file   #显示文件类型, 后面跟文件名/目录(目录也是一种特殊的文件),可以查看文件的属性,是文件还是文件夹(directory),还是块设备(block),格式

、cat # 查看 一个或多个文件的内容,开可以将内容重定向到新文件

、cat  filename  # 查看文件的内容

、cat filename > newfilename  # 将filename中的内容注入到newfilename中

、less  filename #  查看文件内容,显示第一页的内容,每次显示一页,用上下键翻页查看

、more filename  # 查看文件内容,从最后一页显示,不支持上下键

、cat << EOF >> test.txt  # 在terminal中输入内容注入到test.txt中,EOF就是结束字符,快速写脚本

、head  filename  #  查看文件前10行内容

、head -n 5 filename # 查看文件前5行内容

、tail filename  # 查看文件最后10行内容

、tail -n 5 # 查看最后5行内容

、tail -f  # 刷新一个文件,不停的刷新,一般用来看日志有没有刷新

、head -n 58 filename | tail  -n 16 # 显示文件内容,43-58行的内容

、wc  # wc命令是用来统计的

、wc filename  # 统计文件中有多少行,多少单词,多少个字符

、wc -l  filename  #  统计文件中有多少行数

、wc -w  filename  # 统计文件中单词书

、wc -c filename  # 统计文件中字符数

、history   # 查看输入命令的历史记录,然后每条命令都会有数字排序,如果需要重新输入其中的某一条,输入!+序号   PS:ctrl + r 输入命令的关键字回车,直接查询

、pwd  # 查看当前所在的路径

、cp /etc/test.txt .  # 将绝对路径下的文件拷贝到当前目录后面一个 . ,拷贝到上级目录就是 ..,拷贝到上级目录的上级目录就是 ../..

、cp -p filename new_filename  # 维持当前权限拷贝复制文件

、cp -r dirname new_dirname  # 递归拷贝目录,会将目下的所有子目录一起拷贝

、cp -rp dirname new_dirname  # 维持当前权限递归拷贝目录

、cp -a dirname new_dirname  # 和-rp一样

、cp -rv dirname new_dirname  # 可以看到拷贝的过程

、cp file new-file   # 拷贝一个文件内容到新的文件

、alias  # 查看系统中指令的别名

、for i  in {1..100};do echo line$i >>test.txt  # 使用for循环向文件中注入100行内容

、touch filename  # 创建空文件,如果文件存在则更新时间戳

、stat filename   # 查看文件的时间戳

、mkdir name  # 创建文件夹

、mkdir -p 123/456/789  # 递归创建目录,直接创建多层的目录,必须要有-p参数,-p就是创建子目录

、mv file new-file  # 剪切文件

、mv file /test  # 移动文件到指定目录

、mv filename new_filename  # 修改文件的名字

、mv dirname new_dirname  # 修改文件夹的名字

、rm filename  # 删除文件

、rm -rf dirname  # 强制删除目录,不用确认,直接递归全部删除

、rm -r directory  # 删除目录,-r就是递归,递归用来删除目录,每删除一层会提示确认,也可以删除空目录

、rmdir directory  # 删除空目录

、ln haha.txt heihei.txt  # 硬链接,硬链接不可以链接到目录,只能链接文件

、ln -s haha.txt heihei.txt  # 软连接,软连接可以连接到目录和文件

、man ls , / -i    #查询命令帮助,打开后使用/ 进行关键字搜索,n继续搜索, shift + n 向上翻

、man  5 filename  #查询文件帮助,文件必须指定5,5就是针对文件格式的

、man passwd  # 出现的内容是passwd(1),就是查询的是命令相关的帮助

、man -k passwd  #关键字查询,小范围查询,查询成功系统就会列出所有可以查询包含passwd的信息

、man -K drop  #  在man的所有文件中查询关键字  当-k查询不到的时候可以尝试-K,如果没有则输入q回车继续下一个文件打开,查看man帮助敲回车,如果没有继续q退出,ctrl+d下一个文件

、man  5  passwd   # 指定查看命令的文件

、rpm -q httpd  # 查询这个软件包是否安装

、rpm -qi httpd  # 查询这个软件包的摘要信息

、rpm -qd  httpd  # q就是查询 d就是指文档,查询这个软件包中所有文档

、rpm -ql  httpd   # 列出这个软件包中所有的文件安装路径,系统会列出这个软件下所有的文件,包括man帮助

、rpm -qc httpd   # 列出这个软件包的所有配置文件路径

、rpm -q --scripts httpd  # 显示软件包的脚本,查看脚本执行哪些操作

、rpm -q --changelog httpd   #  显示软件包每次制作添加的功能

、find / etc/ -name *.conf  1>ok.txt 2>err.txt   # 查找etc目录下所有文件后缀为err.txt的文件,正确的放入ok.txt文件中,错误的放入err.txt文件中

、find /etc/ -name *.conf  2>/dev/null  # 只在屏幕上输出正确的,错误的放入黑洞文件null

、find /etc/ -name *.conf 1>/dev/null  # 只在屏幕上输出错误的信息,正确的放入黑洞文件null

、find /etc/ -name *.conf 1>/dev/null 2>>err.txt  # 两个>>就是追加的意思

、find /etc/ -name *.conf &>/dev/null  # & 表示正确和错误都放入相同的文件中

、cat httpd.conf | grep ^#  #读取httpd.conf文件的内容交给右边的grep(筛选)出所有#开头的内容

、cat httpd.conf | grep  -v ^#  #读取httpd.conf文件的内容交给右边的grep(筛选)出所有不是#开头的内容,v就是反向筛选

、cat httpd.conf | grep -v ^# | grep -v ^$  #读取httpd.conf文件的内容交给右边的grep(筛选)出所有不是#开头内容,然后交给后面的命令继续筛选出非空行的内容

、cat httpd.conf | grep -v ^# | grep -v ^$  | grep -v ^"    #" # 读取httpd.conf文件的内容交给右边的grep(筛选)出所有不是#开头内容,然后交给后面的命令继续筛选出非空行的内容,再讲结果继续过滤出空格和#号的内容(需要过滤的空格有几个,就在命令的" "内输入几个空格和字符)

、ls -l /etc | wc -l  # 计算一个目录下有多少个文件,有多少行就是有多少个

、id   # id命令加上用户名,就可以查看当前账户的UID,所属的用户组,如果id不跟参数就是查看root用户

、ps -a  # 显示当前terminal的进程信息

、ps -u root # 显示指定用户信息

、ps  -aux   # 查看所有进程的信息

、ps -ef   # 查看所有进程信息,能够看到进程的父进程是谁,PPID就是父进程

、su  # 切换用户,su - admin ,中间的 - 号就是将自己的环境变量加载,不加 - 号就会使用当前账户的环境变量

、sudo passwd admin  # 修改admin的密码

、sudo -i  # 切换成root用户

、chattr +i filename  # 给文件添加特殊标记后root用户无法删除

、chattr -i filename  # 将特殊标记去除

、useradd -u username  # 创建用户,默认创建同名用户组

、useradd -u username -g groupname  # 创建用户,但是不会创建同名的用户组,会加入指定的用户组

、useradd -u username -G groupname  # 创建用户,默认创建同名用户组,会作为附属组加入指定的用户组

、useradd admin -s /sbin/nologin  # 新建用户但是无法使用此账户登录

、useradd admin  -u 3456   # 设定用户的UID号

、userdel admin  # 删除用户,但是没有删除家目录

、userdel -r admin  # 删除用户包括家目录,-r就是递归的意思

、usermod -s /sbin/nologin admin  # 禁止用户登录

、usermod admin -s /bin/bash  # 让用户可以登录

、usermod admin -G wheel  # 将一个用户加入wheel组

、passwd admin # 设置密码,普通用户只能修改自己的密码,root用户可以修改所有用户的密码

、groupadd groupname  # 创建组

、groupdel groupname  # 删除组

、chage -l admin   # 查看账户的密码信息,包括修改时间,生命周期

、chage  admin # 设置账户密码的生命周期等,系统会进行引导设置,可用-h查看后单独设置

、sudo usermod -L admin   # 锁住admin用户

、sudo usermod -U admin   # 解锁admin用户

、usermod -s /sbin/nologin admin   #账号作为系统服务账号,但是并不能登录操作系统

、chmod  u+x  filename.txt     # 设置文件所属用户的权限

、chmod  u- rwx filename.txt   #  去除文件所属用户的权限

、chmod  -R ugo+x  dirname   #  目录设定权限,R是递归携带这个参数就是目录下所有的文件和目录都改变权限

、chmod  -R o+X  dirname   #  目录设定权限,R是递归携带这个参数就是目录下所有的文件都改变权限,权限变成大写后就是只对目录改变权限,并不会对文件改变权限

、chown  admin:admin filename.txt   # 设定文件所属用户和组

、chown  admin filename.txt   # 设定文件所属用户

、chown  :admin filename.txt   # 设定文件所属组

、env  # 查看系统环境变量

、alias  # 查看命令的别名

、alias test="ps axo pid,ppid,comn"  # 设置命令别名,有时候命令太长但是使用率高,设置别名有利于记忆和使用

、ps axo pid,ppid,comn  # 查看和命令相关的进程号

、ps axo pid,ppid,comn,psr | grep httpd  # 查看相关程序的进程关系,可以直接看到最顶端的父进程

、usermod -s /sbin/nologin admin # 禁止用户登录

、pstree  # 查看进程树

、pidof 进程名  # 查看这个进程名字所有相关的进程

、kill -1 进程号  # 对这个进程重新加载配置文件

、kill -15 进程号  # 正常退出进程,先保存后退出

、kill -9 进程号  # 强制退出不保存

、kill all 进程名  # 杀死此进程名所有相关的进程

、top  # 查看系统的负载情况

、shift  p  # 在top下,根据cpu占用率进行排序

、shift  M  # 在top下,根据内存暂用率从大到小排序

、ls cpu  # 可以看到cpu的数量

、cat /proc/cpuinfo  # 从内核信息文件中查看cpu数量,这个最准确

、chmod u + s # 文件设置特殊权限suid,也可以使用十进制数设置,chmod 4775 filename

、chmod u - s  # 文件取消suid

、chmod g + s  # 文件 / 文件夹 设置特殊权限sgid,文件夹也可以使用十进制数设置,chmod 2775 dirname

、chmod g - s  # 文件 / 文件夹取消sgid

、chmod 0 + t  # 文件设置特殊权限sbit,使用十进制数设置,chmod 1777 dirname

、systemctl list-units  # 列出系统中所有的units

、systemctl list-units | grep ssh  # 列出系统中所有的units并且过滤出ssh服务,可以查看ssh是否启动

、systemctl  # 加载所有已经激活的服务,未激活运行的服务不会显示

、systemctl status  sshd  # 查看相关的服务运行状态

、systemctl enable / disable sshd  # 设置开机启动或不启动 

、systemctl mask / unmask sshd  # 服务开启遮罩或取消遮罩

、systemctl isolate graphical.target  # 进入图形化桌面

、systemctl isolate multiuser.targer  # 进入文字界面

、power off  / init 0 # 关机

、reboot / init 6 # 重启系统

、systemctl set-default multi-user.target graphical.target  # 开机默认进入图形化界面

、systemctl get-default  # 查询默认开机的界面方式

、systemd-analyze blame  # 查看开机所有服务启动所花费的时间

、systemctl list-dependencies sshd  # 查看程序服务依来关系图

、systemctl list-dependencies sshd --reverse  # 查看反向依赖关系图

 、cat /var/log/message |grep -i error  # 不区分大小写的过滤出所有error的日志信息

、journalctl  # 显示所有启动时候早期的日志,包括硬件初始化的日志

、journalctl -e  #查看数据库中最后的日志

、journalctl  -f  # 动态刷新日志

、journalctl  -p  err # 查看系统中error级别以上的日志,以红色表示

、journalctl  -u  sshd  # 查看相关服务的日志

、journalctl  -p  err -u  sshd # 日志筛选,结构化的查询

、timedatectl # 查看时区

、tzselect  # 选择时区的命令,输入后选择时区后回提示使用设定的时区进行设置

、timedatectl set-timezone Asia/Shanghai  # 设置时区

、chronyc sources -v # 查看ntp服务的配置,可以看到时间服务器的地址

、ip link  # 查看网卡信息,可以看到link链路层(二层)的信息

、ip address show  # 可以缩写ip a s ,查看网卡信息,可以看到三层的信息,MAC地址信息

、ip -s link show  # 可以查看网络性能,收发包的统计信息

、ip route  # 可以看到网关地址

、rout -n # 也可以看到网关地址,更详细,可以看到什么地址到达那个网关

、tracepath hostname  # 查看主机路由条数

、netstat -tunpla  # 查看所有连接的状况,参数中t表示tcp、u标书udp、n表示将已知端口用数字表示、p表示pid、l表示监听状态、a表示非监听状态下也表示

、nmcli device  show # 列出所有的名称

、nmcli connection show # 可以看到网卡信息,名称,UUID,类型

、nmcli connection reload “网卡名称” # 重新载入网卡配置

、ethtool 网卡名称  # 可以查看网卡接口的速率,是千兆还是百兆

、nmtui  # 可视化的网络配置界面

、nmcli conn show  # 列出所有连接

、nmcli conn show name  # 列出name连接的当前设置

、nmcli dev disconnect name(nmcli dev dis dev)  # 断开连接,这个是从硬件层面彻底的断开

、nmcli con up name  # 激活name连接

、nmcli dev status # 显示所有网络接口的Networkmanager状态

、nmcli con add con-name name  # 添加一个名为name的新连接

、nmcli con mod name # 修改name连接

、nmcli con reload  # 重新加载配置文件

、nmcli  con del name  # 删除name连接及其配置文件

、man nmcli-examples  # 查看man帮助

、hostnamectl # 查看主机的基本信息,包括架构,内核kernel版本等

、hostnamectl set-hostname  主机名 #  这个会默认修改/etc/hostname中的主机名

、nslookup 主机名  # 查看到DNS解析地址和DNS服务器地址

、du -sh /etc  # 查看指定目录大小

、dd if=/dev/zero of=1.img bs=1M count=1024  # 在dev/zero目录下创建一个1G的文件

、which 软件名  # 查看软件安装目录

、rmp -qa  # 列出系统中所有安装的软件包

、rpm -qc 软件名  #  查看所有的安装文件路径

、rpm -qd  # 查看所有的文档

、rpm -q --scripts 软件名  # 可以查看脚本,在安装前需要做什么

、rpm -q --changelog 软件名  # 可以查看更新日志

、rpm -qf 文件名# 可以查看文件来自于哪个软件包,只能查询已存在的文件

、rpm -qp --scripts  软件包名 # 可以查看安装前 执行的脚本

、rpm -qpl --scripts 软件包名 # 列出软件包中所有文件名

、rpm -qpc --scripts 软件包名 # 查看软件包的配置文件,如果有则可以看到

、rpm -ivh 软件包名 # 安装rpm软件包

、rpm -Uvh  # 升级软件包

、rpm -e 软件包名 # 升级软件

、yum list # 列出yum仓库中所有的软件

、yum search 软件包名 # 搜索指定软件包

、yum whatprovides 文件名 # 查看文件来自于哪个软件包,如果未安装软件也能查询,从yum数据库中查询

、yum repolist  # 列出所有的仓库

、yum claen all #清空所有yum缓存,yum仓库有索引缓存,配置新yum仓库后要清理缓存

、yum makecache # 生成yum缓存

、yum install -y 包名  # 安装软件包

、yum localinstall -y 包名  # 安装本地软件包,使用yum自动安装依赖关系

、yum update -y 包名 # 升级软件包

、yum update -y  # 升级所有软件包,也会升级操作系统

、yum remove -y 包名 # 卸载软件包,但是不会卸载依赖关系

、yum grouplist  #  列出包组

、yum groupinstall ''包组名'' # 安装包组,包组名可也以用@包组名,使用@代替 “ ”

、yum groupremove "包组名"  # 卸载包组

、yum history  # 查看敲过的yum 命令

、tail -n1 /etc/fstab  # 查看永久挂载配置信息

、dd if=/rhel8.iso of=/dev/sdd bs=4M  # 用u盘使用镜像做一个启动盘安装系统

、df -h # 查看磁盘空间情况,挂载情况,为增加可读性可以使用h或者H,h的单位是Kib、Mib。H的单位显示是KB\MB\GB

、lsblk # 查看磁盘空间情况、挂载情况等,使用树状结构显示

、lsblk -fp  #列出设备的完整路径,其UUID和挂载点

、du -h # 查看当前目录下文件的尺寸

、du -sh /etc # 查看目录的大小

、lsscsi # 列出主机中的硬盘

、lsscsi -v # 列出主机中的硬盘详细信息,参数v可以是vv也可以是vvv,没多一个v详细信息就更多

、mount UUID="7d739626-58b3-4e86-9e2a-b09e9af23502" /mnt/test  # 使用uuid挂载目录

、umount /test  # umount 后面可以跟设备名,也可以直接跟挂载的目录

、blkid # 查看文件系统的uuid、类型

、lsof /mnt/test  # 列出目录下访问连接,可以查看谁在打开文件或目录

、locate 文件名 #从mlocate数据库中查找指定的文件路径

、locate -i 文件名 #不区分大小写的查询

、locate -n 5 文件名 # 限制返回的结果数量,如5就是只显示前5条

、find /-size +1G # 搜多所有大于1G的文件

、find -size 10M # 查找所有等于10M的文件

、find -size -10M # 查找所有小于10M的文件

、find -mmin 120  # 查找所有过去120分钟被修改过的文件

、find -mmin +120  # 查找修改超过120分钟被修改过的文件

、find -mmin -120  # 查找修改未超过120分钟被修改过的文件

、find  /etc -type d  #  type选项后面跟d表示搜索范围限制为目录

、find  /etc -type f  #  type选项后面跟f表示搜索范围限制为文件

、find  /etc -type l  #  type选项后面跟l表示搜索范围限制为软连接

、find  /etc -type b  #  type选项后面跟b表示搜索范围限制为块设备

、find / -user 用户名 # 搜索根目录下(/),所有属于自定用户的文件

、find / -user 用户名 -exec cp -a {} /backup \;  # 搜索根目录下指定用户的所有文件,进行exec二次加工,-a就是带着权限和子目录一起拷贝,{}表示只带搜索到的所有文件,拷贝到指定的目录,\;表示关闭

、find / -name 文件名  # 查询根目录下指定文件的路径(/表示根目录,也可以指定目录查询),文件名可以使用正则 '*文件名*'

、find / -iname 文件名 # 对文件名不区分大小写的搜索,文件名也可以使用正则‘*文件名*’

、find / -user root -group mail 文件名 # 搜索用户是root并且所属组是mail的文件

、echo $PATH  # 查看系统环境变量的路径,echo命令可以显示任意文本内容

、which ls # 查看命令或者文件再那个路径下

、touch  test.txt  # 创建空文本

、test  # 用来测试脚本

、at now + 5min # 创建单次计划任务(5分钟之后)

、teatime tomorrow # 创建单次计划任务(下午16点)

、noon + 4days  # 创建单次计划任务(4天之后的中午12点)

、5pm august 3 2021 # 创建单次计划任务(2021年8月3日下午5点)

、at -l / atq # 列出当前所有的计划任务

、at -c number # 查看单次计划任务的详细信息 

、atrm 1  # 删除指定序号的单次计划任务

、crontab -l # 查看当前用户的周期性计划任务

、crontab -r # 删除当前用户的周期性计划任务

、crontab -e  # 就会打开一个文本开始编辑开始定义周期性计划任务

、crontab -eu 用户名  # root账户为普通用户定义计划任务

、0 6 * * * systemctl restart httpd  # 0分6小时 每天每月每周的每天,就是每天早上6点重启apache

、30 6 * * * systemctl restart httpd  # 就是每天早上6点30重启apache

、30 6 15,30 * * systemctl restart httpd # 每个月15号和30号早上6点半重启apache服务

、30 6 */10 * * systemctl restart httpd # 每隔十天重启一次服务

、30 6 1 1 * systemctl restart httpd # 每年的1月1号重启服务

、30 6 * * 7 systemctl restart httpd # 每个周日重启服务,星期中日可以用7、0、sun表示

、30 6 1 * 7 systemctl restart httpd  # 逢周日或每月第一天早上6点30重启服务

、30 6 * * 1-5 systemctl restart httpd # 每周1-5重启服务

、0,30 * * * * echo 3 > /proc/sys/vm/drop_caches  # 每隔半小时清空系统缓存

、* 9-17/2 * * * echo 3 > /proc/sys/vm/drop_caches  # 工作日的每天9-17点,隔两小时清空一次缓存

、systemctld daemon-reload # 重新加载配置文件

、ps axo pid,comm,nice,cls --sort=-nice  # 查看nice值等信息,cls就是调度策略,TS针对的就是SHCED_NORMAL

、getfacl filename  # 查看文件的acl信息

、getfacl 目录名 # 查看目录的ACL

、getfacl .  # 命令后面跟 . 就是查看当前目录的ACL

、setfacl -m u:root:---- test.txt  # 给文件设置ACL

、setfacl -Rm d:u:name:rwX # 设置目录的默认ACL

、setfacl -Rm u:name:rwX 目录名  # 设置目录的ACL

setfacl a.txt | setfacl --set-file=- b.txt  # 通过查看A文件的ACL然后设置到B文件

、getenforce  # 查看SELinux当前状态(模式)

、setenforce 1 # 设置SELinux 的模式为Enforcing 强制模式

、setenforce 0 # 设置SELinux 的模式为Permissive 宽容模式

、blkid  # 查看磁盘的信息,包括uuid,类型等

、yum whatprovides 命令 # 查找命令来自于那个软件包

、set nu  # 在vim编辑时候可以显示行数

posted @ 2019-11-03 21:52  clyde_S  阅读(290)  评论(0编辑  收藏  举报