2021-01-25 关于ubuntu系统下一些会用到的命令

关于ubuntu系统下一些会用到的命令

1. 杀死所有python3程序进程( awk、 xargs )

ps aux|grep python|grep -v grep|grep -v usr|cut -c 9-15|xargs kill -15
几个命令:
“ps aux”是linux 里查看所有进程的命令。这时检索出的进程将作为下一条命令“grep python”的输入。
“grep python”的输出结果是,所有含有关键字“python”的进程,这是python程序
“grep -v grep”是在列出的进程中去除含有关键字“grep”的进程。
“cut -c 9-15”是截取输入行的第9个字符到第15个字符,而这正好是进程号PID。
“xargs kill -15”中的xargs命令是用来把前面命令的输出结果(PID)作为“kill -15”命令的参数,并执行该令。
“kill -15”会正常退出指定进程,-9强行杀掉

2.后台执行脚本 back.py

unhup python back.py (> ***.log )&
1.python指定我们要执行的文件为python文件,
2.back.py即是我们要执行的文件。
3.括号内容表示可以将平时输出到控制台中的内容重定向到*.log这个文件中,是可选的,
  如果没有这个,则会默认输出到nohup.out文件中。括号后面你的&表示后台运行。

3.远程登录后,执行back.py脚本并确保远程登录退出后,脚本可以继续运行 (nohup)

nohup
nohup command >/dev/null 2>&1 & 

nohup 应该是另外一个我们常用的命令了,它的作用如其字面意思,使进程不受 SIGHUP 信号的影响。但我们在使用 nohup php test.php 后会发现,进程还会一直占用前台终端,但即使终端被关闭或连接断开了,程序还是会执行,另外我们会发现在当前文件夹下多了个名为 nohup.out 的文件。

这是因为 nohup 的功能仅仅是让进程不受 SIGHUP 信号的影响,并不会让出前台终端,而且它还会在命令执行目录下建立 nohup.out 用以存储进程的输出。如果进程不需要输出,且不想让 nohup 创建文件,可以将标准输出和标准错误输出重定向。

setsid

setsid 是另一个让进程在后台执行的命令,它的作用是让进程打开一个新的会话并运行进程,使用方式为

setsid command

根据上面的概念我们得知终端关闭后进程退出是因为会话首进程向进程发送了 SIGHUP 信号,setsid 就厉害了,它直接打开一个新的会话来执行命令,那么原会话的终端的状态就再也不会影响到此进程了

4.设置ssh免密登陆

1.首先在本地生成ssh私钥和公钥:
    在终端输入:ssh-keygen -t rsa
    连续按三次回车键,不需要输入密码。
    如果文件:~/.ssh/id_rsa.pub文件存在,会提示是否覆盖,如果不存在,则会生成该文件。
2.利用scp命令,将生成的文件复制到服务器root目录下:
    scp ~/.ssh/id_rsa.pub root@x.x.x.x:~/.ssh
    其中x.x.x.x是服务器的ip,root是user。该命令需要输入服务器的登陆密码。
3.复制id_rsa.pub文件里面的公钥,在服务器.ssh目录下新建一个文件。authorized_keys,如果不存在。
  将公钥粘贴到这个文件里面并保存。如果存在则替换。至此,免密登陆设置成功。测试一把。在终端输入:
    ssh root@x.x.x.x
    点击回车,是否已经登陆到了远程服务器。

5.Ubuntu系统下,修改apt软件库镜像源

1.备份source.list
cd /etc/apt/
sudo cp sources.list sources.list.bak复制代码
2.修改sources.list
sudo vim sources.list复制代码
3. 更新 apt 本地索引
sudo apt-get update复制代码

  #一些源的网址
