收集一些自己常用的linux指令
一、一台服务器向另一台服务器推送文件
scp -P port 20120420.tar.gz adhai@192.168.33.55:/data3/redis_db/02
推送到指定的目录,-P后面接端口号,不写默认为22,按回车之后,输入密码即可。
二、压缩,解压文件
压缩:tar -zcvf 20120420.tar.gz ./20120420 z是gz格式压缩,c是压缩,v是显示压缩文件
解压:tar -zvxf 20120420.tar.gz -C ./test/ z是gz压缩的,x是解压,v是显示解压文件,-C后面可跟解压到的路径,默认当前目录
三、查找指定的文件路径
find /home -name text.txt /home指定需要搜索的路径,-name后面接需要搜索的文件
四、统计一个文件下文件个数
ls -lR | grep “^-” | wc -l ^-筛选出以-开头的,文件一般都是以-开头, wc是统计
五、查看磁盘使用情况
df -h
六、查看进程
ps aux | grep “test” | 管道命令,查找test的进程
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
USER: 行程拥有者 ;PID: pid ;%CPU: 占用的 CPU 使用率 ;%MEM: 占用的记忆体使用率
VSZ: 占用的虚拟记忆体大小 ;RSS: 占用的记忆体大小 ;TTY: 终端的次要装置号码 (minor device number of tty)
STAT: 该行程的状态: ;D: 不可中断的静止 ;R: 正在执行中 ;S: 静止状态 ;T: 暂停执行 ;Z: 不存在但暂时无法消除 ;W: 没有足够的记忆体分页可分配 ;<: 高优先序的行程 ;N: 低优先序的行程 ;L: 有记忆体分页分配并锁在记忆体内 (即时系统或捱A I/O)
START: 行程开始时间 ;TIME: 执行的时间 ;COMMAND:所执行的指令
top -u adhai -u后面接账号,默认的root账号,此指令相当于windows下的任务管理器
清理缓存:
echo 3 > /proc/sys/vm/drop_caches
七、grep命令查文件
grep -n -C 10 –color “xxxxxxxx” nohup.out -n 是显示行号,-C 10 是显示前后10行,–color是反色显示,默认是红色,“”里是查找的内容,支持正则,后面接所要查找的文件
grep -E 'xxxx' *.php 从php文件里面找内容xxxx
八、创建文件夹、权限修改等相关
mkdir -p ./abc/def -p的作用是递归创建目录,没有abc就创建abc,再进去创建def。不加-p没有abc目录的话会报错
chown -R adhai html/ 修改当前目录下的html文件夹adhai账号访问权限,-R是递归里面的子目录
九、linux上ssh跳转
ssh -f -N -L 8014:192.168.33.185:20100 adhai@115.238.154.164 -p 57764
8014是本地端口,192.168.33.185是目标服务器的IP,20100是目标服务器端口,adhai@115.238.154.164是跳转机的账号IP,57764是跳转机的ssh端口。
十、打包成.a静态库
ar cr libxxxx.a *.o
十一、wc命令详解:该命令统计给定文件中的字节数、字数、行数。如果没有给出文件名,则从标准输入读取。wc同时也给出所有指定文件的总统计数。字是由空格字符区分开的最大字符串。
用法:wc [选项] 文件…
- c 统计字节数。
- l 统计行数。
- w 统计字数。w为word缩写,表示统计英文单词的意思
- m 统计字符数。
这些选项可以组合使用,省略参数为默认的-lcw
linux命令行打开可视化文件夹 : nautilus
linux命令行下如何进入带空格的文件夹
可以使用加英文的引号cd /usr/chen/java/"MyeClips e 9" 或cd /usr/chen/java/MyeClipse \ 9如果在行末,是说明本行还未结束,下面一行和本行是一起的意思. -- 就是选项的开始,一般一个字母的选项用 - 开头,多个字母的就用 -- 开头. “\”后如果是回车,不换行的话可能省略;但要是其它字符,就不能省略。 “\”告诉系统后面跟着的字符为原意,不是命令。 比如有个文件名中带有空格,就要在空格前加一个“\”。文件名的方法应该与文件夹一样。
xcu work 权限
1、查看文件夹里文件个数
find ./company -type f | wc -l
2、比较svn两个版本间区别
svn diff -r r872:r871 spacecp_profile.php
3、vim分屏操作
启动分屏
1.使用大写O参数进行垂直分屏
$ vim -On file1 file2 ...
2.使用小写o参数进行水平分屏
$ vim -on file1 file2 ...
注: n是数字,表示分屏的数量
关闭分屏
1.关闭当前窗口
ctrl+w c
2.关闭当前窗口,如果只剩最后一个,则退出vim
ctrl+w q
编辑中分屏
1.上下分割当前打开的文件
ctrl+w s
2.上下分割,并打开一个新的文件
:sp filename
3.左右分割当前打开的文件
ctrl+w v
4.左右分割,并打开一个新的文件
:vsp filename
分屏编辑中光标的移动
vi中的光标键是h,j,k,l,要在各个屏之间切换,只需要先按一下ctrl+w
1.把光标移动到上边的屏
ctrl+w k
2.把光标移动到下边的屏
ctrl+w j
3.把光标移动到右边的屏
ctrl+w l
4.把光标移动到左边的屏
ctrl+w h
5.把光标移动到下一个的屏
ctrl+w w
移动分屏
1.向上移动
ctrl+w K
2.向下移动
ctrl+w J
3.向右移动
ctrl+w L
4.向左移动
ctrl+w H
屏幕尺寸
1.增加高度
ctrl+w +
2.减少高度
ctrl+w -
3.让所有屏的高度一致
ctrl+w =
linux下vim命令详解
:qx 开始记录宏,并将结果存入寄存器x
q 退出记录模式
@x 播放记录在x寄存器中的宏命令
稍微解释一下,当在normal模式下输入:qx后,你对文本的所有编辑动作将会被记录下来,再次输入q即退出了记录模
式,然后输入@x对刚才记录下来的命令进行重复,此命令后可跟数字,表示要重复多少次,比如@x20,可以重复20次。这个在文本的批处理中是非常有用的。
同时编辑多个文件
在vim众多的插件中,有一个叫minibuffer的插件,就是下面所说的标签页功能了,可以支持同时编辑多个文件。
标签命令
:tabe fn 在一个新的标签页中编辑文件fn
gt 切换到下一个标签页
gT 切换到上一个标签页
:tabr 切换到第一个标签页
:tabl 切换到最后一个标签页
:tabm [N] 把当前tab移动到第N个tab之后
对,正如你所想象的那样,跟eclipse, ue等的标签页是一个意思!
窗口命令
ctrl+w s 水平分割窗口
ctrl+w w 切换窗口
ctrl+w q 退出当前窗口(由于同时有多个文件,此命令不会影响其他窗口)
ctrl+w v 垂直分割窗口
其他
vim在保存之前不会对文件做实际的修改,只是加载到缓冲区中,对文件的编辑其实是对缓冲区的编辑,直到:w时才会存入物理文件。
:e file 把file加载到新的缓冲区中
:bn 跳转到下一个缓冲区
:bd 删除缓冲区(关闭文件)
:sp fn 分割窗口,并将fn加载到新的窗口中
退出编辑器
:w 将缓冲区写入文件,即保存修改
:wq 保存修改并退出
:x 保存修改并退出
:q 退出,如果对缓冲区进行过修改,则会提示
:q! 强制退出,放弃修改
查找替换
/pattern 向后搜索字符串pattern
?pattern 向前搜索字符串pattern
n 下一个匹配(如果是/搜索,则是向下的下一个,?搜索则是向上的下一个)
N 上一个匹配(同上)
:%s/old/new/g 搜索整个文件,将所有的old替换为new
:%s/old/new/gc 搜索整个文件,将所有的old替换为new,每次都要你确认是否替换
复制粘贴
dd 删除光标所在行
dw 删除一个字(word)
x 删除当前字符
X 删除前一个字符
D 删除到行末
yy 复制一行,此命令前可跟数字,标识复制多行,如6yy,表示从当前行开始复制6行
yw 复制一个字
y$ 复制到行末
p 粘贴粘贴板的内容到当前行的下面
P 粘贴粘贴板的内容到当前行的上面
]p 有缩进的粘贴,vim会自动调节代码的缩进
"a 将内容放入/存入a寄存器,可以支持多粘贴板
附:比如常用的一个寄存器就是系统寄存器,名称为+,所以从系统粘贴板粘贴到vim中的命令为"+p,注意此处的+不表示操作符,二十一个寄存器。
移动光标
在vim中移动光标跟其他的编辑器中有很大的区别,不过一旦学会了,就会飞速的在文本中移动了。
h,j,k,l 上,下,左,右
ctrl-f 上翻一页
ctrl-b 下翻一页
% 跳到与当前括号匹配的括号处,如当前在{,则跳转到与之匹配的}处
w 跳到下一个字首,按标点或单词分割
W 跳到下一个字首,长跳,如end-of-line被认为是一个字
e 跳到下一个字尾
E 跳到下一个字尾,长跳
b 跳到上一个字
B 跳到上一个字,长跳
0 跳至行首,不管有无缩进,就是跳到第0个字符
^ 跳至行首的第一个字符
$ 跳至行尾
gg 跳至文件的第一行
gd 跳至当前光标所在的变量的声明处
[N]G 跳到第N行,如0G,就等价于gg,100G就是第100行
fx 在当前行中找x字符,找到了就跳转至
; 重复上一个f命令,而不用重复的输入fx
tx 与fx类似,但是只是跳转到x的前一个字符处
Fx 跟fx的方向相反
),( 跳转到上/下一个语句
* 查找光标所在处的单词,向下查找
# 查找光标所在处的单词,向上查找
`. 跳转至上次编辑位置
在屏幕上移动
H 移动光标到当前屏幕上最上边的一行
M 移动光标到当前屏幕上中间的一行
L 移动光标到当前屏幕上最下边的一行
书签
ma 把当前位置存成标签a
`a 跳转到标签a处
编辑
r 替换一个字符
J 将下一行和当前行连接为一行
cc 删除当前行并进入编辑模式
cw 删除当前字,并进入编辑模式
c$ 擦除从当前位置至行末的内容,并进入编辑模式
s 删除当前字符并进入编辑模式
S 删除光标所在行并进入编辑模式
xp 交换当前字符和下一个字符
u 撤销
ctrl+r 重做
. 重复上一个编辑命令
~ 切换大小写,当前字符
g~iw 切换当前字的大小写
gUiw 将当前字变成大写
guiw 将当前字变成小写
>> 将当前行右移一个单位
<< 将当前行左移一个单位(一个tab符)
== 自动缩进当前行
插入模式
i 从当前光标处进入插入模式
I 进入插入模式,并置光标于行首
a 追加模式,置光标于当前光标之后
A 追加模式,置光标于行末
o 在当前行之下新加一行,并进入插入模式
O 在当前行之上新加一行,并进入插入模式
Esc 退出插入模式
可视模式
标记文本
v 进入可视模式,单字符模式
V 进入可视模式,行模式
ctrl+v 进入可视模式,列模式,类似于UE的列模式
o 跳转光标到选中块的另一个端点
U 将选中块中的内容转成大写
O 跳转光标到块的另一个端点
aw 选中一个字
ab 选中括号中的所有内容,包括括号本身
aB 选中{}括号中的所有内容
ib 选中括号中的内容,不含括号
iB 选中{}中的内容,不含{}
对标记进行动作
> 块右移
< 块左移
y 复制块
d 删除块
~ 切换块中内容的大小写
1、或操作
2、与操作
3、其他操作
grep -i pattern files :不区分大小写地搜索。默认情况区分大小写,
grep -l pattern files :只列出匹配的文件名,
grep -L pattern files :列出不匹配的文件名,
grep -w pattern files :只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),
grep -C number pattern files :匹配的上下文分别显示[number]行,