Vim使用

什么是 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.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

转载于:https://www.cnblogs.com/bubu99/p/11546588.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值