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
posted @ 2019-09-19 05:32  silencio。  阅读(263)  评论(0编辑  收藏  举报