首页 > 其他分享 >liunx命令大全

liunx命令大全

时间:2025-01-07 12:01:39浏览次数:3  
标签:文件 file1 查看 file2 命令 liunx txt 目录 大全

一、文件和命令

  1. cd 命令:(它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径)

cd /home 进入’/home’目录

cd .. 返回上一级

Cd .. /.. 返回上两级目录

Cd / 返回跟目录

Cd - 返回上次所在的目录

Mkdir <目录名> 创建目录

Mkdir dir1 dir2 同时创建两个目录

Mkdir -p /tmp/dir1/dir2 递归创建目录树

Mkdir -f filel 删除’dir1’文件

Rmdir dir1 删除’dir1’目录

rm -rf dir1 删除’dir1’目录和其内容

-rm -rf dir1 dir2同时删除两个目录及其内容

  1. Pwd:pwd 显示工作路径

  1. ls命令

ls 查看目录的文件

Ls -l 显示文件和目录的详细资料

Ls -a 列出全部文件,包含隐藏文件

Ls -lh 查看文件和目录的详情列表 (增强文件大小易读性)

Ls -lsr 查看文件和目录列表(以文件大小升序查看)

Tree 查看文件和目录的树型结构 (如果没有需要先安装yum install tree)

Ls -r 连同子目录的内容一起列出(递归列出),等于该目录的所有文件都会显示出来

Ls -al /proc/pid/exe 通过pid查询程序正在运行的路径

  1. cp 命令:(用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下)

-a 将文件的特性一起复制

-p 连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份

-i 若目标文件已经存在时,在覆盖时会先询问操作的进行

-r 递归持续复制,用于目录的复制行为

