文章目录
文件结构
在Linux操作系统中,所有被操作系统管理的资源,例如网卡、磁盘驱动器、打印机、输入输出设备、普通文件或是目录都被看作是一个文件。
也就是说在LINUX系统中有一个重要的概念:一切都是文件。其实这是UNIX哲学的一个体现,而Linux是重写UNIX而来,所以这个概念也就传承了下来。在UNIX系统中,把一切资源都看作是文件,包括硬件设备。UNIX系统把每个硬件都看成是一个文件,通常称为设备文件,这样用户就可以用读写文件的方式实现对硬件的访问。
常见目录说明
- /bin: 存放二进制可执行文件(ls,cat,mkdir等),常用命令一般都在这里;
- /etc: 存放系统管理和配置文件;
- /home: 存放所有用户文件的根目录,是用户主目录的基点,比如用户user的主目录就是/home/user,可以用~user表示;
- /usr : 用于存放系统应用程序;
- /opt: 额外安装的可选应用程序包所放置的位置;
- /proc: 虚拟文件系统目录,是系统内存的映射。可直接访问这个目录来获取系统信息;
- /root: 超级用户(系统管理员)的主目录;
- /sbin: 存放二进制可执行文件,只有root才能访问。这里存放的是系统管理员使用的系统级别的管理命令和程序。如ifconfig等;
- /dev: 用于存放设备文件;
- /mnt: 系统管理员安装临时文件系统的安装点,系统提供这个目录是让用户临时挂载其他的文件系统;
- /boot: 存放用于系统引导时使用的各种文件;
- /lib : 存放着和系统运行相关的库文件 ;
- /tmp: 用于存放各种临时文件,是公用的临时文件存储点;
- /var: 用于存放运行时需要改变数据的文件,也是某些大文件的溢出区,比方说各种服务的日志文件(系统启动日志等。)等;
- /lost+found: 这个目录平时是空的,系统非正常关机而留下“无家可归”的文件(windows下叫什么.chk)就在这里。
常用命令
Linux命令用法一般用man命令可以查看其帮助信息
目录切换 cd
- cd usr: 切换到该目录下usr目录
- cd …(或cd…/): 切换到上一层目录
- cd /: 切换到系统根目录
- cd ~: 切换到用户主目录
- cd -: 切换到上一个所在目录
目录操作
- mkdir -p 目录
- ls / ll (ls -l)
- find
- 列出当前目录及子目录下所有文件和文件夹: find .
- 在/home目录下查找以.txt结尾的文件名: find /home -name “*.txt”
- 同上,但忽略大小写: find /home -iname “*.txt”
- 当前目录及子目录下查找所有以.txt和.pdf结尾的文件: find . -name *.rdb -o -name *.log
- mv -rf
- 重命名
- 剪切
- cp -rf
- rm -rf
文件操作
- touch 文件
- cat / more / less / head / tail
- cat: 打印全文, 但只显示最后一屏内容
- more: 可以显示百分比,回车可以向下一行, 空格可以向下一页,q可以退出查看
- less: 可以使用键盘上的PgUp和PgDn向上 和向下翻页,q结束查看
- head -10: 查看文件的前10行,Ctrl+C结束
- tail -10: 查看文件的后10行,Ctrl+C结束
- tail -f: 可以对某个文件进行动态监控
- vim
- 命令模式: 用 vim 打开一个文件, 就是命令模式, 可以用快捷键操作文本, 按 i 进入编辑模式
- 移动光标
- 1.vim 可以使用小写英文字母 h j k l 分别控制光标左 下 上 右移动,也可以使用箭头
- 2.Ctrl+b 屏幕往后移动一页
- 3.Ctrl+f 屏幕往前移动一页
- 4.Ctrl+u 屏幕往后移动半页
- 5.Ctrl+d 屏幕往前移动半页
- 6.Shift+g == G 移动到文章的最后
- 7.Shift+4 == $ 移动到光标所在行的行尾
- 8.Shift+6 == ^ 移动到光标所在行的行首
- 9.w 光标跳到下个字的开
- 10.e 光标跳到下个字的字
- 11.b 光标回到上个字的开
- 12.#l 例如:5l ,56l 光标移动到该行的第’#'个位
- 13.gg 进入到文本的开始
- 搜索
- /搜索内容: 搜索
- n: 跳到下一个
- N: 跳到上一个
- 删除
- 1.x 每按一次删除光标所在位置的一个字符
- 2.#x 栗子:6x 删除光标所在位置的"后面"(包含自己在内)6个字符
- 3.Shift+x == X 每按一次,删除光标所在位置的前一个字符
- 4.Shift+#x == #X 栗子 20X 删除光标所在位置的前面20个字符
- 5.dd 删除光标所在行
- 6.#dd 栗子 6dd 从光标所在行开始删除6行
- 复制
- 1.yw 将光标所在之处到字尾的字符复制到缓冲区中
- 2.#yw 栗子 6yw 复制6个字符到缓冲区
- 3.yy 复制光标所在行到缓冲区
- 4.#yy 栗子 6yy 拷贝从光标所在的该行"往下数"6行文字
- 5.p 将缓冲区内的字符贴到光标所在位置. 注意:所有与y有关的复制命令都必须与p配合才能完成复制粘贴功能
- 替换
- 1.r 替换光标所在处的字符
- 2.R 替换光标所到之处的字符,知道按下Esc键为止.
- 撤销上一次的操作
u 回到上一个操作,按动多次’u’可以执行多次回复 - 更改
1.cw 更改光标所在处的字到字尾处
2.c#w 栗子 c3w 表示更改三个字 - 跳至指定行
- 1.Ctrl+g 列出光标所在行的行号
- 2.#G 栗子 15G 表示移动光标到文章的第15行行首
- 移动光标
- 编辑模式: 可以插入文本, 按 Esc 进入底行模式
- 底行模式: 保存/退出
- 退出 :q 或 :q!
- 保存 :x 或 :wq
- 命令模式: 用 vim 打开一个文件, 就是命令模式, 可以用快捷键操作文本, 按 i 进入编辑模式
压缩文件
打包并压缩
Linux中的打包文件一般是以.tar结尾的,压缩的文件一般是以.gz结尾的。
而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般.tar.gz。
tar -zcvf 打包压缩后的文件名 要打包压缩的文件
, 比如:加入test目录下有三个文件分别是 :aaa.txt bbb.txt ccc.txt,如果我们要打包test目录并指定压缩后的压缩包名称为test.tar.gz可以使用命令:tar -zcvf test.tar.gz aaa.txt bbb.txt ccc.txt 或:tar -zcvf test.tar.gz /test/
- z:调用gzip压缩命令进行压缩
- c:打包文件
- v:显示运行过程
- f:指定文件名
解压缩
tar [-xvf] 压缩文件
, 将/test下的test.tar.gz解压到当前目录下可以使用命令:tar -xvf test.tar.gz
; 将/test下的test.tar.gz解压到根目录/usr下:tar -xvf xxx.tar.gz -C /usr(- C代表指定解压的位置)
- x:代表解压
权限命令
操作系统中每个文件都拥有特定的权限、所属用户和所属组。权限是操作系统用来限制资源访问的机制,在Linux中权限一般分为读(readable)、写(writable)和执行(excutable),分为三组。分别对应文件的属主(owner),属组(group)和其他用户(other),通过这样的机制来限制哪些用户、哪些组可以对特定的文件进行什么样的操作。通过 ls -l 命令我们可以 查看某个目录下的文件或目录的权限
文件类型
- d: 代表目录
- -: 代表文件
- l: 代表链接(可以认为是window中的快捷方式)
权限类型
- r:代表权限是可读,r也可以用数字4表示
- w:代表权限是可写,w也可以用数字2表示
- x:代表权限是可执行,x也可以用数字1表示
文件权限和目录权限的区别
- 对于文件
- r: 可以使用cat查看文件的内容
- w: 可以修改文件的内容
- x: 可以将其运行为二进制文件
- 对于目录
- r: 可以查看目录下列表
- w: 可以创建和删除目录下文件
- x: 可以使用cd进入目录
所有者 / 所属组 / 其他组
在linux中的每个用户必须属于一个组,不能独立于组外。在linux中每个文件有所属用户、所属组、其它组的概念。
- 所有者: 一般为文件的创建者,谁创建了该文件,就天然的成为该文件的所有者,用ls ‐l命令可以看到文件的所有者, 也可以使用
chown 用户名 文件名
来修改文件的所有者 - 所属组: 当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组, 用ls ‐l命令可以看到文件的所有组, 也可以使用
chgrp 组名 文件名
来修改文件所在的组 - 其他组: 除开文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组
修改文件/目录的权限 chmod
- chmod u=rwx,g=rw,o=r aaa.txt
- chmod 764 aaa.txt
用户管理
Linux系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。
用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。
用户管理
useradd命令用于Linux中创建的新的系统用户。useradd可用来建立用户帐号。帐号建好之后,再用passwd设定帐号的密码.而可用userdel删除帐号。使用useradd指令所建立的帐号,实际上是保存在/etc/passwd文本文件中。该文件内容的解释:用户名:密码:用户id:组id:用户说明:用户的主目录:用户使用的shell环境(默认为bash)
passwd命令用于设置用户的认证信息,包括用户密码、密码过期时间等。系统管理者则能用它管理系统用户的密码。只有管理者可以指定用户名称,一般用户只能变更自己的密码。
- useradd 选项 用户名:添加用户账号
- userdel 选项 用户名:删除用户帐号
- usermod 选项 用户名:修改帐号
- passwd 用户名:更改或创建用户的密码
- passwd -S 用户名 :显示用户账号密码信息
- passwd -d 用户名: 清除用户密码
- su - 用户名:切换登录用户
用户组管理
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。
- groupadd 选项 用户组 :增加一个新的用户组
- groupdel 用户组:要删除一个已有的用户组
- groupmod 选项 用户组 : 修改用户组的属性
其他常用命令
- pwd: 显示当前所在位置
- grep: 要搜索的字符串 要搜索的文件 --color: 搜索命令,–color代表高亮显示
- ps -ef/ps aux: 这两个命令都是查看当前系统正在运行进程,两者的区别是展示格式不同。如果想要查看特定的进程可以使用这样的格式:ps aux|grep redis (查看包括redis字符串的进程)
注意:如果直接用ps((Process Status))命令,会显示所有进程的状态,通常结合grep命令查看某进程的状态。 - kill -9 进程的pid: 杀死进程(-9 表示强制终止。)先用ps查找进程,然后用kill杀掉
- 网络通信命令
- ifconfig: 查看当前系统的网卡信息
- ping: 查看与某台机器的连接情况
- netstat: 查看当前系统的端口
- -an 所有的连接和端口
- tuln 查看正在监听TCP(t)和UDP(u)的端口 ,例如:netstat -tuln | grep LISTEN
- rn 查看网关 route -n
- ln: 创建链接文件
- 软链接文件:ln -s [源文件] [目标文件] (硬链接不需-s选项)
- 软链接特点:权限是所有人都可以访问,并且软连接文件指向源文件
- 软链接就像windows系统中的快捷方式一样,特点也都类似
- 硬链接文件:类似copy,硬链接大小和源文件一样,并且是同步更新的。
- shutdown: shutdown -h now: 指定现在立即关机;shutdown +5 “System will shutdown after 5 minutes”:指定5分钟后关机,同时送出警告信息给登入用户
- reboot: reboot: 重开机。reboot -w: 做个重开机的模拟(只有纪录并不会真的重开机)