当前位置: 首页 / 技术干货 / 正文
好程序员云计算培训分享Linux Shell常见命令总结大全

2020-09-03

云计算培训

  好程序员云计算培训分享Linux Shell常见命令总结大全,Linux shell命令应该算是非常入门的东西,但是实际上在使用的时候,会遇到各种各样的问题,前几天我在我们的项目上需要做一个功能,根据进程名字杀死这个进程,下面是过程。

好程序员

  (1) 我们正常需要的操作是

  $ps |grep xxx

  $kill -9 xx

  (2) kill命令是常用的,但是用killall命令会更快

  $killall -9 xxx

  (3) 令我困扰的是我用的那个没有killall然后我做了下面的操作

  $adb shell ps |grep speech |awk '{print $2}' > 1.txt

  $cat 1.txt |xargs -n1 adb shell kill -9

  我用这个的原因是用一条指令重定向总是各种问题,正常情况下用这条就可以了

  $adb shell ps |grep speech |awk '{print $2}'|xargs -n1 kill -9

  1. 关机/重启

  关机(必须用root用户)

  shutdown -h now ## 立刻关机

  shutdown -h +10 ## 10分钟以后关机

  shutdown -h 12:00:00 ##12点整的时候关机

  halt # 等于立刻关机

  重启

  shutdown -r now

  2. echo

  root@ubuntu:~# a="hello,world"

  root@ubuntu:~# echo a

  a

  root@ubuntu:~# echo &a

  [1] 3091

  a: command not found

  [1]+ Done echo

  root@ubuntu:~# echo $a

  hello,world

  root@ubuntu:~#

  3. vim文本编辑器

  最基本用法

  vi somefile.4

  1 首先会进入“一般模式”,此模式只接受各种快捷键,不能编辑文件内容

  2 按i键,就会从一般模式进入编辑模式,此模式下,敲入的都是文件内容

  3 编辑完成之后,按Esc键退出编辑模式,回到一般模式;

  4 再按:,进入“底行命令模式”,输入wq命令,回车即可

  常用快捷键

  一些有用的快捷键(在一般模式下使用):

  a 在光标后一位开始插入

  A 在该行的最后插入

  I 在该行的最前面插入

  gg 直接跳到文件的首行

  G 直接跳到文件的末行

  dd 删除一行

  3dd 删除3行

  yy 复制一行

  3yy 复制3行

  p 粘贴

  u undo

  v 进入字符选择模式,选择完成后,按y复制,按p粘贴

  ctrl+v 进入块选择模式,选择完成后,按y复制,按p粘贴

  shift+v 进入行选择模式,选择完成后,按y复制,按p粘贴

  查找并替换

  1 显示行号

  :set nu

  2 隐藏行号

  :set nonu

  3 查找关键字

  :/you ## 效果:查找文件中出现的you,并定位到diyi个找到的地方,按n可以定位到下一个匹配位置(按N定位到上一个)

  4 替换操作

  :s/sad/bbb 查找光标所在行的diyi个sad,替换为bbb

  :%s/sad/bbb 查找文件中所有sad,替换为bbb

  4. 拷贝/删除/移动/更换文件名字

  cp somefile.1 /home/hadoop/

  rm /home/hadoop/somefile.1

  rm -f /home/hadoop/somefile.1

  mv /home/hadoop/somefile.1 ../

  mv a.txt b.txt //把a.txt更名为b.txt

  5. 打包压缩

  1、gzip压缩

  gzip a.txt

  2、解压

  gunzip a.txt.gz

  gzip -d a.txt.gz

  3、bzip2压缩

  bzip2 a

  4、解压

  bunzip2 a.bz2

  bzip2 -d a.bz2

  5、打包:将指定文件或文件夹

  tar -cvf bak.tar ./aaa

  将/etc/password追加文件到bak.tar中

  tar -rvf bak.tar /etc/password

  6、解压

  tar -xvf bak.tar

  7、打包并压缩

  tar -zcvf a.tar.gz aaa/

  8、解包并解压缩(重要的事情说三遍!!!)

  tar -zxvf a.tar.gz

  解压到/usr/下

  tar -zxvf a.tar.gz -C /usr

  9、查看压缩包内容

  tar -ztvf a.tar.gz

  zip/unzip

  10、打包并压缩成bz2

  tar -jcvf a.tar.bz2

  11、解压bz2

  tar -jxvf a.tar.bz2

  6. 常用查找命令的使用

  1、查找可执行的命令所在的路径:

  which ls

  2、查找可执行的命令和帮助的位置:

  whereis ls

  3、从某个文件夹开始查找文件

  find / -name "hadooop*"

  find / -name "hadooop*" -ls

  4、查找并删除

  find / -name "hadooop*" -ok rm {} \;

  find / -name "hadooop*" -exec rm {} \;

  5、查找用户为hadoop的文件

  find /usr -user hadoop -ls

  6、查找用户为hadoop的文件夹

  find /home -user hadoop -type d -ls

  7、查找权限为777的文件

  find / -perm -777 -type d -ls

  8、在指定目录不分大小写查找某个文件

  find ./sound/ -iname ft56Q.c

  9、显示命令历史

  history

  7. grep命令

  最常用的-全字匹配

  grep -wrn weiqifa ./sound/

  查找 某个字符串但是不在指定文件夹查找

  grep -E "http" ./ -R --exclude-dir=./sound/

  grep -E "http" . -R --exclude-dir={.git,res,bin}

  排除扩展名为 java 和 js 的文件

  grep -E "http" . -R --exclude=*.{java,js}

  1 基本使用

  查询包含hadoop的行

  grep hadoop /etc/password

  grep aaa ./*.txt

  2 cut截取以:分割保留第七段

  root@ubuntu:~/kernel_rk3399_yan4_dev/kernel# grep dsl /etc/passwd | cut -d: -f7

  /bin/bash

  root@ubuntu:~/kernel_rk3399_yan4_dev/kernel# grep dsl /etc/passwd

  dsl:x:1000:1000:dsl,,,:/home/dsl:/bin/bash

  root@ubuntu:~/kernel_rk3399_yan4_dev/kernel#

  3 查询不包含hadoop的行

  grep -v hadoop /etc/passwd

  4 正则表达包含hadoop

  grep 'hadoop' /etc/passwd

  5 正则表达(点代表任意一个字符)

  grep 'h.*p' /etc/passwd

  6 正则表达以hadoop开头

  grep '^hadoop' /etc/passwd

  7 正则表达以hadoop结尾

  grep 'hadoop$' /etc/passwd

  规则:

  . : 任意一个字符

  a* : 任意多个a(零个或多个a)

  a? : 零个或一个a

  a+ : 一个或多个a

  .* : 任意多个任意字符

  \. : 转义.

  o\{2\} : o重复两次

  查找不是以#开头的行

  grep -v '^#' a.txt | grep -v '^$'

  以h或r开头的

  grep '^[hr]' /etc/passwd

  不是以h和r开头的

  grep '^[^hr]' /etc/passwd

  不是以h到r开头的

  grep '^[^h-r]' /etc/passwd

  8. linux文件权限的描述格式解读

  drwxr-xr-x (也可以用二进制表示 111 101 101 --> 755)

  d:标识节点类型(d:文件夹 -:文件 l:链接)

  r:可读 w:可写 x:可执行

  diyi组rwx: ## 表示这个文件的拥有者对它的权限:可读可写可执行

  第二组r-x: ## 表示这个文件的所属组用户对它的权限:可读,不可写,可执行

  第三组r-x: ## 表示这个文件的其他用户(相对于上面两类用户)对它的权限:可读,不可写,可执行

  9. 修改文件权限

  chmod g-rw haha.dat ## 表示将haha.dat对所属组的rw权限取消

  chmod o-rw haha.dat ## 表示将haha.dat对其他人的rw权限取消

  chmod u+x haha.dat ## 表示将haha.dat对所属用户的权限增加x

  chmod a-x haha.dat ## 表示将haha.dat对所用户取消x权限

  也可以用数字的方式来修改权限

  chmod 664 haha.dat

  就会修改成 rw-rw-r--

  如果要将一个文件夹的所有内容权限统一修改,则可以-R参数

  chmod -R 770 aaa/

  10. 修改文件所有权

  <只有root权限能执行>

  chown angela aaa ## 改变所属用户

  chown :angela aaa ## 改变所属组

  chown angela:angela aaa/ ## 同时修改所属用户和所属组

  11. 统计文件或文件夹的大小

  root@ubuntu:~/kernel_rk3399_yan4_dev/kernel# du -sh sound/

  33M sound/

  root@ubuntu:~/kernel_rk3399_yan4_dev/kernel#

  df -h 查看磁盘的空间

  root@ubuntu:~/kernel_rk3399_yan4_dev/kernel# df -h

  Filesystem Size Used Avail Use% Mounted on

  udev 1.9G 0 1.9G 0% /dev

  tmpfs 394M 6.4M 388M 2% /run

  /dev/sda1 294G 93G 186G 34% /

  tmpfs 2.0G 204K 2.0G 1% /dev/shm

  tmpfs 5.0M 4.0K 5.0M 1% /run/lock

  tmpfs 2.0G 0 2.0G 0% /sys/fs/cgroup

  tmpfs 394M 80K 394M 1% /run/user/1000

  root@ubuntu:~/kernel_rk3399_yan4_dev/kernel#

好程序员公众号

  • · 剖析行业发展趋势
  • · 汇聚企业项目源码

好程序员开班动态

More+
  • HTML5大前端 <高端班>

    开班时间:2021-04-12(深圳)

    开班盛况

    开班时间:2021-05-17(北京)

    开班盛况
  • 大数据+人工智能 <高端班>

    开班时间:2021-03-22(杭州)

    开班盛况

    开班时间:2021-04-26(北京)

    开班盛况
  • JavaEE分布式开发 <高端班>

    开班时间:2021-05-10(北京)

    开班盛况

    开班时间:2021-02-22(北京)

    开班盛况
  • Python人工智能+数据分析 <高端班>

    开班时间:2021-07-12(北京)

    预约报名

    开班时间:2020-09-21(上海)

    开班盛况
  • 云计算开发 <高端班>

    开班时间:2021-07-12(北京)

    预约报名

    开班时间:2019-07-22(北京)

    开班盛况
IT培训IT培训
在线咨询
IT培训IT培训
试听
IT培训IT培训
入学教程
IT培训IT培训
立即报名
IT培训

Copyright 2011-2023 北京千锋互联科技有限公司 .All Right 京ICP备12003911号-5 京公网安备 11010802035720号