admin管理员组文章数量:1122853
什么是 vim?
所有的 Unix Like 系统都会内建 vi 文书编辑器,其他的文书编辑器则不一定会存在。
但是目前我们使用比较多的是 vim 编辑器。
vim 具有程序编辑的能力,可以主动的以字体颜色辨别语法的正确性,方便程序设计。
Vim是从 vi 发展出来的一个文本编辑器。代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。
简单的来说, vi 是老式的字处理器,不过功能已经很齐全了,但是还是有可以进步的地方。 vim 则可以说是程序开发者的一项很好用的工具。
vi/vim 的使用
基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode),输入模式(Insert mode)和底线命令模式(Last line mode)。 这三种模式的作用分别是:
命令模式:
用户刚刚启动 vi/vim,便进入了命令模式。
此状态下敲击键盘动作会被Vim识别为命令,而非输入字符。比如我们此时按下i,并不会输入一个字符,i被当作了一个命令
移动光标
w(e) 移动光标到下一个单词
b 移动到光标上一个单词
数字0 移动到本行开头
$ 移动光标到本行结尾
H 移动光标到屏幕首行
M 移动到光标到屏幕的中间一行
L 移动光标到屏幕的尾行
gg 移动光标到文档的首行
G 移动光标到文档尾行
ctrl + f 下一页
ctrl + b 上一页
`. 移动光标到上一次的修改行
查找
/chaoge 在整篇文档中搜索chaoge字符串,向下查找 ?chaoge 在整篇文档中搜索chaoge字符串,向上查找 * 查找整个文档,匹配光标所在的所有单词,按下n查找下一处,N上一处 # 查找整个文档,匹配光标所在的所有单词,按下n查找下一处,N上一处 gd 找到光标所在单词匹配的单词,并停留在非注释的第一个匹配上
% 找到括号的另一半!!
复制,删除,粘贴
yy 拷贝光标所在行
dd 删除光标所在行
D 删除当前光标到行尾的内容
dG 删除当前行到文档尾部的内容
p 粘贴yy所复制的内容
x 删除光标所在的字符
u 撤销上一步的操作
数字与命令
3yy 拷贝光标所在的3行
5dd 删除光标所在5行
输入模式
在命令模式下按下字母i即可进入输入模式,可以编写代码啦。
底线命令模式
在命令模式下输入冒号(英文的:),就进入了底线命令模式,在底线命令模式下可以输入单个或多个字符的命令,常用命令有:
:q! 强制退出 :wq! 强制写入退出
:set nu 显示行号
:数字 调到数字那行
随时按下esc可以退出底线命令模式
vim工作模式
vim按键
移动光标
移动光标的方法
h 或 向左箭头键(←) 光标向左移动一个字符
j 或 向下箭头键(↓) 光标向下移动一个字符
k 或 向上箭头键(↑) 光标向上移动一个字符
l 或 向右箭头键(→) 光标向右移动一个字符
向下移动5行 5j
向右移动10字符 10l
n(space) 按下数字n,例如10,然后按下空格,光标会向右移动10个字符
底线命令
:! command 暂时离开vim指令模式,执行command的结果 例如 :!ip a 临时看一下ip信息,然后可以回到vim
:set nu 显示vim行号
:set nonu 取消行号
更多nb的vim用法请看菜鸟教程:http://www.runoob/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
转载于:https://wwwblogs/bubu99/p/11546588.html
本文标签: vim
版权声明:本文标题:Vim使用 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/biancheng/1724510327a890387.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论