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目录下才是文件