-u 目标文件与源文件有差异时才会复制

 -cp dir/* . 复制某目录下的所有文件至当前目录

Cp -a dir1 dir2 复制目录

Cp -a /temp/dir1 . 复制一个目录至当前目录

Ln -s filel link1 创建指向文件/目录的软链接

Ln  filel lnkl 创建指向文件/目录的物理链接

Touch -t 0712250000 filel 修改一个文件或目录的时间戳-(YYMMDDhhmm)

  1. mv 命令

-f force 强制的意思 ,如果目标文件已经存在,不会询问而直接覆盖

-i 若目标文件已经存在,就会询问是否覆盖

-u 若目标文件已经存在,且比目标文件新,才会更新

Mv old_dir new_dir 重命名/移动目录

  1. rm 命令

-f :就是force的意思,忽略不存在的文件,不会出现警告消息

-i :互动模式,在删除前会询问用户是否操作

-r :递归删除,最常用于目录删除,它是一个非常危险的参数

  • 查看文件内容
  1. cat命令:(用于查看文本文件的内容,后接要查看的文件名,通常可用管道与 more 和 less 一起使用)

Cat filel 从第一个字节开始正向查看文件的内容

Cat -n filel 标示文件的行数

Cat xxx.txt awk‘NR%2==1’

Tac filel 从最后一行开始反向查看一个文件的内容

More filel 查看一个长文件的内容

Less filel 类似more命令,但允许方向操作

Head -n 2 filel 查看一个文件的前两行

Tail -f /log /msg 实时查看添加到文件中的内容

Tail -n 2 filel 查看一个文件的最后两行

Tail -n +1000 filel 从1000行开始显示,显示1000行以后的

Cat filename | head -n 3000 |tail -n +1000 显示1000行到3000行

Cat filename | tail -n +3000 | head -n 1000 从第3000行开始,显示1000(即显示3000~3999行)

Grep ss hello.txt 在文件hello.txt中查找关键词ss

grep ^s hello.txt 在⽂件hello.txt中查找以 s 开头的内容

grep [0-9] hello.txt 选择hello.txt⽂件中所有包含数字的⾏

sed 's/ss/mm/g' hello.txt 将hello.txt⽂件中的 ss 替换成 mm

sed '/^$/d' hello.txt 从hello.txt⽂件中删除所有空⽩⾏

sed '/ *#/d; /^$/d' hello.txt 从hello.txt⽂件中删除所有注释和空⽩⾏

sed -e '1d' hello.txt 从⽂件hello.txt 中排除第⼀⾏

sed -n '/s1/p' hello.txt 查看只包含关键词"s1"的⾏

sed -e 's/ *$//' hello.txt 删除每⼀⾏最后的空⽩字符

sed -e 's/s1//g' hello.txt 从⽂档中只删除词汇s1并保留剩余全部

sed -n '1,5p;5q' hello.txt 查看从第⼀⾏到第5⾏内容

sed -n '5p;5q' hello.txt 查看第5⾏

paste file1 file2 合并两个⽂件或两栏的内容

paste -d '+' file1 file2 合并两个⽂件或两栏的内容,中间⽤"+"区分

sort file1 file2 排序两个⽂件的内容

sort file1 file2 uniq

sort file1 file2 uniq -u

sort file1 file2 uniq -d

comm -1 file1 file2 ⽐较两个⽂件的内容(去除’file1’所含内容)

comm -2 file1 file2 ⽐较两个⽂件的内容(去除’file2’所含内容)

comm -3 file1 file2 ⽐较两个⽂件的内容(去除两⽂件共有部分)

三、文件搜索

8、find 命令

find / -name file 从根目录开始搜索文件/目录

find / -user user1 搜索用户 user1 的文件/目录

find /dir -name *.bin 在目录/dir 中搜索带有 .bin 后缀的文件

find / -name file1 从 ‘/’ 开始进入根文件系统搜索文件和目录(完整文件或文件名)

find / -user user1 搜索属于用户 ‘user1’ 的文件和目录

find /usr/bin -type f -atime +100 搜索在过去100天内未被使用过的执行文件

find /usr/bin -type f -mtime -10 搜索在10天内被创建或者修改过的文件

find . -regex '.*\(net\|comm\).*' ‘-regex’ 选项匹配整个路径名,出当前目录树中所有文件名中任意位置包含字符串 net 或 comm 的文件

locate *.mp4 寻找 .mp4结尾的文件

whereis <关键词> 显示某⼆进制⽂件/可执⾏⽂件的路径

whereis halt 显示一个二进制文件、源码或man的位置

which <关键词> 查找系统⽬录下某的⼆进制⽂件

which halt 显示一个二进制文件或可执行文件的完整路径

四、文件的权限 - 使用 “+” 设置权限,使用 “-” 用于取消

9、chmod 命令

    ls -lh 显示当前目录所有文件的权限

    chmod 777 文件名 修改文件权限(最高权限)

    chmod ugo+rwx dir 设置目录的所有人(u)、群组(g)以及其他人(o)以读(r,4 )、写(w,2)和执行(x,1)的权限

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

    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 位

    chmod +x 文件路径 为所有者、所属组和其他用户添加执行的权限

    chmod -x 文件路径 为所有者、所属组和其他用户删除执行的权限

    chmod u+x 文件路径 为所有者添加执行的权限

    chmod g+x 文件路径 为所属组添加执行的权限

    chmod o+x 文件路径 为其他用户添加执行的权限

    chmod ug+x 文件路径 为所有者、所属组添加执行的权限

    chmod =wx 文件路径 为所有者、所属组和其他用户添加写、执行的权限,取消读权限

    chmod ug=wx 文件路径 为所有者、所属组添加写、执行的权限,取消读权限

10、chown 命令

(改变文件的所有者)

chown user1 file1 改变一个文件的所有人属性

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

chown user1:group1 file1 改变一个文件的所有人和群组属性

11、chgrp 命令

(改变文件所属用户组)

chgrp group1 file1 改变文件的群组

五、文本处理

12、grep 命令

(分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等)

grep Aug /var/log/messages 在文件 '/var/log/messages’中查找关键词"Aug"

grep ^Aug /var/log/messages 在文件 '/var/log/messages’中查找以"Aug"开始的词汇

grep [0-9] /var/log/messages 选择 ‘/var/log/messages’ 文件中所有包含数字的行

grep Aug -R /var/log/* 在目录 ‘/var/log’ 及随后的目录中搜索字符串"Aug"

sed 's/stringa1/stringa2/g' example.txt 将example.txt文件中的 “string1” 替换成 “string2”

sed '/^$/d' example.txt 从example.txt文件中删除所有空白行

13、paste 命令

paste file1 file2 合并两个文件或两栏的内容(查看两文件合并后的内容)

paste -d '+' file1 file2 合并两个文件或两栏的内容,中间用"+"区分

14、sort 命令

sort file1 file2 排序两个文件的内容

sort file1 file2 | uniq 取出两个文件的并集(重复的行只保留一份)

sort file1 file2 | uniq -u 删除交集,留下其他的行

sort file1 file2 | uniq -d 取出两个文件的交集(只留下同时存在于两个文件中的文件)

15、comm 命令

comm -1 file1 file2 比较两个文件的内容只删除 ‘file1’ 所包含的内容

comm -2 file1 file2 比较两个文件的内容只删除 ‘file2’ 所包含的内容

comm -3 file1 file2 比较两个文件的内容只删除两个文件共有的部

六、打包和压缩文件

16、tar 命令

对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压)推荐

-c :新建打包文件

-t :查看打包文件的内容含有哪些文件名

-x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中

-j :通过bzip2的支持进行压缩/解压缩

-z :通过gzip的支持进行压缩/解压缩

-v :在压缩/解压缩过程中,将正在处理的文件名显示出来

-f filename :filename为要处理的文件

-C dir :指定压缩/解压缩的目录dir

压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称

查询:tar -jtv -f filename.tar.bz2

解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录

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包

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

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

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

 七、进程相关的命令

 用于将某个时间点的进程运行情况选取下来并输出,process之意

    -A :所有的进程均显示出来

    -a :不与terminal有关的所有进程

    -u :有效用户的相关进程

    -x :一般与a参数一起使用,可列出较完整的信息

    -l :较长,较详细地将PID的信息列出

ps -ef # 显示所有进程的详细信息。

ps aux # 查看系统所有的进程数据

ps ax # 查看不与terminal有关的所有进程

ps -lA # 查看系统所有的进程数据

ps axjf # 查看连同一部分进程树状态

pstree -aup # 查看正在运行的树桩结构显示

netstat -lntp # 查看各个节点及进程和使用的端口号

18、kill 命令

    kill -9 pid (-9表示强制关闭)

    kill -9 程序的名字

    kill -

    pkill 程序的名字

19、Vim 下复制粘贴等操作

    x,X : 在一行中,x为向后删除一个字符(相当于del键),X为向前删除一个字符(相当于backspace键)

    dd : 删除光标所在的那一整行

    ndd : n 为数字。从光标开始,删除向下n列

    yy : 复制光标所在的那一行

    nyy : n为数字。复制光标所在的向下n行

    p,P : p 为将已复制的数据粘贴到光标的下一行,P则为贴在光标的上一行

    u : 复原前一个操作

    CTRL + r : 重做上一个操作

    小数点 ‘.’:重复前一个动作

    :set number :在每一行设置行标号

    :n1,n2 m n3 移动n1-n2行(包括n1,n2)到n3行之下

    :n1,n2 co n3 复制n1-n2行(包括n1,n2)到n3行之下

    :n1,n2 d 删除n1-n2行(包括n1,n2)行

    

系统常用命令
关机、注销、重启

查看进程端口号:netstat -tunlp|grep 端口号

ss -tnl  查看正在已使用的端口

shutdown -h now 关闭系统(1) 即刻关机

shutdown -h 10 10分钟后关机

shutdown -h 11:00  11:00 关机

shutdown -h +10 预定时间关机(10分钟后关机)

shutdown -c  取消指定时间关机

shutdown -f now 重启

shutdown -r 10  10分钟后重启

shutdown -r 11:00   定时重启

reboot 重启

init 6 重启

init 0 即刻关机

telinit 0 关机

poweroff   立刻关机

halt 关机

sync  buff数据同步到磁盘

logout 退出登录Shell

time 测算一个命令(即程序)的执行时间

系统信息和性能查看

# 查看系统的详细信息

lsb_release -a

# 查看内核/OS/CPU信息

uname -a

# 查看内核版本

uname -r

# 查看处理器架构

uname -m

# 查看处理器架构

arch

# 查看主机名称

hostname

# 显示当前登录系统的用户

who

# 显示登陆时的用户名

who am i

# 显示当前用户名

whoami

# 查看 linux 版本信息

cat /proc/version

# 查看 CPU 信息

cat /proc/cpuinfo

# 查看中断

cat /proc/interrupts

# 查看系统负载

cat /proc/loadavg

# 查看系统运行时间、用户数、负载

uptime

# 查看系统的环境便令

env

# 查看系统PCI设备信息

lspci -tv

# 查看已加载的系统模块

lsmod

# 查看内存总量

grep MemTotal /proc/meminfo

# 查看空闲内存量

grep MemFree /proc/meminfo

# 查看内存用量和交换区用量

free -m

# 显示系统时间

date

# 显示2021日历表

cal 2021

# 动态显示cpu/内存/进程情况

top

# 每1秒采一次系统状态,采20次

vmstat 1 20

# 查看io读写/cpu使用情况

iostat

# 查看 cpu 使用情况(1秒1次,共10次)

sar -u 1 10

# 查询磁盘性能

sar -d 1 10

# 找出占用内存资源最多的前 10 个进程

ps -auxf | sort -nr -k 4 | head -10

# 找出占用 CPU 资源最多的前 10 个进程

ps -auxf | sort -nr -k 3 | head -10

# 查看 cpu 内存占用情况

ps -eo pid,ppid,cmd,%cpu,%mem --sort=-%cpu | head

磁盘和分区

 # 查看所属有磁盘分区

fdisk -l

# 查看所有交换分区

swapon -s

# 查看磁盘使用情况及挂载点

df -h

# 查看磁盘使用情况及挂载点

df -hl

# 查看指定某个目录大小

du -sh /dir

# 从高到底依次显示文件和目录大小

du -sk * | sort -rn

# 查看内存

free -h

# 查看CPUs

cat /proc/cpuinfo

# 挂在hda2盘

mount /dev/hda2 /mnt/hda2

# 指定⽂件系统类型挂载(如ntfs)

mount -t ntfs /dev/sdc1 /mnt/usbhd1

# 挂载iso⽂件

mount -o loop xxx.iso /mnt/cdrom

# 挂载usb盘/闪存设备

mount /dev/sda1 /mnt/usbdisk

# 通过设备名卸载

umount -v /dev/sda1

# 通过挂载点卸载

umount -v /mnt/mymnt

# 强制卸载(慎⽤)

fuser -km /mnt/hda1

用户和用户组

  # 创建用户

useradd ss

# 查看所用系统用户

cut -d: -f1 /etc/passwd

# 删除用户

userdel -r ss

# 创建用户组

groupadd group_name

# 查看系统所有组

cut -d: -f1 /etc/group

# 删除用户组

groupdel group_name

# 修改用户的组

usermod -g group_name user_name

# 将用户添加到组

usermod -aG group_name user_name

# 修改用户 ss 的登录 Shell、主目录及用户组

usermod -s /bin/ksh -d /home/codepig –g dev ss

# 查看 ss 用户所在的组

groups ss

# 切换到另一个用户环境

su user_name

# 修改口令

passwd

# 修改用户密码

passwd ss

# 查看用户活动

w

# 查看指定用户 ss 的信息

id ss

# 查看用户登录日志

last

# 查看当前用户的计划任务

crontab -l

网络和进程管理

# 查看网络接口属性

ifconfig

# 查看某网卡的配置

ifconfig eth0

# 查看路由表

route -n

# 查看所有监听端⼝

netstat -lntp

# 查看已经建立连接的TCP连接

netstat -antp

# 查看TCP/UDP的状态信息

netstat -lutp

# 启⽤eth0⽹络设备

ifup eth0

# 禁⽤eth0⽹络设备

ifdown eth0

# 查看iptables规则

iptables -L

# 配置ip地址

ifconfig eth0 192.168.1.1 netmask 255.255.255.0

# 以dhcp模式启⽤eth0

dhclient eth0

# 配置默认⽹关

route add -net 0/0 gw Gateway_IP

# 配置静态路由到达⽹络'192.168.0.0/16'

route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1

# 删除静态路由

route del 0/0 gw Gateway_IP

# 查看主机名

hostname

# 解析主机名

host 主机名  例如:host www.baidu.com

# 查询DNS记录,查看域名解析是否正常

nslookup 主机名  例如:nslookup wwww.baidu.com

# 查看所有进程

ps -ef

# 过滤出你需要的进程

ps -ef|grep redis

# kill指定名称的进程

kill -s name

# kill指定pid的进程

kill -s pid

查看文件大小

# 查看当前目录总大小

du -sh

# 查看当前目录所有子目录大小

du -sh *

# 查看当前目录和所有子目录大小,最后一行会显示当前目录的总大小,不包括隐藏文件

du -ach *

du -h –max-depth=0 *

# 指定文件夹显示层次深度

du -h --max-depth=0

                     

CentOS查看开机自启服务

# 查看有哪些自启服务

systemctl list-unit-files --type service | grep enabled

# 查看服务的开机启动状态

systemctl list-unit-files --type service |grep service_name

# 启动(关闭,重启,查看)某个服务

# centos6

service service_name (start|stop|restart|status)

# centos7

systemctl (start|stop|restart|status) service_name

# 设置开机启动或者关闭某个服务

# centos6

开机启动:chkconfig --add service_name  或者  chkconfig  service_name  on

开机关闭:chkconfig  --del   service_name  或者  chkconfig  service_name  off

# centos7

开机启动:systemctl enable service_name

开机关闭:systemctl disable service_name

标签:文件,file1,查看,file2,命令,liunx,txt,目录,大全
From: https://blog.csdn.net/xue_lun/article/details/144960502

相关文章

  • C#版OpenCv常用函数大全
    OpenCvSharp是OpenCV的NET封装,提供了丰富的图像处理和计算机视觉功能。以下是一些常用函数及其详细说明。1.图像读取与显示Cv2.ImRead功能:读取图像文件并返回一个Mat对象。用法:Matimage=Cv2.ImRead("path/to/image.jpg");Cv2.ImShow功能:在窗口中显示图像。用法:C......
  • tr命令
    [root@localhostdemo]#w08:59:43up11min,1user,loadaverage:0.00,0.01,0.01USERTTYFROMLOGIN@IDLEJCPUPCPUWHATrootpts/0192.168.0.10508:487.00s0.09s0.01sw[root@localhostdemo]#whoroot......
  • wc命令
    [root@localhostdemo]#catluffy.txt10.0.0.110.0.0.110.0.0.5110.0.0.5110.0.0.110.0.0.110.0.0.5110.0.0.3110.0.0.5110.0.0.1210.0.0.510.0.0.510.0.0.5[root@localhostdemo]#cat-nluffy.txt110.0.0.1210.0.0.1310.0.0.51......
  • MobaxTerm不能用ssh命令
    问题1:MobaxTerm不能用ssh命令1.1症状MobaxTerm版本:21.5用MobaXterm新建session去ssh正常。用MobaXterm手动ssh失败,提示➤sshroot@172.1.1.5/etc/ssh_configline8:BadSSH2cipherspec'aes128-ctr,aes192-ctr,aes256-ctr,arcfour256,arcfour128,aes256-gcm@openssh......
  • 【项目经理】面试常见难题大全及回答思路和回答实例参考
    一、人际交往能力问题1、管理团队中利益相关方之间的冲突思路:首先要表明你对冲突管理的重视,然后描述一个具体的冲突场景,重点在于你如何倾听各方的观点,寻找共同利益点,并通过沟通和协商达成解决方案。示例回答:“在之前的项目中,我们的研发团队和市场团队在产品发布时间上有冲突。......
  • cut命令
    [root@localhostdemo]#catalex.txtmynameisalex.helovelinux.helikeeatapple.[root@localhostdemo]#cut-c4alex.txt#截取每行的第4个字符nll[root@localhostdemo]#cut-c4-7alex.txt#截取每行的4到7个字符namelovelike[root@localho......
  • Docker-Compose配置文件结构详解及命令
    yaml文件结构在项目名目录下创建docker-compose.yaml文件,文件结构如下version:'3'#版本号services:#服务类web:#web服务build:../#在本文件的上级目录下构建映像restart:unless-stopped#重启策略ports:-"6000:5......
  • OPENSSL命令行
    note openssl虽然对SM2有一定支持,但是在基于1.1.1版本签发证书和时间戳响应时都会存在问题,比如oid不支持SM2withSM3,签发时间戳会报错PKCS7_R_SIGNING_CTRL_FAILURE推荐RSA使用OPENSSL,SM2使用GMSSL自建CA准备目录mkdir-pprivatecertsnewcertscrl cd/etc/pki/CA生成R......
  • Mongodb日常操作命令
    查看数据库状态:db.stats()查看集合状态:db.collection_name.stats()查看索引使用情况:db.collection_name.getIndexes()重新生成集合的索引:db.collection_name.reIndex()查看查询执行计划:db.collection_name.find({...}).explain()查看库大小:db.stats();查看集合大小:db.js_user.st......
  • Linux命令行连接蓝牙设备
    Linux命令行连接蓝牙设备查看Bluetooth设备:hciconfig启动一个Bluetooth设备,例如:hci0:hciconfighci0up相关指令查看特定的Bluetooth设备(例如,设备名为hci0):hciconfighci0关闭一个Bluetooth设备(例如,设备名为hci0):hciconfighci0down修改一个Bluetooth设备的......