1.[网易源]:(http://mirrors.163.com)
2.[搜狐源]: (http://mirrors.shlug.org)
3.[官方上海源]:(http://mirror.rootguide.org)
4.[厦大源]:(http://mirrors.xmu.edu.cn)
5.[中科大源]:(http://debian.ustc.edu.cn)
6.[成都电子科大源]:(http://ubuntu.uestc.edu.cn)
7.[北京交大源]:(http://mirror.bjtu.edu.cn)

6.Ubuntu系统下,修改pip模块包镜像源

1.打开终端
2.新建.pip目录
  ~$ mkdir ~/.pip
  ~$ vim ~/.pip/pip.conf
3.添加文件内容//阿里源
  [global]
  timeout = 6000
  index-url = http://mirrors.aliyun.com/pypi/simple/
  trusted-host = mirrors.aliyun.com
4.保存,退出

7.通过requirement文件,使用pip安装模块

a.生成requirements文件:

1.通过 pip 安装pyreqs模块:
   pip install pipreqs
2.进入 python 源码所在的目录下,执行:
   pipreqs ./
3.该命令在当前目录下生成 requirements.txt

b.使用requirements文件:

需要在一个新的环境下重新安装源码需要的依赖包,只需执行:
pip install -r requirements.txt

8.确认主机网络联通 (ping)

ping 127.0.0.1//判断硬件是否有问题
ping 网关//判断本地是否能到达出口
ping 8.8.8.8//公网网关,判断本地是否可以连接互联网

9.确认主机端口联通 (telnet)

  telnet [-8acdEfFKLrx][-b<主机别名>][-e<脱离字符>][-k<域名>][-l<用户名称>][-n<记录文件>][-S<服务类型>][-X<认证形态>][主机名称或IP地址<通信端口>]
//例子 
 telnet 192.168.0.5  // 登录IP为 192.168.0.5 的远程主机

10.查看本机硬盘使用情况 (df)

df -h

11.了解linux指令中 | < > >> 2> 2>&1 等输入、输出流重定向的使用方式

文件描述符
文件描述符
文件重定向
文件重定向
重定向标准输出
在下面的命令中,把/etc/passwd文件中的用户ID域按照用户命排列。

该命令的输出重定向到sort.out文件中。要提醒注意的是,在使用sort命令的时候(或其他含有相似输入文件参
数的命令),重定向符号一定要离开sort命令两个空格,否则该命令会把它当作输入文件。

$ cat passwd | awk -F: '{print $1}' | sort 1>sort.out //错误信息不会输出到sort.out

也可以使用如下的表达方式,结果和上面一样:

$ cat passwd | awk -F: '{print $1}' | sort >sort.out //与上面的等价,什么也不写的>,默认就是1【标准输出】
重定向标准输入
可以指定命令的标准输入。在awk一章就会遇到这样的情况。下面给出一个这样的例子:

$ sort < name.txt

在上面的命令中, sort命令的输入是采用重定向的方式给出的,不过也可以直接把相应的

文件作为该命令的参数:

$ sort name.txt

在上面的例子中,还可以更进一步地通过重定向为sort命令指定一个输出文件name.out。

这样屏幕上将不会出现任何信息(除了错误信息以外):

$ sort name.out

12.指令显示当前时间。(date)

date //命令将显示日期和时间
date "+%H:%M:%S   %d/%m/%y" //展示如何将输出控制为需要的任何格式

13.Sed 进行文本替换的简单用法

1.sed的常用命令:
  常用选项:
          -n∶使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN的资料一般都会被列出到萤幕
               上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
          -e∶直接在指令列模式上进行 sed 的动作编辑;
          -f∶直接将 sed 的动作写在一个档案内, -f filename 则可以执行 filename 内的sed 动作;
          -r∶sed 的动作支援的是延伸型正规表示法的语法。(预设是基础正规表示法语法)
          -i∶直接修改读取的档案内容,而不是由萤幕输出。       

  常用命令:
          a   ∶新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
          c   ∶取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
          d   ∶删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
           i   ∶插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
           p  ∶列印,亦即将某个选择的资料印出。通常 p 会与参数 sed -n 一起运作~
           s  ∶取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!
  举例:(假设我们有一文件名为ab)
      1.删除某行
       [root@localhost ruby]# sed '1d' ab              #删除第一行 
       [root@localhost ruby] # sed '$d' ab              #删除最后一行
       [root@localhost ruby] # sed '1,2d' ab           #删除第一行到第二行
       [root@localhost ruby] # sed '2,$d' ab           #删除第二行到最后一行

      2.显示某行
.      [root@localhost ruby]# sed -n '1p' ab           #显示第一行 
       [root@localhost ruby] # sed -n '$p' ab           #显示最后一行
       [root@localhost ruby] # sed -n '1,2p' ab        #显示第一行到第二行
       [root@localhost ruby] # sed -n '2,$p' ab        #显示第二行到最后一行

      3.使用模式进行查询
       [root@localhost ruby] # sed -n '/ruby/p' ab    #查询包括关键字ruby所在所有行
       [root@localhost ruby] # sed -n '/\$/p' ab        #查询包括关键字$所在所有行,使用反斜线\屏蔽特殊含义

      4.增加一行或多行字符串
       [root@localhost ruby]# cat ab
       Hello!
       ruby is me,welcome to my blog.
       end
       [root@localhost ruby] # sed '1a drink tea' ab  #第一行后增加字符串"drink tea"
       Hello!
       drink tea
       ruby is me,welcome to my blog. 
       end
       [root@localhost ruby] # sed '1,3a drink tea' ab #第一行到第三行后增加字符串"drink tea"
       Hello!
       drink tea
       ruby is me,welcome to my blog.
       drink tea
       end
       drink tea
       [root@localhost ruby] # sed '1a drink tea\nor coffee' ab  #第一行后增加多行,使用换行符\n
       Hello!
       drink tea
       or coffee
       ruby is me,welcome to my blog.
       end

      5.代替一行或多行
       [root@localhost ruby] # sed '1c Hi' ab               #第一行代替为Hi
       Hi
       ruby is me,welcome to my blog.
       end
       [root@localhost ruby] # sed '1,2c Hi' ab            #第一行到第二行代替为Hi
       Hi
       end

       sed 's/^/添加的头部&/g'   //在所有行首添加
       sed 's/$/&添加的尾部/g'    //在所有行末添加

       sed '2s/原字符串/替换字符串/g'    //替换第2行

       sed '$s/原字符串/替换字符串/g'    //替换最后一行

       sed '2,5s/原字符串/替换字符串/g'    //替换2到5行

       sed '2,$s/原字符串/替换字符串/g'    //替换2到最后一行

       sed '.,$s/原字符串/替换字符串/g'    //替换当前行到最后一行
      6.替换一行中的某部分
    格式:sed 's/要替换的字符串/新的字符串/g'   (要替换的字符串可以用正则表达式,末尾加g替换每一个匹配的关键字,否则只替换每行的第一个)
       sed -n '/ruby/p' ab | sed 's/ruby/bird/g'    #替换ruby为bird
    sed -n '/ruby/p' ab | sed 's/ruby//g'        #删除ruby

       替换样式可以多个在同一条命令中执行,用分号”;”分隔:

       sed 's/^/添加的头部&/g;s/$/&添加的尾部/g'    //同时执行两个替换规则
      7.插入
      sed -i '$a bye' ab        #在文件ab中最后一行直接输入"bye"
      sed -i '1i'$first ab#在文件ab中第一行插入变量$first作为一行,这里注意1和i之间可以有空格,但是$first前不能有空格

      8.删除匹配行

        sed -i '/匹配字符串/d'  filename  (注:若匹配字符串是变量,则需要“”,而不是‘’。记得好像是)

      9.替换匹配行中的某个字符串:

        sed -i '/匹配字符串/s/替换源字符串/替换目标字符串/g' filename

      10.sed处理过的输出是直接输出到屏幕上的,要保存可以将输出重定向,或者使用参数”i”直接在文件中替换:

        sed -i 's/原字符串/替换字符串/g' filename    //替换文件中的所有匹配项

注:为了避免/的歧义。可以使用?、#、+等其他字符来代替/作为命令的分隔符。

14.计数指令 (wc)

wc 命令 的功能为统计指定文件中的字节数、字数、行数, 并将统计结果显示输出。
语法:wc [-clmw] [file ...]
wc -c file #文件字节数
wc -l file #文件行数
wc -m file #文件字符数
wc -w file #文件单词数
wc pom.xml #输出信息依次是:行数 字数 字节数 文件名称
ls -l |wc -l #统计当前目录下的文件数
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容