• Linux-Vim


    什么是 vim?

    所有的 Unix Like 系统都会内建 vi 文书编辑器,其他的文书编辑器则不一定会存在。

    但是目前我们使用比较多的是 vim 编辑器。

    vim 具有程序编辑的能力,可以主动的以字体颜色辨别语法的正确性,方便程序设计。

    Vim是从 vi 发展出来的一个文本编辑器。代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。

    简单的来说, vi 是老式的字处理器,不过功能已经很齐全了,但是还是有可以进步的地方。 vim 则可以说是程序开发者的一项很好用的工具。

    vi/vim 的使用

    基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode 普通模式)输入模式(Insert mode 编辑模式)底线命令模式(Last line mode末行模式)。 这三种模式的作用分别是:

    vim工作模式

    VIM模式三种模式介绍

    1.普通模式: 主要是控制光标移动,可对文本进行复制、粘贴、删除等工作。
    使用vim filename 编辑一个文件时,一进入该文件就是普通模式了。
    在这个模式下,可以进行光标移动、复制、删除、粘贴操作。

    2.编辑模式: 主要进行文本内容编辑和修改
    从普通模式进入编辑模式,只需你按一个键即可(i, I, a, A, o, O)
    当进入编辑模式时,会在屏幕的最下一行会出现 “INSERT”标记
    从编辑模式回到普通模式只需要按键盘左上方的 ESC 键即可。

    3.末行模式: 主要用于保存或退出文本。
    在普通模式下,输入 “:” 或者 “/“ 即可进入命令模式。
    在命令该模式下,可进行的操作有,显示行号、搜索、替换、保存、退出。

    小结: vim编辑打开文件整体流程如下:
    1.默认打开文件处于普通模式
    2.从普通模式切换至编辑模式需要使用a、i、o
    3.编辑模式修改完毕后需要先使用ECS返回普通模式
    4.在普通模式输入”:”或”/“进入命令模式,可实现文件的保存与退出。
    PS: 在vim中,无法直接从编辑模式切换到命令模式。

    1.普通模式

    #1.命令光标跳转
    G       #光标跳转至末端
    gg      #光标跳转至顶端
    Ngg     #光标跳转至当前文件内的N行
    $       #光标跳转至当前光标所在行的尾部
    ^或者0     #光标跳转至当前光标所在行的首部
    
    #2.文件内容较多
    ctrl+f  #往下翻页(行比较多)
    ctrl+b  #往上翻页
    
    
    #3.复制与粘贴
    yy      #复制当前光标所在的行
    5yy     #复制当前光标以及光标向下4行
     
    p(小写)   #粘贴至当前光标下一行   
    P(大写)   #粘贴至当前光标上一行
    
    
    #4.删除、剪贴、撤销  
    dd      #删除当前光标所在的行   
    4dd     #删除当前光标所在的行以及往下的3行
    dG      #删除当前光标以后的所有行
    D       #删除当前光标及光标以后的内容  
    x       #删除当前光标标记往后的字符
    X       #删除当前光标标记往前的字符
    dd & p  #剪贴、先删除dd(number dd),后粘贴p
    u       #撤销上一次的操作
    
    
    #5.替换
    r       #替换当前光标标记的单个字符
    R       #进入REPLACE模式, 连续替换,ESC结束

    2.编辑模式(从普通模式进入到编辑模式)

    i   #进入编辑模式,光标不做任何操作
    a   #进入编辑模式,将当前光标往后一位
    o   #进入编辑模式,并在当前光标下添加一行空白内容
    
    
    I   #进入编辑模式,并且光标会跳转至本行的头部
    A   #进入编辑模式,将光标移动至本行的尾部
    O   #进入编辑模式,并在当前光标上添加一行空白内容

    3.命令模式,主要用于搜索, 保存, 退出文件。

    #1.文件保存与退出
    :w      保存当前状态
    :w!     强制保存当前状态
    :q      退出当前文档(文档必须保存才能退出)
    :q!     强制退出文档不会修改当前内容
    :wq     先保存,在退出
    :wq!    强制保存并退出
    :x      先保存,在退出
    ZZ      保存退出, shfit+zz
    :number 跳转至对应的行号
    :set nu 显示行号
    :set nonu 不显示行号
    
    #2.文件内容查找
    /string #需要搜索的内容(查找)
    n       #按搜索到的内容依次往下进行查找
    N       #按搜索到的内容依次往上进行查找
    
    
    #3.文件内容替换
    :1,5s#sbin#test#g   #替换1-5行中包含sbin的内容为test
    :1,5s#sbin#test#   #只替换1-5行中第一个包含sbin的内容为test
    :%s#sbin#test#g     #替换整个文本文件中包含sbin的替换为test
    :%s#sbin#test#gc    #替换内容时时提示是否需要替换
    
    
    #4.文件内容另存
    :w /root/test.txt  #将所有内容另存为/root/test.txt文件中
    
    
    #5.文件内容读入
    :r  /etc/hosts  #读入/etc/hosts文件至当前光标下面
    :5r /etc/hosts  #指定插入/etc/hosts文件至当前文件的第五行下面

    4.视图模式(从普通模式进入视图模式),主要进行批量操作

    ctrl+v  进入可视块模式,选中需要注释的行
        1.插入:按shift+i进入编辑模式,输入#,结束按ESC键
        2.删除:选中内容后,按x或者d键删除
        3.替换:选中需要替换的内容, 按下r键,然后输入替换后的内容
    
    
    shift+v 进入可视行模式,选中整行内容
        1.复制:选中行内容后按y键及可复制。
        2.删除:选中行内容后按d键删除。

    VIM扩展知识

    1.环境变量临时生效

    :set nu             #显示行号
    :set ic             #忽略大小写, 在搜索的时候有用
    :set ai             #自动缩进
    :set list           #显示制表符(空行、tab键)
    :set no[nu|ic|ai…]  #取消临时设定的变量

    2.环境变量永久生效。~/.vimrc 个人环境变量(优先级高) /etc/vimrc 全局环境变量

    # vim  ~/.vimrc #当下次再打开文件自动显示行号并忽略大小写
    set nu
    set ic
    
    #如果个人vim环境没有配置, 则使用全局vim环境变量配置。
    #如果个人vim环境和全局环境变量产生冲突, 优先使用个人vim环境变量。

    3.如何同时编辑多个文件

    vim -o file1 file2  #水平分割
    vim -O file1 file2  #垂直分割
    
    #ctrl+ww 文件间切换

    4.相同文件之间差异对比,通常用于对比修改前后差异

    # diff      #文件对比   
    # vimdiff   #以vim方式打开两个文件对比,高亮显示不同的内容

    5.如果VIM非正常退出 (ctrl+z)挂起或强制退出终端没关闭VIM后

    #假设打开filename文件被以外关闭,需要删除同文件名的.swp文件即可解决
    # rm -f .filename.swp

    更多nb的vim用法请看菜鸟教程:http://www.runoob.com/linux/linux-vim.html

    du -sh /etc/ du看目录多大
    ll |wc -l 查看文件数量
    ls -i /etc/passwd.bak -i查看文件的inode编号
    ls -di /etc/passwd/ 查看目录的inode编号
    vim /etc/sysconfig/selinux (开机不检索)
    --->SELINUX=enforcing 改成 SELINUX=disabled
    echo 123 | passwd --stdin root 
    --stdin代表接受输入(只有root可以用,就不需要两次输密码了)
    :set nu 设置行号
    !cat 执行上一次的cat命令
    ctrl+c结束当前命令
    ===日志切割
    mv access.log accsee.log1
    touch access.log
    tail -f a.txt 动态监测日志
    tail -f /var/log/messages 查看系统日志
    语法格式:命令 【选项】 【参数】
    mv * /tmp/bak/ 就是移动的时候不要提示,比如是否覆盖。。 
    /mnt/ 
    /opt 
    /media/ 
    /tmp/ 
    /bin存放常用的可执行文件 
    /sbin存放系统的可执行文件 
    /home /dev 设备文件目录device /etc 配置文件目录 
    相对路径: cd.. d3/a.txt 等价于../d3/a.txt 绝对路径:(必须以/开头) 
    /root/d3/a.txt 
    #root用户 $普通用户 
    命令 选项(描述命令) 参数(作用于谁) 
    dhcp服务 自动获取ip 
    :set nu 设置行号 
    init 0 关机 
    into 6 重启 
    shutdown -h now立即关机 
    tty查看当前终端 
    who 
    whoami 
    date 
    date 月日时分年 
    cal 
    cal 3 1990 
    clear 
    ctrl+l 
    passwd 没有跟参数就是修改当前用户密码 
    passwd tom 只有root才可以 
    echo 123 | passwd --stdin root --stdin代表接受输入(只有root可以用,就不需要两次输密码了) 
    man passwd 
    passwd --help 
    exit 
    Ctrl+shift+n 开启一个新的终端 
    写了部分命令可用 tab键补齐,tab键查看 
    q退出 
    Ctrl+alt+f[1-6] 切换终端 
    Ctrl+alt 鼠标退出虚拟机
     > 左边的内容覆盖到右边 
    cat /etc/passwd > new.txt 
    只要左边有输出就可以,右边就是文件名,没有文件会自动新建 
    cat a.txt b.txt > c.txt 
    左边两个文件都写到右边 
    echo 'hello' > new.txt 
    >> 左边的内容追加到右边 
    wc -l /etc/passwd wc -l 看这个文件多少行 
    cat /etc/passwd | wc -l 管道 上一个命令的结果当做下一个命令的参数 
    cat a.txt b.txt | wc -l 
    cd 
    cd - 切换上一次所在目录 
    cd ~ 当前用户的家目录 root用户的家目录是/root 
    ls 
    pwd 
    history -c 清除之前的命令 
    history 后 !行号再次执行这一行的命令 
    reboot 重启 
    useradd tom 
    passwd tom 
    useradd -u 1000 -g root -d /home/sb -c miaoshu -s /bin/bash tom 
    -u:用户的UID 
    -g:用户的GID 
    -G:将一个用户加入到指定的群组中 
    -d:用户的家目录 
    -c:用户的备注信息 
    -s:用户所用的shell 
    /bin/bash就说明这个用户可以登录操作系统,sbin/nologin不能登录操作系统,
    uid为0的就代表有root权限 
    groupadd group_new 
    touch /test/b.txt 
    touch /test/b.txt a.txt 
    touch /test/{1..9}.txt 
    mkdir /test mkdir -p /dir1/dir2/dir3 -p递归建目录 
    ln -s anaconda-ks.cfg test 新建快捷方式anaconda-ks.cfg -s源 
    cp -r /home/tom/.[!.]* /home/sb/ -r递归的拷贝 
    cp -a /home/tom/.[!.]* /home/sb/ -a文件属性一起拷贝 
    大文件备份先打包,减少编号。 
    rm -f /dir1/a.txt -f删文件 -f不提示直接删 
    rm -r /dir1/dir2/ -r删目录 
    rm -rf /dir1/ id tom ll a.txt 
    ll -d /test/ -d查看目录 
    ls -a /test/ -a查看隐藏文件 点开头的文件都是隐藏文件 
    ls -l /test/ -l 文件长信息 
    ls -l 等于 ll ls *.txt 查看所有txt结尾的文件 
    ls 
    ls . 
    ls / 是一样的效果 
    vim a.txt less /etc/passwd 上下键翻 
    more /etc/passwd 回车翻 百分百 
    cat a.txt cd /test/ 
    cd 直接切换到家目录 
    cd ~ 切换到当前用户的家目录 
    cd ..返回上一级目录 
    cd – 返回上一次存在的目录 
    pwd 
    head -2 /opt/a.txt 
    cat /opt/a.txt 
    tail -2 /etc/passwd 
    tail -f /etc/passwd -f 动态看 
    echo 'hello world' 
    echo 'hello world' >> /opt/a.txt alias 
    ll 
    alias ll='ls -l --color=auto' 
    ==目录 
    mkdir /a 
    mkdir /a/b 
    mkdir -p /e/f/g -p递归建目录 
    ll ls -d /a 
    ls -ld /home/tom 
    --->drwx------. 14 tom tom 4096 12月 13 18:56 /home/tom 
    ls -la 
    ls --help|less 
    然后按q退出 
    mv /a/b /a/newb 剪切 
    cp /a/b /tmp/newb 
    rm -rf /a/newb 
    ===文件 
    wc -l /etc/passwd wc -l 看这个文件多少行 
    cat /etc/passwd | wc -l 管道 上一个命令的结果当做下一个命令的参数 
    touch a.txt 
    cp a.txt /tmp/a.txt 
    cat a.txt 
    less a.txt 
    more a.txt 
    head -n 2 a.txt 
    tail -n 2 a.txt 
    tail -f a.txt 动态监测日志 
    mv /tmp/test/a.txt /tmp/test/newa.txt 改名 
    rm -rf newa.txt 
    echo '123123' > a.txt 
    echo '123123' >> a.txt
    
    ===/etc/group和/etc/gshadow groupadd group1
    groupmod -g 1205 group1 -g修改群组的GID
    groupmod -n newgroup1 group1 -n修改群组的名称
    groupdel group1
    
     
    ===用户
    su - tom 切换用户就是往用户的家目录下面走,所以更改了用户的权限就需要退出再登录才能看到新权限
    id tom
    useradd tom
    usermod -G wheel sbtom
    usermod -L tom 锁住
    usermod -U tom 解锁
    usermod –d /home/sb tom 只是修改了passwd文件,对应的家目录没有修改
    usermod -aG group_new tom -G覆盖 -a追加
    userdel -r tom -r删除用户的同时删除用户的家目录及其邮箱
    
    mkdir /home/sb
    --->useradd -u 1009 -g root -d /home/sb -c miaoshu -s /bin/bash sbtom
    -u:用户的UID 
    -g:用户的GID(主组) 
    -G:将一个用户加入到指定的群组中(附加组)
    -d:用户的家目录 
    -c:用户的备注信息 
    -s:用户所用的shell
    /bin/bash就说明这个用户可以登录操作系统,sbin/nologin不能登录操作系统,uid为0的就代表有root权限
    
    
    tail -1 /etc/passwd
    --->sbtom:x:1009:0:miaoshu:/home/sb:/bin/bash
    设置的sbtom初始组是root(也就是主组) 就不需要在root组里面显示sbtom成员
    cat /etc/group 
    --->root:x:0: 而不是root:x:0:sbtom 附加组才显示,主组不显示 ######所以第四段内容显示的是附加组
    id sbtom
    --->uid=1009(sbtom) gid=0(root) 组=0(root)
    
    passwd tom
    echo 123|passwd --stdin tom
    id tom
    --->uid=1000(tom) gid=1000(tom) 组=1000(tom),10(wheel)
    cat /etc/passwd 
    --->root:x:0:0:root:/root:/bin/bash
    --->bin:x:1:1:bin:/bin:/sbin/nologin
    --->tom:x:1000:1000:tom:/home/tom:/bin/bash
    cat /etc/shadow
    --->tom:$6$r40Mbr24$NrQqNjtZl0tbQVEP.eu1Lo1AQx9.asyEFpNSbMKObho.Ph/WBnDMrjEng2RA10GlRD5bA0R..oBFoxhSjIrZq1:17878:0:99999:7:::
    cat /etc/group
    --->wheel:x:10:tom,tom2
    --->tom:x:1000:
    cat /etc/gshadow
    --->tom:!::
    ll /var/spool/mail/tom
    --->-rw-rw----. 1 tom mail 0 12月 13 18:54 /var/spool/mail/tom
    
      
    模拟新建用户
    1.vim /etc/passwd
    2.vim /etc/shadow
    3.vim /etc/group
    4.vim /etc/gshadow
    5.touch /var/spool/mail/tom 
    chown -R tom.mail /var/spool/mail/tom 
    6.mkdir /home/tom 那个用户建立的文件,该文件的属主和属组就属于它
    cp -r /etc/skel/.[!.]* /home/tom
    chown -R 属主.属组 参数 -R递归修改
    chown -R tom.tom /home/tom/
    
    #############
    /etc/passwd文件的功能:存储所有用户的相关信息。
    a) 第1个字段(列)记录的是这个用户的名字(在创建用户时root用户起的)。
    b)    第2个字段(列)如果是x,表示该用户登录Linux系统时必须使用密码;如果为空,则该用户在登录时无须提供密码。
    c)    第3个字段(列)记录的是这个用户的uid。
    d)    第4个字段(列)记录的是这个用户所属群组的gid。
    e)    第5个字段(列)记录的是有关这个用户的注释信息(如全名或通信地址)。
    f)    第6个字段(列)记录的是这个用户的家目录的路径。
    g)    第7个字段(列)记录的是这个用户登录后,第一个要执行的进程。
    
    /etc/shadow文件的功能:存储所有用户的密码,每一个用户占用一行记录。
    a) 第1个字段(列)是用户名。
    b)    第2个字段(列)是密码,这个密码是经过MD5加密算法加密过的密码。
    
    /etc/group文件的功能:存放了Linux系统中所有群组的信息。
    a)    第1个字段是这个群组的名字。
    b)    第2个字段中的x表示这个群组在登录Linux系统时必须使用密码。
    c)    第3个字段记录的是这个群组的gid。
    d)    第4个字段记录的是这个群组里还有哪些群组成员(附加组才显示,主组不显示)。
    
    /etc/gshadow文件的功能:存储群组密码,每一个群组占用一行记录。
    ###########
    
    权限
    
    那个用户建立的文件/目录,该文件/目录的属主和属组就属于它。
    
    root用户也称为超级用户,它可以完全不受限制地访问任何用户的账户和所有文件及目录。
    对文件:
    文件类型分类: -:普通文件d:目录l:软连接就是快捷方式b:设备p:管道文件
    执行文件的方法:sh 文件路径 . 文件路径 ./ 文件路径 bash 文件路径
    ll a.txt
    --->-rw-r--r--. 1 root root 157 12月 13 22:54 a.txt
    权限信息(属主u 属组g 其他o). 硬链接数 属主 属组 文件大小 文件创建时间 文件名
    权限后面的点说明该文件是在selinux开启的情况下创建的,是一个安全标志
    
    
    有执行权限必须得有读的权限
    
    chmod u=rx,g=x,o=rwx a.txt r->4 w->2 x->1
    chmod u-x a.txt
    chmod u+w a.txt
    chmod u=--- a.txt
    chmod u=- a.txt 简写为一个-
    chmod 517 a.txt
    chmod 777 *
    
    chmod 777 *  -R       -R递归修改
    
    对文件:
    
    ll -a 
    
    ll -a /home/tom/ 查看tom这个目录下文件的权限
    r:能看内容 目录得有x权限
    w:修改内容
    x:执行文件
    
    对目录:
    
    ll -d 
    
    ll -d /home/tom/ 查看tom这个目录的权限
    
    r:可以ls该目录下的子文件名,子目录名 
    w:可以在该目录下新建,删除,重命名子文件。
    x:相当于双击也就是可以cd到该目录下
    要有w的权限必须要先能cd进去也就是必须得有x权限
    要有r的权限必须要先能cd进去也就是必须得有x权限
    
    修改属主.属组
    chown -R 属主.属组 参数 -R递归修改
    chown -R tom.tom /home/tom/ 这样tom登录以后才能在tom家目录下新建文件等操作
    chown -R tom.tom a.txt
    chown 属主 参数 
    chown .属组 参数
    
     
    
    归档打包tar==压缩 gzip bzip2
    tar -cvf new.tar a.txt b.txt c.txt -c创建 -f打包文件名 -v打包文件的详细信息
    tar -tf new.tar -t查看这个包里面有什么文件
    tar -xvf new.tar x解包
    tar -xvf new.tar -C /opt/ -C指定解包目录
    
    gzip test.txt
    ll test.txt.gz
    ll test.txt.bz2
    gunzip test.txt.gz
    bunzip2 test.txt.bz2
    tar cvzf new.tar.gz a.txt b.txt c.txt z就是gzip
    
    带tmp目录
    tar cvzf new.tar.gz /tmp/ 打包压缩tmp里面的所有文件,带tmp目录
    mkdir /opt
    tar xvf new.tar.gz -C /opt/ 解包,就不需要压缩了 解压出来是带tmp目录,tmp目录下才是文件
    
    不带tmp目录 (先要cd进去)
    cd /tmp/
    tar cvzf new.tar.gz * 打包压缩tmp里面的所有文件,不带tmp目录
    mkdir /opt
    tar xvf new.tar.gz -C /opt/ 解包,就不需要压缩了 解压出来是不带tmp目录,tmp目录下才是文件
    View Code
  • 相关阅读:
    系统测试的策略
    POJ1611(并查集)
    POJ2752(KMP)
    POJ3176(DP)
    HDU2579(BFS)
    HDOJ1175(BFS)
    HDOJ1242(BFS)
    HDOJ1180(BFS)
    HDOJ1372(BFS)
    HDOJ2717(BFS)
  • 原文地址:https://www.cnblogs.com/bubu99/p/11546588.html
Copyright © 2020-2023  润新知