Linux基本操作
01P-Linux命令基础习惯-Linux系统编程
date 显示系统当前时间
cat /etc/shells 查看当前可使用的shell
echo $SHELL 查看当前使用的shell
主键盘快捷键:
上 Ctrl-p
下 Ctrl-n
左 Ctrl-b
右 Ctrl-f
Del Ctrl-d delete 光标后面的
Home Ctrl-a first letter
End Ctrl-e end
Backspace Backspace delete光标前面的单个字符
清除整行 Ctrl-u
删除光标到行末 Ctrl-k
显示上滚 Shift-PgUp
显示下滚 Shift-PgDn
增大终端字体 Ctrl-Shift-+
减小终端字体 Ctrl- -
新打开一个终端 Ctrl-Alt-T
清屏 Ctrl-l 直接用clear也行
02P-类Unix系统目录
pwd 查看当前所在目录
Linux系统目录:
bin:存放二进制可执行文件
boot:存放开机启动程序
dev:存放设备文件: 字符设备、块设备
home:存放普通用户
etc:用户信息和系统配置文件 passwd、group
lib:库文件:libc.so.6
root:管理员宿主目录(家目录)
usr:用户资源管理目录 unix software resource
查看鼠标日志
03P-目录和文件操作1
cd – 返回上一个目录
Linux系统文件类型: 7/8 种
普通文件:-
目录文件:d
字符设备文件:c
块设备文件:b
软连接:l
管道文件:p
套接字:s
未知文件。
ls 列出当前文件夹下目录项
ll 竖排显示目录项和详细信息,ls -l的缩写
ls -l 显示目录项详细信息
ls -l dirname 显示dirname中目录详细信息
ls -dl dirname 显示dirname本身的详细信息
ls -R 递归查看目录
ls -Rl 递归展示详细信息
文件权限说明
目录项详细信息
文件权限 硬链接计数 所有者 所属组 大小 时间 文件名/文件夹名
权限具体展开
-rw-r—r—
1234567890
1代表文件类型
234代表所有者读写执行权限
567代表同组用户读写执行权限
890代表其他人读写执行权限
which instruct查看instruct命令所在目录位置
隐藏终端中的路径
vi ~./bash 打开使用的shell环境配置文件
末尾添加 PS1=$ 保存退出,重启终端即可
效果如下:
mkdir dirname 新建目录
rmdir dirname 删除空目录,非空目录删不掉
touch filename 创建名为name的空文件
rm filename删除文件
rm -r dirname 递归删除目录
rm -rf dirname 强制删除
mv file1 file2 location
将文件1和文件2移动到目标位置
cp filename dirname 复制文件到目录
cp filename1 filename2 复制文件1并重命名为文件2
cp -a dirname1 dirname2 复制目录1及其下所有文件到目录2
cp -r dirname1 dirname2 递归复制目录1到目录2
这里-a和-r的差别在于,-a是完全复制,文件权限,改动时间什么的也完全相同。
04P-目录和文件操作2
cat filename 查看文件内容
tac filename 逆转查看文件内容
cat 读取终端,就是回显
more filename 和cat差不多,但是对于大文件查看很强势
空格翻页,回车一行
用q或者Ctrl-c退出
less filename 也和cat差不多
空格翻页,回车一行
用q或者Ctrl-c退出
head -n filename 查看文件前n行
不加-n参数默认查看10行
tail -n filename 查看文件后n行
默认查看10行,顺序显示的,不是倒序显示,1-10查看后4行是78910
tree 命令,查看当前目录结构树
需要安装tree
05P-软链接和硬链接
ln -s file file.s 创建一个软链接
软链接就像windows下的快捷方式
这里软链接的大小是文件路径
Linux下的软链接行为和windows下的快捷方式差不多,但是如果是用相对路径创建的软链接,在软链接移动之后就会失效,无法访问。这一点和windows快捷方式不同,windows快捷方式随便放哪里都行。
失效的软链接
所以,创建软链接最好使用绝对路径
移动后,绝对路径创建的软链接不会失效
上图要注意,软链接的权限指的是这个软链接本身的权限,不是软链接指向文件的权限
ln file file.h 创建一个硬链接
创建硬链接后,文件的硬链接计数+1
再创建一个硬链接
这里对于file1,有2个硬链接file.h和file.hard,无论更改哪个硬链接或者文件本身,这三个文件的变化同步
产生这种同步变化的原因:
可以看到文件和硬链接的Inode是相同的,每个文件都有唯一的Inode,直观理解起来就像洗佳佳里面的引用,对于同一个文件,无论有多少引用,在访问时,都是这个文件,所以修改就是同步的。
当删除一个硬链接时,文件的硬链接计数-1,当这个计数减为0时,才会删除这个文件
即使删除硬链接指向的文件,也只会让硬链接计数-1
06P-创建修改用户和用户组
whoami 查看当前用户
chmod 修改权限操作
第一种,文字设定法
chmod [who] [+|-|=] [mode] filename
操作对象who可以是下述字母中的任一个或者它们的组合
u 表示”用户(user)”,即文件或目录的所有者
g 表示”同组(group)用户”,即与文件所有者有相同组ID的所有用户
o 表示”其他(others)用户”
a 表示”所有(all)用户”,它是系统默认值
操作符号可以是:
+ 添加某个权限
- 取消某个权限
= 赋予给定权限并取消其他所有权限(如果有的话)
如下所示,给file2文件添加执行权限
第二种,数字设定法
chmod 操作码 filename 直接用操作码修改文件权限
对于file2的权限
-rw-rw-r—
421421421
三个组的权限都用二进制编号,比如要设置当前用户对文件的读写和执行权限,则当前用户的操作权限为4(读)+ 2(写)+ 1(执行) = 7
用户组和其他用户的权限设置也是一样的
对于file2的权限-rw-rw-r—
我们设置如下:
所有者 rwx = 7
所有者所在组 rw = 6
其他用户 r = 4
操作码就是764
sudo adduser newusername 添加新用户
chown username filename 修改文件所有者
su username 切换当前用户为username
sudo addgroup groupname 添加新的用户组
sudo chgrp groupname filename 修改文件所属用户组
sudo chown username:groupname filename 同时修改文件所属用户和用户组
sudo deluser username 删除用户
sudo delgroup groupname 删除用户组
07P-find命令1
find命令:找文件
-type 按文件类型搜索 d/p/s/c/b/l/ f:文件
-name 按文件名搜索
find ./ -name "*file*.jpg"
-maxdepth 指定搜索深度。应作为第一个参数出现。
find ./ -maxdepth 1 -name "*file*.jpg"
-size 按文件大小搜索. 单位:k、M、G
find /home/itcast -size +20M -size -50M
这里要注意,两个size一个都不能少,还有就是文件大小单位对大小写敏感
-atime、mtime、ctime 天 amin、mmin、cmin 分钟。
按照时间搜索
a 表示最近访问时间
m 表示最近更改时间,指更改文件属性一类的
c 表示最近改动时间,指更改文件内容
08P-午后复习
09P-find命令2
-exec:将find搜索的结果集执行某一指定命令。
find /usr/ -name '*tmp*' -exec ls -ld {} \;
-ok: 以交互式的方式 将find搜索的结果集执行某一指定命令
10P-grep和xargs
grep命令:找文件内容
grep -r 'copy' ./ -n
-n参数::显示行号
ps监控后台进程工作情况,默认只显示当前可以和用户交互的进程
ps aux | grep 'cupsd' -- 检索进程结果集。
下图显示和内核相关进程
使用grep搜索进程,有一条结果是搜索进程本身
find … | xargs ls -l 对find操作的结果集进行操作
等价于
find … -exec ls -l {} \;
两者差别在于当结果集合很大的时候,xargs会对结果进行分段处理,所以性能好些
但xargs也有缺陷,xargs默认用空格来分割结果集,当文件名有空格的时候,会因为文件名被切割失效
-xargs:将find搜索的结果集执行某一指定命令。 当结果集数量过大时,可以分片映射。
find /usr/ -name '*tmp*' | xargs ls -ld
创建名字带空格的文件方法
第一个方法,文件名加引号
第二个方法,转义
xargs缺陷演示
解决xargs的缺陷,指定切分符号位null
-print0:
find /usr/ -name '*tmp*' -print0 | xargs -print0 ls -l
第一个print0指定结果集分隔为null,第二个print0指定xargs分隔为null
11P-xargs加强和awk说明
12P-软件包安装
sudo apt-get install softname
安装软件
sudo apt-get update 更新软件列表
更换软件源:
系统设置->软件和更新->下载自…
换软件源过后要更新软件列表
sudo apt-get remove softname卸载软件
使用安装包进行软件安装
13P-压缩命令gzip和bzip2
两者都是配合tar打包命令使用
这两个压缩的缺陷都是只能对单个文件进行压缩,一来不能压目录,二来不能打包
第一种压缩方式:gzip
tar zcvf 要生成的压缩包名 压缩材料,这里压缩包名一般以.tar.gz结尾
上述命令实际上执行了两步,
一个是gzip进行压缩
gzip filename
解压
gunzip zipfile
另一个是打包命令
tar file… tarname
所以tar zcvf 是两条指令的结合版本
对zcvf进行解释:
z:zip,压缩
c:create,创建
v:vision,显示压缩过程,可以去掉,直接用zcf,但这样不显示压缩过程
f:file,文件
file filename 查看文件来源
第二种压缩方式:使用bzip2方式压缩
tar jcvf 要生成的压缩包名 压缩材料
解压:
将压缩命令中的c --> x
tar zxvf 压缩材料 使用gzip解压
tar jxvf 压缩材料 使用bzip2解压
14P-rar压缩和zip压缩
rar压缩,需要安装rar
rar a -r newdir dir
打包,把dir压缩成newdir.rar,如果压缩材料里没有目录,-r参数可以省去
unrar x newdir.rar 解压rar文件
sudo aptitude show softname 查看软件安装信息
zip压缩:
zip -r dir.zip dir
zip解压
unzip dir.zip
zip文件在windows和linux下通用
15P-其他命令
who
查看当前在线上的用户情况
whoami
查看当前用户,不带有进程
ps aux | grep 条件 结果至少有一个,就是当前查询进程
jobs
查看操作系统当前运行了哪些用户作业
kill 杀死进程
env 环境变量
top 文字版任务管理器
sudo passwd uusername 设置用户密码
sudo su 切换root用户
ifconfig 查看网卡信息
man 系统参考手册
man n name 在系统手册第n章查看name
alias 给命令起别名
图中,ll实际指令里的F意味着带文件标识符,目录末尾有/,可执行文件末尾带*
alias 别名=’指令’
这里以管道查询别名为例
16P-总结
Linux系统: “所见皆文件”
Linux系统目录:
bin:存放二进制可执行文件
boot:存放开机启动程序
dev:存放设备文件: 字符设备、块设备
home:存放普通用户
etc:用户信息和系统配置文件 passwd、group
lib:库文件:libc.so.6
root:管理员宿主目录(家目录)
usr:用户资源管理目录
Linux系统文件类型: 7/8 种
普通文件:-
目录文件:d
字符设备文件:c
块设备文件:b
软连接:l
管道文件:p
套接字:s
未知文件。
软连接:快捷方式
为保证软连接可以任意搬移, 创建时务必对源文件使用 绝对路径。
硬链接:
ln file file.hard
操作系统给每一个文件赋予唯一的 inode,当有相同inode的文件存在时,彼此同步。
删除时,只将硬链接计数减一。减为0时,inode 被释放。
创建用户:
sudo adduser 新用户名 --- useradd
修改文件所属用户:
sudo chown 新用户名 待修改文件。
sudo chown wangwu a.c
删除用户:
sudo deluser 用户名
创建用户组:
sudo addgroup 新组名
修改文件所属用户组:
sudo chgrp 新用户组名 待修改文件。
sudo chgrp g88 a.c
删除组:
sudo delgroup 用户组名
使用chown 一次修改所有者和所属组:
sudo chown 所有者:所属组 待操作文件。
find命令:找文件
-type 按文件类型搜索 d/p/s/c/b/l/ f:文件
-name 按文件名搜索
find ./ -name "*file*.jpg"
-maxdepth 指定搜索深度。应作为第一个参数出现。
find ./ -maxdepth 1 -name "*file*.jpg"
-size 按文件大小搜索. 单位:k、M、G
find /home/itcast -size +20M -size -50M
-atime、mtime、ctime 天 amin、mmin、cmin 分钟。
-exec:将find搜索的结果集执行某一指定命令。
find /usr/ -name '*tmp*' -exec ls -ld {} \;
-ok: 以交互式的方式 将find搜索的结果集执行某一指定命令
-xargs:将find搜索的结果集执行某一指定命令。 当结果集数量过大时,可以分片映射。
find /usr/ -name '*tmp*' | xargs ls -ld
-print0:
find /usr/ -name '*tmp*' -print0 | xargs -0 ls -ld
grep命令:找文件内容
grep -r 'copy' ./ -n
-n参数::显示行号
ps aux | grep 'cupsd' -- 检索进程结果集。
软件安装:
1. 联网
2. 更新软件资源列表到本地。 sudo apt-get update
3. 安装 sudo apt-get install 软件名
4. 卸载 sudo apt-get remove 软件名
5. 使用软件包(.deb) 安装: sudo dpkg -i 安装包名。
tar压缩:
1. tar -zcvf 要生成的压缩包名 压缩材料。
tar zcvf test.tar.gz file1 dir2 使用 gzip方式压缩。
tar jcvf test.tar.gz file1 dir2 使用 bzip2方式压缩。
tar解压:
将 压缩命令中的 c --> x
tar zxvf test.tar.gz 使用 gzip方式解压缩。
tar jxvf test.tar.gz 使用 bzip2方式解压缩。
rar压缩:
rar a -r 压缩包名(带.rar后缀) 压缩材料。
rar a -r testrar.rar stdio.h test2.mp3
rar解压:
unrar x 压缩包名(带.rar后缀)
zip压缩:
zip -r 压缩包名(带.zip后缀) 压缩材料。
zip -r testzip.zip dir stdio.h test2.mp3
zip解压:
unzip 压缩包名(带.zip后缀)
unzip testzip.zip
17P-复习
创建一个目录,大小默认是4096k