• linux常用命令


    写在前面

    记录工作中经常用到的Linux命令,作为备忘录,同时也希望能帮助到看到的朋友。

    1:常用命令

    1.1:ps

    该命令用来查看进程信息,主要参数如下:

    a:显示一个终端的所有进程,除会话引线外;
    u:显示进程的归属用户及内存的使用情况;
    x:显示没有控制终端的进程;
    -l:长格式显示更加详细的信息;
    -e:显示所有进程;
    
    • 1
    • 2
    • 3
    • 4
    • 5

    这里我们不用刻意去记每个参数是什么意思,只需要记住常用的几个使用方式就行,如下:

    "ps aux" 可以查看系统中所有的进程;
    "ps -le" 可以查看系统中所有的进程,而且还能看到进程的父进程的 PID 和进程优先级;
    "ps -l" 只能看到当前 Shell 产生的进程;
    
    • 1
    • 2
    • 3

    接下来分别看下。

    1.1.1:ps aux

    查看系统中所有进程的信息,如下:

    [root@localhost study]# ps aux
    USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
    root          1  0.0  0.6 128048  6668 ?        Ss   Nov17   0:01 /usr/lib/systemd/sroot          2  0.0  0.0      0     0 ?        S    Nov17   0:00 [kthreadd]
    root          4  0.0  0.0      0     0 ?        S<   Nov17   0:00 [kworker/0:0H]
    root          5  0.0  0.0      0     0 ?        S    Nov17   0:00 [kworker/u256:0]
    root          6  0.0  0.0      0     0 ?        S    Nov17   0:01 [ksoftirqd/0]
    ...
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    每列的含义如下:

    USER 该进程是由哪个用户产生的。
    PID	进程的 ID。 -- 重点关注
    %CPU 该进程占用 CPU 资源的百分比,占用的百分比越高,进程越耗费资源。 -- 重点关注
    %MEM 该进程占用物理内存的百分比,占用的百分比越高,进程越耗费资源。-- 重点关注
    VSZ	该进程占用虚拟内存的大小,单位为 KB。
    RSS	该进程占用实际物理内存的大小,单位为 KB。 -- 重点关注
    TTY	该进程是在哪个终端运行的。其中,tty1 ~ tty7 代表本地控制台终端(可以通过 Alt+F1 ~ F7 快捷键切换不同的终端),tty1~tty6 是本地的字符界面终端,tty7 是图形终端。pts/0 ~ 255 代表虚拟终端,一般是远程连接的终端,第一个远程连接占用 pts/0,第二个远程连接占用 pts/1,依次増长。
    STAT 进程状态。常见的状态有以下几种:
            -D:不可被唤醒的睡眠状态,通常用于 I/O 情况。
            -R:该进程正在运行。
            -S:该进程处于睡眠状态,可被唤醒。
            -T:停止状态,可能是在后台暂停或进程处于除错状态。
            -W:内存交互状态(从 2.6 内核开始无效)。
            -X:死掉的进程(应该不会出现)。
            -Z:僵尸进程。进程已经中止,但是部分程序还在内存当中。
            -<:高优先级(以下状态在 BSD 格式中出现)。
            -N:低优先级。
            -L:被锁入内存。
            -s:包含子进程。
            -l:多线程(小写 L)。
            -+:位于后台。
    START 该进程的启动时间。
    TIME 该进程占用 CPU 的运算时间,注意不是系统时间。
    COMMAND	产生此进程的命令名。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    以上标注重点关注的我们经常需要用到。

    1.1.2:ps -le

    ps aux,但是会展示更加详细的信息,如父进程ID,优先级等,正常二者使用其一即可,如下:

    [root@localhost study]# ps -le
    F S   UID    PID   PPID  C PRI  NI ADDR SZ WCHAN  TTY          TIME CMD
    4 S     0      1      0  0  80   0 - 32012 ep_pol ?        00:00:01 systemd
    1 S     0      2      0  0  80   0 -     0 kthrea ?        00:00:00 kthreadd
    1 S     0      4      2  0  60 -20 -     0 worker ?        00:00:00 kworker/0:0H
    1 S     0      5      2  0  80   0 -     0 worker ?        00:00:00 kworker/u256:0
    1 S     0      6      2  0  80   0 -     0 smpboo ?        00:00:01 ksoftirqd/0
    ...
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    各列含义如下:

    F 进程标志,说明进程的权限,常见的标志有两个:
        1:进程可以被复制,但是不能被执行;
        4:进程使用超级用户权限;
    S 进程状态。具体的状态和"psaux"命令中的 STAT 状态一致;
    UID	运行此进程的用户的 ID;
    PID	进程的 ID;
    PPID 父进程的 ID;
    C 该进程的 CPU 使用率,单位是百分比;
    PRI	进程的优先级,数值越小,该进程的优先级越高,越早被 CPU 执行;
    NI 进程的优先级,数值越小,该进程越早被执行;
    ADDR 该进程在内存的哪个位置;
    SZ 该进程占用多大内存;
    WCHAN 该进程是否运行。"-"代表正在运行;
    TTY	该进程由哪个终端产生;
    TIME 该进程占用 CPU 的运算时间,注意不是系统时间;
    CMD	产生此进程的命令名;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    1.1.3:ps -l

    该命令仅用于查看当前登录用户产生的进程信息,如下:

    [root@localhost study]# ps -l
    F S   UID    PID   PPID  C PRI  NI ADDR SZ WCHAN  TTY          TIME CMD
    4 S     0   1470   1466  0  80   0 - 28904 do_wai pts/2    00:00:00 bash
    0 R     0   3746   1470  0  80   0 - 38332 -      pts/2    00:00:00 ps
    
    • 1
    • 2
    • 3
    • 4

    僵尸进程:僵尸进程是子进程因为程序异常异常结束,而父进程并没有对其进行正常的回收,从而造成子进程一直存在于内存中,僵尸进程可能会影响到程序的稳定性,产生僵尸进程后,首先要对已经产生的僵尸进程进行强行终止,并对程序优化,避免产生僵尸进程。

    1.2:top

    该命令可以认为是ps命令的动态版本,如果是想要持续的观察进程运行情况,就需要不断的执行ps命令,显然效率不高,为此,Linux提供了top命令,持续的输出进程的运行状态,并提供一定的交互能力。命令基本格式top [选项],选项如下:

    -d 秒数:指定 top 命令每隔几秒更新。默认是 3 秒;
    -b:使用批处理模式输出。一般和"-n"选项合用,用于把 top 命令重定向到文件中;
    -n 次数:指定 top 命令执行的次数。一般和"-"选项合用;
    -p 进程PID:仅查看指定 ID 的进程;
    -s:使 top 命令在安全模式中运行,避免在交互模式中出现错误;
    -u 用户名:只监听某个用户的进程;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    交互操作如下:

    ? 或 h:显示交互模式的帮助;
    P:按照 CPU 的使用率排序,默认就是此选项;
    M:按照内存的使用率排序;
    N:按照 PID 排序;
    T:按照 CPU 的累积运算时间排序,也就是按照 TIME+ 项排序;
    k:按照 PID 给予某个进程一个信号。一般用于中止某个进程,信号 9 是强制中止的信号;
    r:按照 PID 给某个进程重设优先级(Nice)值;
    q:退出 top 命令;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    2.1:top结果说明

    top输出如下:

    top - 16:43:15 up 1 day, 34 min,  4 users,  load average: 0.08, 0.03, 0.05
    Tasks: 101 total,   1 running, 100 sleeping,   0 stopped,   0 zombie
    %Cpu(s):  0.0 us,  0.3 sy,  0.0 ni, 99.7 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
    KiB Mem :   995676 total,   661228 free,   204268 used,   130180 buff/cache
    KiB Swap:  2097148 total,  2097148 free,        0 used.   651000 avail Mem 
    
       PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                                                                                                 
         1 root      20   0  128048   6668   4176 S  0.0  0.7   0:01.73 systemd                                                                                                                 
         2 root      20   0       0      0      0 S  0.0  0.0   0:00.01 kthreadd                                                                                                                
         4 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 kworker/0:0H                                                                                                            
         5 root      20   0       0      0      0 S  0.0  0.0   0:01.23 kworker/u256:0                                                  
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    其中开始有5行内容,后面是各个进程的相关信息,第一行内容top - 16:43:15 up 1 day, 34 min, 4 users, load average: 0.08, 0.03, 0.05,含义如下:

    16:43:15 -> 系统当前时间
    up 1 day, 34 min -> 系统的运行时间.本机己经运行1天34分钟
    4 users -> 当前登录了4个用户(但是我认为这里应该是session数,因为我本地是用一个用户开了4个终端)
    load average: 0.08, 0.03, 0.05 -> 系统在之前 1 分钟、5 分钟、15 分钟的平均负载。如果 CPU 是单核的,则这个数值超过 1 就是高负载:如果 CPU 是四核的,则这个数值超过 4 就是高负载 (这个平均负载完全是依据个人经验来进行判断的,一般认为不应该超过服务器 CPU 的核数)
    
    • 1
    • 2
    • 3
    • 4

    第二行内容Tasks: 101 total, 1 running, 100 sleeping, 0 stopped, 0 zombie,说明如下:

    Tasks: 101 total -> 系统中的进程总数,这里一共有101个进程
    1 running -> 正在运行的进程数
    100 sleeping -> 睡眠的进程数
    0 stopped -> 正在停止的进程数
    0 zombie -> 僵尸进程数。如果不是 0,则需要手工检查僵尸进程
    
    • 1
    • 2
    • 3
    • 4
    • 5

    第三行内容%Cpu(s): 0.0 us, 0.3 sy, 0.0 ni, 99.7 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st,说明如下:

    Cpu(s): 0.1 %us	用户模式占用的 CPU 百分比
    0.1%sy	系统模式占用的 CPU 百分比
    0.0%ni	改变过优先级的用户进程占用的 CPU 百分比
    99.7%id	空闲 CPU 占用的 CPU 百分比
    0.1%wa	等待输入/输出的进程占用的 CPU 百分比
    0.0%hi	硬中断请求服务占用的 CPU 百分比
    0.1%si	软中断请求服务占用的 CPU 百分比
    0.0%st	st(steal time)意为虚拟时间百分比,就是当有虚拟机时,虚拟 CPU 等待实际 CPU 的时间百分比
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    第四行内容KiB Mem : 995676 total, 661228 free, 204268 used, 130180 buff/cache,说明如下:

    Mem: 625344k total	物理内存的总量,单位为KB
    571504k used	己经使用的物理内存数量
    53840k&ee	空闲的物理内存数量。我们使用的是虚拟机,共分配了 628MB内存,所以只有53MB的空闲内存
    65800k buffers	作为缓冲的内存数量
    
    • 1
    • 2
    • 3
    • 4

    第五行内容KiB Swap: 2097148 total, 2097148 free, 0 used. 651000 avail Mem,说明如下:

    Swap: 524280k total	交换分区(虚拟内存)的总大小
    Ok used	已经使用的交换分区的大小
    524280k free	空闲交换分区的大小
    409280k cached	作为缓存的交换分区的大小
    
    • 1
    • 2
    • 3
    • 4

    我们通过top命令的第一部分就可以判断服务器的健康状态。如果1分钟、5分钟、15分钟的平均负载高于核数,则证明系统压力较大。如果CPU的使用率过高或空闲率过低,则证明系统压力较大。如果物理内存的空闲内存过小,则也证明系统压力较大。这时,我们就应该判断是什么进程占用了系统资源。如果是不必要的进程,就应该结束这些进程;如果是必需进程,那么我们该増加服务器资源(比如増加虚拟机内存),或者建立集群服务器。

    第二部分进程信息含义如下:

    PID:进程的ID。
    USER:该进程所属的用户。
    PR:优先级,数值越小优先级越高。
    NI:优先级,数值越小、优先级越高。
    VIRT:该进程使用的虚拟内存的大小,单位为KB。
    RES:该进程使用的物理内存的大小,单位为KB。
    SHR:共享内存大小,单位为 KB。
    S:进程状态。
    %CPU:该进程占用CPU的百分比。
    %MEM:该进程占用内存的百分比。
    TIME+:该进程共占用的CPU时间。
    COMMAND:进程的命令名。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    2.2:查看指定进程

    top -p 1:

    top - 17:32:12 up 1 day,  1:23,  4 users,  load average: 0.00, 0.01, 0.05
    Tasks:   1 total,   0 running,   1 sleeping,   0 stopped,   0 zombie
    %Cpu(s):  0.0 us,  0.0 sy,  0.0 ni,100.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
    KiB Mem :   995676 total,   661380 free,   204104 used,   130192 buff/cache
    KiB Swap:  2097148 total,  2097148 free,        0 used.   651160 avail Mem 
    
       PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                                                                                                 
         1 root      20   0  128048   6668   4176 S  0.0  0.7   0:01.77 systemd                                                         
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    2.3:输出到文件

    -b,输出到文件,-n设置次数,如下将pid为1的进程信息输出2次到文件中:

    [root@localhost study]# top -p 1 -b -n 2 > ./pid1info.txt
    [root@localhost study]# cat pid1info.txt 
    top - 17:35:42 up 1 day,  1:27,  4 users,  load average: 0.00, 0.01, 0.05
    Tasks:   1 total,   0 running,   1 sleeping,   0 stopped,   0 zombie
    %Cpu(s):  0.0 us,  0.0 sy,  0.0 ni,100.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
    KiB Mem :   995676 total,   661628 free,   203852 used,   130196 buff/cache
    KiB Swap:  2097148 total,  2097148 free,        0 used.   651408 avail Mem 
    
       PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND
         1 root      20   0  128048   6668   4176 S  0.0  0.7   0:01.77 systemd
    
    top - 17:35:45 up 1 day,  1:27,  4 users,  load average: 0.00, 0.01, 0.05
    Tasks:   1 total,   0 running,   1 sleeping,   0 stopped,   0 zombie
    %Cpu(s):  0.0 us,  0.0 sy,  0.0 ni,100.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
    KiB Mem :   995676 total,   661628 free,   203848 used,   130200 buff/cache
    KiB Swap:  2097148 total,  2097148 free,        0 used.   651408 avail Mem 
    
       PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND
         1 root      20   0  128048   6668   4176 S  0.0  0.7   0:01.77 systemd
    [root@localhost study]# 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    1.3:查看端口号

    1.3.1:lsof

    格式lsof -i:端口号,如:

    # lsof -i:8000
    COMMAND   PID USER   FD   TYPE   DEVICE SIZE/OFF NODE NAME
    nodejs  26993 root   10u  IPv4 37999514      0t0  TCP *:8000 (LISTEN)
    
    • 1
    • 2
    • 3

    更多 lsof 的命令如下:

    lsof -i:8080:查看8080端口占用
    lsof abc.txt:显示开启文件abc.txt的进程
    lsof -c abc:显示abc进程现在打开的文件
    lsof -c -p 1234:列出进程号为1234的进程所打开的文件
    lsof -g gid:显示归属gid的进程情况
    lsof +d /usr/local/:显示目录下被进程开启的文件
    lsof +D /usr/local/:同上,但是会搜索目录下的目录,时间较长
    lsof -d 4:显示使用fd为4的进程
    lsof -i -U:显示所有打开的端口和UNIX domain文件
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    1.3.2:netstat

    格式netstat -tunlp | grep 端口号。如:

    # netstat -tunlp | grep 8000
    tcp        0      0 0.0.0.0:8000            0.0.0.0:*               LISTEN      26993/nodejs   
    
    • 1
    • 2

    更多命令:

    netstat -ntlp   //查看当前所有tcp端口
    netstat -ntulp | grep 80   //查看所有80端口使用情况
    netstat -ntulp | grep 3306   //查看所有3306端口使用情况
    
    • 1
    • 2
    • 3

    1.3.3:根据进程关键字查看占用的端口号

    netstat -anp|grep 服务名

    [root@localhost bin]# netstat -anp|grep freeswi
    tcp        0      0 192.168.192.128:7443    0.0.0.0:*               LISTEN      116686/./freeswitch 
    tcp        0      0 192.168.192.128:5080    0.0.0.0:*               LISTEN      116686/./freeswitch 
    tcp        0      0 192.168.192.128:5060    0.0.0.0:*               LISTEN      116686/./freeswitch 
    tcp        0      0 192.168.192.128:5066    0.0.0.0:*               LISTEN      116686/./freeswitch 
    tcp6       0      0 :::8021                 :::*                    LISTEN      116686/./freeswitch 
    tcp6       0      0 ::1:5080                :::*                    LISTEN      116686/./freeswitch 
    tcp6       0      0 ::1:5060                :::*                    LISTEN      116686/./freeswitch 
    udp        0      0 192.168.192.128:5060    0.0.0.0:*                           116686/./freeswitch 
    udp        0      0 192.168.192.128:5080    0.0.0.0:*                           116686/./freeswitch 
    udp6       0      0 ::1:5060                :::*                                116686/./freeswitch 
    udp6       0      0 ::1:5080                :::*                                116686/./freeswitch 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    1.4:安装软件包

    1.4.1:Ubuntu

    命令apt-get install -y 软件包名称,如下按照ssh:

    安装ssh:
    sudo apt install -y openssh-server
    service sshd start # 启动
    
    安装docker:
    sudo apt install docker.io
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    1.5:写多行内容到文件中

    tee命令,cat命令,如下:

    tee命令:
    sudo tee /home/dongyunqi/wp.conf <<-'EOF'
    server {
      listen 80;
      default_type text/html;
    
      location / {
          proxy_http_version 1.1;
          proxy_set_header Host $host;
          proxy_pass http://172.17.0.5;
      }
    }
    EOF
    
    cat命令:
    cat > /path/to/file << EOF
    content
    content
    content
    EOF
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    1.6:grep常用操作

    1.6.1:查询多项

    dongyunqi@mongodaddy:~/k8s$ kubectl api-resources | egrep "DaemonSet|KIND"
    NAME                              SHORTNAMES   APIVERSION                             NAMESPACED   KIND
    daemonsets                        ds           apps/v1                                true         DaemonSet
    
    • 1
    • 2
    • 3

    1.6.2:精准匹配

    -w参数实现,如下:

    ongyunqi@mongodaddy:~/k8s$ kubectl api-resources | egrep -w 'Service|KIND'
    
    NAME                              SHORTNAMES   APIVERSION                             NAMESPACED   KIND
    services                          svc          v1                                     true         Service
    
    • 1
    • 2
    • 3
    • 4

    1.6.3:向前向后显示指定行数

    -A after向后显示指定行,-B before向前显示指定行。
    在这里插入图片描述

    1.7:scp拷贝文件

    1.7.1:拷贝文件夹到目标主机

    -r代表递归拷贝。

    scp -r /home/dongyunqi/k8s/images dongyunqi@192.168.64.131:/home/dongyunqi/k8s
    
    • 1

    实例:

    dongyunqi@mongomummy:~/k8s/images$ scp -r /home/dongyunqi/k8s/images dongyunqi@192.168.64.131:/home/dongyunqi/k8s
    The authenticity of host '192.168.64.131 (192.168.64.131)' can't be established.
    ED25519 key fingerprint is SHA256:pblVurw73lnn0ZQouRbQcO5XCHl9vbgLW86aPARYRTQ.
    This key is not known by any other names
    Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
    Warning: Permanently added '192.168.64.131' (ED25519) to the list of known hosts.
    dongyunqi@192.168.64.131's password: 
    pause.tar                                                                                                                                 100%  677KB  37.9MB/s   00:00    
    etcd.tar                                                                                                                                  100%  280MB  82.2MB/s   00:03    
    kube-apiserver.tar                                                                                                                        100%  130MB  72.0MB/s   00:01    
    coredns.tar                                                                                                                               100%   45MB  32.0MB/s   00:01    
    kube-controller-manager.tar                                                                                                               100%  120MB  38.7MB/s   00:03    
    kube-scheduler.tar                                                                                                                        100%   52MB  44.1MB/s   00:01    
    kube-proxy.tar                                                                                                                            100%  109MB  49.4MB/s   00:02    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    1.8:查看文件前/后n行

    [root@localhost ~]# cat /tmp/a.txt | head -10 // 前10行
    
     num     #instances         #bytes  class name
    ----------------------------------------------
       1:        590155       37769920  dongshi.daddy.huohuo.EmptyObject
       2:          5482        7697624  [B
       3:         20403        5691824  [C
       4:          3196        4999616  [Ljava.lang.Object;
       5:          2736        2136072  [I
       6:         12916         619968  java.nio.HeapCharBuffer
       7:         20142         483408  java.lang.String
    [root@localhost ~]# cat /tmp/a.txt | tail -10 // 后10行
    1368:             1             16  sun.text.normalizer.NormalizerImpl$FCDTrieImpl
    1369:             1             16  sun.text.normalizer.NormalizerImpl$NormTrieImpl
    1370:             1             16  sun.util.calendar.Gregorian
    1371:             1             16  sun.util.locale.provider.AuxLocaleProviderAdapter$NullProvider
    1372:             1             16  sun.util.locale.provider.CalendarDataUtility$CalendarWeekParameterGetter
    1373:             1             16  sun.util.locale.provider.SPILocaleProviderAdapter
    1374:             1             16  sun.util.locale.provider.TimeZoneNameUtility$TimeZoneNameGetter
    1375:             1             16  sun.util.resources.LocaleData
    1376:             1             16  sun.util.resources.LocaleData$LocaleDataResourceBundleControl
    Total        713405       62014248
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    1.9:find查找文件

    find 路径 -name ’文件名'

    [root@localhost data]# find /data/ -name '*.conf' | grep module
    /data/freeswitch/conf/minimal/modules.conf
    /data/freeswitch/modules.conf
    
    • 1
    • 2
    • 3

    2:常用配置

    2.1:ubuntu配置阿里云源

    首先在文件/etc/apt/sources.list中增加如下内容:

    deb http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
    deb-src http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
    
    deb http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
    deb-src http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
    
    deb http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
    deb-src http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
    
    deb http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
    deb-src http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
    
    deb http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
    deb-src http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    然后在文件/etc/resolv.conf中增加如下内容:

    nameserver 8.8.8.8
    nameserver 114.114.114.114
    
    • 1
    • 2

    最后执行如下命令:

    sudo apt-get update
    sudo apt-get upgrade
    
    • 1
    • 2

    写在后面

    参考文章列表:

    Linux ps命令详解:查看正在运行的进程

    Linux top命令详解:持续监听进程运行状态

    Linux 查看端口占用情况

    如何在Ubuntu上开启SSH服务 并开机启动

  • 相关阅读:
    【RuoYi-Vue-Plus】学习笔记 42 - Easy Excel(二)Excel 2007(*.xlsx)导入流程分析(源码)
    【CTF】jarvisoj_fm 1
    MySQL分库分表
    Conda Channel 介绍与配置
    Keil 厂商DFP pack实现原理
    入门力扣自学笔记112 C++ (题目编号899)
    【贝叶斯分析】计算机科学专业博士作业一
    [游戏开发][Shader]GLSLSandBox转Unity-CG语言
    五种多目标优化算法(MOAHA、MOGWO、NSWOA、MOPSO、NSGA2)性能对比(提供MATLAB代码)
    实战PyQt5: 134-QChart图表之折线图
  • 原文地址:https://blog.csdn.net/wang0907/article/details/127927941