Linux & Shell 学习笔记【1/2】
小小屌丝程序员 人气:0因为工作上的需要,花了些许时间去熟悉学习Linux和Shell,现在也花点事件在此记录一下以加强巩固学习的内容吧。学的不算深入,所以都是一些比较junior的内容。
在下一篇随笔会详述之前写的一个用于解析swift(569/940/950)的Shell。
一. Linux
1. 如下为一些经常使用到的命令,因为刚开始学习的时候记忆的东西比较多,都是根据全称来记忆的,多使用之后就会熟悉了。
cd / ls / mkdir / rmdir / rm / touch / mv / cp
对应全称如下
change directory / list / make directory / remove directory / remove / touch / move / copy
2. 归档/压缩会用到后面两个命令: tar / gzip
归档/解归档命令如下:
tar -cvf archived.tar fileName/FolderName --- 归档文件/文件夹,其中c=create(创建归档);v=visual(显示归档过程);f=file(归档后文件名);archived.tar为归档后的文件名; fileName/FolderName为需要归档的文件/文件夹
tar -xvf archived.tar --- 解除归档,其中vf参数与归档的含义相同,x=extract(解析归档)
压缩/解压命令如下:
gzip fileName --- 压缩,会自动生成fileName.gz的压缩文件(原始的fileName文件会消失)
gzip -d fileName.gz --- 解压缩,会自动生成fileName的文件(压缩文件会消失)
上述的归档/解归档和压缩/压缩可以同时使用
tar -zcvf archived.tar.gz fileName/FolderName --- 在归档命令的基础上添加z(标识以gzip的方式进行压缩)
tar -zxvf archived.tar.gz --- 在解归档的基础上添加z(标识以gzip的方式进行解压)
3.history
该命令用来获取历史执行命令的记录(会显示对应的commandNumber & commandContent),有如下两个参数:
history n --- 展示最新的n条历史记录
history -c ---清空历史记录
其中针对展示的历史记录,可以通过两个方式进行调用:
! + commandNumber
! + commandContent
其中commandContent可以为前几个字符,环境会自动匹配历史中最新的命令。
4. 用户/用户组操作
添加/删除用户
useradd newUsername --- 添加新用户newUsername(此时用户组也默认新建,亦为newUsername)
uueradd groupName newUsername --- 添加新用户newUsername,并且该用户所属groupName 用户组
passwd newUsername userPwd --- 为用户newUsername 添加密码userPwd
userdel newUsername --- 删除用户newUsername
groupadd newGroupName --- 添加新用户组newGroupName
groupdel newGroupName --- 删除用户组newGroupName
5. 文件夹权限管理
针对每个文件都存在属主/属组/其他人的三个读/写/执行权限。可通过如下命令修改文件的属主/属组
chown newUsername:newGroupName fileName --- 修改文件fileName的属主为newUsername,属组为newGroupName
如果只想修改属组,把newUsername置空,注意':'不能去掉。同时也可以通过如下命令
chgrp newGroupName fileName
如上两个命令我理解全称就是change owner和change group(方便记忆,包括后面的chmod=change modification)
6. 利用scp进行上传/下载
规则一般就是scp source destination
下载:scp username@host:absolutePath/fileName D:\ ---- 将文件fileName下载到D盘中
上传:scp D:\fileName username@host:absolutePath/ --- 将文件fileName上传到服务器absolutePath/下
如果是上传文件夹,在上传的路径前加-r (标识recursive)
7. grep/sed/awk
这三个命令也会经常使用到,查询的时候使用grep比较多,替换使用sed比较多,对查询后的继续处理使用awk比较多。
grep:
如grep test test* ---用来查询以test开头的文件中包含test字符串的内容
echo “abc” | grep ‘^a' -- 查询字符串abc是否以字母a开头
如上可以知道grep也支持正则表达式(会在后面描述),一般情况下需要使用正则时候我会使用egrep,因为有些正则grep还不能使用(应该需要使用grep -e)
sed:
echo “abc" | sed 's/a/A/g’ ---可以将a替换成A
sed -n '1,3p' fileName 输出文件fileName的第一行到第三行,其中p为print,n为quiet(代表只输出选中的内容,否则所有内容都会输出,而且选中的内容会输出两遍)
awk:
awk -F ‘:’ '{print $2}' fileName --- 以分号为分隔符,输出每一行的第二个字符。其中-F为field seperator,作用同-v FS
awk -v RS=':' 'NR==2{print}' --- 以分号为RS(row seperator行分隔符),并输出第二行(NR=number row)
上述只是具体,实际功能均远不止于此,特别awk的功能在处理字符串上极为强大。前段时间因为工作需要利用awk解析swift(569/940/950)报文到指定的格式上,会在后面单独写一遍文档详述。
8, 切换用户
su userName --- 切换到userName用户,但依旧使用当前的环境变量,但userName为空时为切换到root。可以使用exit命令退出当前用户
su - userName --- 与上面的相比的不同时会切换当前的环境变量到新用户
9.管道
管道用符号|标识,即将管道左边的输出作为管道右边的输入,如:
echo “123” | grep ‘1’
上述命令中将文本作为grep命令的输入
10. 标准输出/输入/错误输出
标准输入为0,默认从屏幕输入
标准输出为1,默认输出的屏幕
标准错误输出为2,默认输出到屏幕
echo 123 > fileName --- 将文本123输出到文件fileName中,此时123不会输出到屏幕上
cat > file1 < file2 --- 将file2作为file1的标准输入,即拷贝file2的内容到file1
command > file 2>$1 --- 将命令command的结果输出到file中,并将标准错误输出的转到标准输出,即此时如果存在错误也会很标准输出一样输出至file中
11. 其他零碎的小命令
sort 排序
last | sort
uniq 对重复的内容只显示一次(unique),其中可以使用参数-c来计算重复的数量,如下
uniq -c
wc 计算数量(行/单词/字符), 全称应为word count
wc -l A --- 计算行数
wc -w --- 计算单词数量
wc -m ---计算字符数量
如果什么参数都没有,会显示行/单词/字符的数量
tee 将内容输出的文件的同时标准输出,如:
echo “123” | tee test.txt
如上命令在把文本123输入到test.txt*(覆盖的方式)的同时输出到屏幕
ps -aux --- 查看内存等使用情况
top --- 查看内存等使用情况(动态)
df -h ---查看磁盘使用情况
dos2unix fileName ---- window和linux的换行符不同,所在需要通过该命令去除多余的^M
unix2dos filename
tr ‘a-z’ 'A-Z' 将小写字母转成大写字母
二. VIM
1. 搜索字符串
:/string --- 向文件尾部搜索字符串
:?string --- 向文件头部搜索字符串
搜索过程中使用n(向下搜索)/N(向上搜索)字符串
2. 替换字符串
:[range]s/oldString/newString/g
其中range可以是1,4代表第一行至第四行:%代表全部内容
g标识全部替换
3. 编辑模式
i/o为进入编辑模式,其中o为在当前行插入一行并让光标停在新的一行
通过ctrl x + ctrl o可以对参数进行补齐(根据现在文件内容),如果在写shell,参数又比较长,还是比较好用的
通过ctrl x + ctrl n可以对参数进行补齐(根据当前目录文件)
4. 指令模式
u为取消上一次操作(undo),ctrl + r为重做上一次操作(redo);万一取消错了,redo还是很有用的
v/V/ctrl + v可以对区块(即不对整行进行处理)进行选择,进而进行后续操作(yyhttps://img.qb5200.com/download-x/dd/p)
5. 多文件处理
好处是针对多个文件间需要使用yy/p命令,不同vim下的文件是无法处理的。vim 后加多个文件可以多文件处理,利用:files可以展示正在多文件处理的文件列表,:n进入到下一个文件,:N进入到上一个文件。
环境参数设置
:set nu --- 显示行号(number)
:set nonu --- 不显示行号
:set hlsearch --- 高亮查询的结果(highlight search)
:set nohlsearch --- 不高亮查询结果
:set autoindent --- 启用indent(当该行存在indent,换行后下一行也会保留和改行的indent)
:set noautoindent --- 不启动indent
:set backup --- 启动备份,当文件发生修改时,会自动生成一个fileName~的备份文件
:set nobackup --- 关闭备份(默认为关闭的状态)
;syntax on --- 启动语法(字符颜色不同)
:syntax on --- 关闭语法
三. 正则
^为匹配首字符,但在[]代表非
$匹配尾字符,如^1.*2$为匹配1开头2结尾的字符
. 匹配除换行符外的任意字符
*匹配前面的内容0次或多次
+匹配前面的内容1次或多次
?匹配前面的内容0次或1次
{n}匹配前面的内容n次
{n,}匹配前面的内容n次或更多次
{n,m}匹配前面的内容n-m次(包含n和m)
|各个条件之间的或
加载全部内容