################vim的用法#################
1.命令模式
设定
vim /etc/vimrc
:set nu|nonu ###行号的显示|关闭
:set mouse=a ####设定鼠标可以操作光标位置
:set cursorline ####下标线显示
永久显示可在vim /etc/vimrc中输入以上命令
:help ####查看vim的用法,:q退出帮助
ctrl +v ####高亮选择模式,可以选者一片区域操作
u ####恢复到未操作之前
ctrl + r ####恢复到操作之后
2.批量添加字符
ctrl + v 选中要加字符所在的位,按I键,在加入想要加入的字符,按esc
例:
3.替换字符
:%s/原有字符/替换后的字符 ###只替换每一行中出现的第一个原有字符
:%s/原有字符/替换后字符/g ###替换所有要替换的字符
:%s/\t//g ###去掉全文中所有tab键。“\t”表示tab
:%s/^\ *//g ###去掉每行开头的空格“^\ *”表示行首的空格
:%s/^\#\ */#/g ###去掉全文#后的空格
4.分屏功能
ctrl+w s ####上下分屏
ctrl+w v ####左右分屏
ctrl+w c ###撤销光标所在屏幕
ctrl+w 上|下|左|右 ####移动光标到指定的屏幕中
:sp file2 ###同时编辑当前文件和file2
5.搜索关键字
:/关键字
n向下匹配
N向上匹配
6.vim光标的移动
在命令模式下
:数字 ####移动到指定的行
G ####到文件的最后一行
gg ####到文件的首行
####################字符的管理#########
1.字符的复制
yl ####复制一个字母
y3l ####复制三个字母
yw ####复制一个单词
y3w ####复制三个单词
yy #####复制一行
y3y #####复制三行
p #####复制完成后按“p”键粘贴
2.字符的删除
dl ######删除一个字母
d3l ######删除三个字母
dw ######删除一个单词
d3w ######删除三个单词
dd ######删除一行
d3d ######删除三行
3.字符的剪切
cl #####剪切一个字母
c3l ####剪切三个字母
cw ####剪切一个单词
c3w ####剪切三个单词
cc ####剪切一行
c3c ####剪切三行
esc----> p ####剪切后进入到插入模式,在执行粘贴动作时一定要退出插入模式
4.vim的插入模式
i ###光标坐在位置插入字符
I ###光标所在行行首插入
a ###光标所在字符的下一位插入
A ###光标所在行行尾插入
o ###光标所在行的下一行
O ###光标所在行的上一行
s ####删除光标所在字符插入
S ###删除光标所在行插入
5.vim的退出模式
在命令模式下输入
:q ###退出,在未对文件作任何修改的时候可以用
:q! ###强制退出
:wq ###退出保存
:wq! ###强制退出保存
6
###############vimtutor##########:
vimtutor是vim的说明工具
用:q退出此工具
###############图形中的文本编辑器gedit##########
crtl+n ##新建窗口
ctrl+s ##保存文件
ctrl+o ##打开文件
ctrl+x ##剪切
ctrl+v ##粘贴
ctrl+c ##复制
对于giedit软件帮助的查看可以用
yelp help:gedit
####################用户如何存在与系统当中######################
/etc/passwd ###用信息文件
用户名字:用户密码:用户uid:用户gid:用户说明:用户加目录:用户使用的shell
/etc/shadow ###用户认证信息
用户名称:密码:密码使用天数:最短有效期:密码最长有效期:密码警告期:密码非活跃期:密码到期日:
/etc/group ####用户组信息
用户组名称:用户组密码:用户组id:附加用户成员
/home/username ####用户加目录
/etc/skel/.* ####用户的基本信息配置
##########################用户操作命令################
id ###查看用户信息
id -u ###用户uid
-g ###用户gid
-a ###用户所有信息
-G ###用户所在所有的id
-un ###用户名字
-gn ###用户初始组名称
-Gn ###用户所在所有组名称
su - username ###切换用户用户所使用的环境
echo $PATH ###查看当前用户的用户环境
echo $USER ###显示当前用户的信息
useradd ###新建用户
-u ###指定用户的uid
-g ###指定用户初始组,这个组一定要存在
-G ###指定附加组,组同样要存在
-c ###用户说明
-d ###指定用户加目录
-s ###指定用户使用的shell,shell种类参看/etc/shells
userdel -r ####删除用户
groupadd -g ###新建组,-g表示指定组的id
groupdel ###删除组
echo $PATH ######查看用户环境
echo $USER #####查看当前用户信息
查看用户建立或管理过程使用的命令
watch -n 1 'tail -3 /etc/passwd /etc/group;echo ==== ;ls -l /home;echo ===;ls -l /mnt'
usermod -u #####改变用户uid
-g #####改变用户初始组
-G #####改变用户附加组
-aG ######增加用户附加组
-d ######改变用户加目录信息
-md ######改变用户加目录信息和加目录名称
-s ######改变用户的shell
-c ######改变用户的说明
-L ######冻结用户
-U ######解锁用户
###################用户权限下放(sudo)###################
权限下放动作的配置文件
/etc/sudoers
这个文件用visudo命令编辑
文件内容写法:
授权目标用户主机名称=(授权用户得到的新用户身份)授权用户执行命令
示例:
###test用户能在localhost主机执行useradd(要test密码)
test localhost=(root) /usr/sbin/useradd
###test用户能在localhost主机执行useradd(不要要test密码)
test localhost=(root) NOPASSWD: /usr/sbin/useradd
第99行输入:
test desktop28.example.com=(root) NOPASSWD: /user/sbin/useradd /user/sbin/userdel
###测试结果:
su - test
sudo useradd username
##########################密码期限更改###################
chage -d 0 ####秘密使用了多久,如何设定为0表示用户登陆系统前必须更改密码
-m ####最短有效期
-M ####最长有效期
-W ####警告期
-I ####非活跃期
-E ####到期时间格式yyyy-mm-dd
监控命令:watch -n 1 tail -n 1 /etc/shadow
#######################################################################
1.文件属性查看
ls -l filename
-rw-rw-r-- 1 kiosk kiosk 0 Oct 2 17:05 file
文件类型文件权限 文件副本个数 文件所有人 文件所有组 大小 最后一次被修改的时间 名字
2.查看目录属性
ls -ld directoy
drwxr-xr-x 3 kiosk kiosk 33 Aug 27 09:47 directory
类型权限 子目录个数 目录所有人 目录所有组 子文件属性大小 目录中内容变化时间 目录名字
3.文件用户组的更改
chown 用户名称文件 ####更改文件所有人
chgrp 组名称文件 ####更改文件所有组
chown -R 用户目录 #####更改目录本身以及目录中的子文件的所有人
chgrp -R 组名目录 #####更改目录本身以及目录中的子文件的所有组
4.权限的识别
ls -l 中2-10字符为文件权限
rwx r-x r-x
u g o
用户权限 组成员权限 其他用户权限
权限种类
r
r权限针对文件,表示可以查看文件内容
r权限针对目录,表示可以ls 查看目录中存在的文件名称
w
w权限针对文件,表示可以更改文件的内容
w权限针对目录,表示是否可以删除目录中的子文件或者子目录
x
x权限对于文件,表示是否可以开启文件当中记录的程序
x权限对于目录,表示是否可以进入目录中
u=rwx=7|g=rwx=7|o=rwx=7
r=4
w=2
x=1
-=0
7=rwx,6=rw-,5=r-x,4=r--,3=-wx,2=-w-,1=--x,0=---
5.文件的默认权限
umask ##显示系统预留权限值
vim /etc/bashrc 71行是普通用户的更改,73是超级用户的更改
vim /etc/profile 60行是普通用户的更改,62是超级用户的更改
source /etc/bashrc ##刷新bash配置
source /etc/profile ##刷新系统配置
6.特殊权限
stickyid ###强制位
o+t ###之针对目录,当一个目录上有t权限时,这个目录中的文件只能被文件拥有者删除
t=1
chmod o+t directroy
chmod 1777 directory
sgid ###粘制位
g+s ##针对目录,在目录中创建的文件都自动归属到目录所在组,针对二进制文件,文件内记录的程序在执行时和执行者的组身份没有关系,而是以二进制文件的所有组的身份执行的
chmod g+s file|directory
chmod 2777 file|directory
suid ###冒险位
u+s ###针对文件,文件记录动作在执行时是一文件所有人身份执行的,与是谁发起的无关
chmod u+s file
chmod 4777 fileg+s
##############################################
####1.进程定义####
进程就是cpu未完成的工作
####2.ps命令####
ps
a ##关于当前环境的所有进程
x ##与当前环境无关的所有进程
f ##显示进程从属关系
e ##显示进程调用环境工具的详细信息
l ##长列表显示进程的详细信息
u ##显示进程的用户信息
ps ax -o %cpu,%mem,user,group,comm,nice,pid ##指定显示进程的某些信息
%cpu ##显示进程cpu负载
%mem ##显示进程内存负载
user ##进程用户
group ##进程组
comm ##进程名称
nice ##进程优先级
pid ##进程的id
ps ax -o %cpu,comm --sort <+|-%cpu > <+|-%mem> ##按照进程信息排序
+ ##正序
- ##倒序
%cpu ##cpu负载排序
%mem ##内存负载
####3.进程优先级####
1.进程的优先级范围
-20~19
2.优先级查看
ps ax -o pid,nice,comm
3.指定某个优先级开启进程
nice -n 优先级数字进程名称
nice -n -5 vim & ####开启vim并且指定程序优先级为-5
4.改变进程优先级
reince -n 优先级数字进程pid
renice -n -0 3793 #####改变3793进程的优先级为0
####4.环境中进程的前后台调用####
jobs ##查看被打入环境后台的进程
ctrl+z ##把占用终端的进程打入后台
fg ##把后台进程调回前台
bg ##把后台暂停的进程运行
comm & ##让命令直接在后台运行
####5.进程信号####
1.常用信号等级
1 ##进程重新加载配置
2 ##删除进程在内存中的数据
3 ##删除鼠标在内存中的数据
9 ##强行结束单个进程
15 ##正常关闭进程
18 ##运行暂停的进程
19 ##暂停某个进程
20 ##把进程打入后台
man 7 signal ##查看信号详细信息
kill -信号 进程pid
killall -信号进程名字
pkill-u student -信号
SIGHUP 终止进程 终端线路挂断
SIGINT 终止进程 中断进程
SIGQUIT 建立CORE文件终止进程,并且生成core文件
SIGILL 建立CORE文件 非法指令
SIGTRAP 建立CORE文件 跟踪自陷
SIGBUS 建立CORE文件 总线错误
SIGSEGV 建立CORE文件 段非法错误
SIGFPE 建立CORE文件 浮点异常
SIGIOT 建立CORE文件 执行I/O自陷
SIGKILL 终止进程 杀死进程
SIGPIPE 终止进程 向一个没有读进程的管道写数据
SIGALARM 终止进程 计时器到时
SIGTERM 终止进程 软件终止信号
SIGSTOP 停止进程 非终端来的停止信号
SIGTSTP 停止进程 终端来的停止信号
SIGCONT 忽略信号 继续执行一个停止的进程
SIGURG 忽略信号 I/O紧急信号
SIGIO 忽略信号 描述符上可以进行I/O
SIGCHLD 忽略信号 当子进程停止或退出时通知父进程
SIGTTOU 停止进程 后台进程写终端
SIGTTIN 停止进程 后台进程读终端
SIGXGPU 终止进程 CPU时限超时
SIGXFSZ 终止进程 文件长度过长
SIGWINCH 忽略信号 窗口大小发生变化
SIGPROF 终止进程 统计分布图用计时器到时
SIGUSR1 终止进程 用户定义信号1
SIGUSR2 终止进程 用户定义信号2
SIGVTALRM 终止进程 虚拟计时器到时
1) SIGHUP
本信号在用户终端连接(正常或非正常)结束时发出, 通常是在终端的控
制进程结束时, 通知同一session内的各个作业, 这时它们与控制终端
不再关联.
2) SIGINT
程序终止(interrupt)信号, 在用户键入INTR字符(通常是Ctrl-C)时发出
3)
SIGQUIT 和SIGINT类似, 但由QUIT字符(通常是Ctrl-)来控制. 进程在因收到
SIGQUIT退出时会产生core文件, 在这个意义上类似于一个程序错误信
号.
4)
SIGILL 执行了非法指令. 通常是因为可执行文件本身出现错误, 或者试图执行
数据段. 堆栈溢出时也有可能产生这个信号.
5)
SIGTRAP 由断点指令或其它trap指令产生. 由debugger使用.
6)
SIGABRT 程序自己发现错误并调用abort时产生.
6)
SIGIOT 在PDP-11上由iot指令产生, 在其它机器上和SIGABRT一样.
7)
SIGBUS 非法地址, 包括内存地址对齐(alignment)出错. eg: 访问一个四个字长
的整数, 但其地址不是4的倍数.
8)
SIGFPE 在发生致命的算术运算错误时发出. 不仅包括浮点运算错误, 还包括溢
出及除数为0等其它所有的算术的错误.
9)
SIGKILL 用来立即结束程序的运行. 本信号不能被阻塞, 处理和忽略.
10)
SIGUSR1 留给用户使用
11)
SIGSEGV 试图访问未分配给自己的内存, 或试图往没有写权限的内存地址写数据.
12)
SIGUSR2 留给用户使用
13)
SIGPIPE Broken pipe
14)
SIGALRM 时钟定时信号, 计算的是实际的时间或时钟时间. alarm函数使用该
信号.
15)
SIGTERM 程序结束(terminate)信号, 与SIGKILL不同的是该信号可以被阻塞和
处理. 通常用来要求程序自己正常退出. shell命令kill缺省产生这
个信号.
17)
SIGCHLD 子进程结束时, 父进程会收到这个信号.
18)
SIGCONT 让一个停止(stopped)的进程继续执行. 本信号不能被阻塞. 可以用
一个handler来让程序在由stopped状态变为继续执行时完成特定的
工作. 例如, 重新显示提示符
19)
SIGSTOP 停止(stopped)进程的执行. 注意它和terminate以及interrupt的区别:
该进程还未结束, 只是暂停执行. 本信号不能被阻塞, 处理或忽略.
20)
SIGTSTP 停止进程的运行, 但该信号可以被处理和忽略. 用户键入SUSP字符时
(通常是Ctrl-Z)发出这个信号
21)
SIGTTIN 当后台作业要从用户终端读数据时, 该作业中的所有进程会收到SIGTTIN
信号. 缺省时这些进程会停止执行.
22)
SIGTTOU 类似于SIGTTIN, 但在写终端(或修改终端模式)时收到.
23)
SIGURG 有"紧急"数据或out-of-band数据到达socket时产生.
24)
SIGXCPU 超过CPU时间资源限制. 这个限制可以由getrlimit/setrlimit来读取/
改变
25)
SIGXFSZ 超过文件大小资源限制.
26)
SIGVTALRM 虚拟时钟信号. 类似于SIGALRM, 但是计算的是该进程占用的CPU时间.
27)
SIGPROF 类似于SIGALRM/SIGVTALRM, 但包括该进程用的CPU时间以及系统调用的
时间.
28)
SIGWINCH 窗口大小改变时发出.
29)
SIGIO 文件描述符准备就绪, 可以开始进行输入/输出操作.
30)
SIGPWR Power failure
有 两个信号可以停止进程:SIGTERM和SIGKILL。 SIGTERM比较友好,进程能捕捉这个信号,根据您的需要来关闭程序。在关闭程序之前,您可以结束打开的记录文件和完成正在做的任务。在某些情况下,假 如进程正在进行作业而且不能中断,那么进程可以忽略这个SIGTERM信号。
对于SIGKILL信号,进程是不能忽略的。这是一个 “我不管您在做什么,立刻停止”的信号。假如您发送SIGKILL信号给进程,Linux就将进程停止在那里
####6.用户登陆审记####
1
w ##查看使用系统的当前用户有那些
w -f ##-f查看使用地点
2
last ##查看用户登陆成功历史
3.
lastb ##查看用户登陆未成功历史
####7.top命令####
top ##监控系统负载工具