问题描述:
1 linux 基本命令
一、目录操作
1.ls (显示出当前目录下的文件)
ls -a (显示出包含隐藏文件的所有文件)
ls -t (按照文件最后修改时间显示文件)
ls -F (显示出当前目录下的文件及其类型)
ls -l (显示目录下所有文件的许可权、拥有者、文件大小、修改时间及名称,同ls -lg) ls -R (显示出该目录及其子目录下的文件)
2
2. mkdir (建新目录)
执行格式: mkdir 目录名
例: mkdir mydir (新建一个名为 dir1 的目录)
3. rmdir (删除目录)
执行格式: rmdir 目录名
或 rm 目录名
例:rmdir mydir(它必须是空目录,否则无法删除)
rm -rdir1 (删除目录 dir1 及其下所有文件及子目录)
rm -rf dir1 (不管是否空目录,统统删除,而且不给出提示, 使用时要小心)
4. cd (改变工作目录位置)
执行格式: cd 目录名
例:cd dir1 (改变目录位置,至dir1目录)
cd.. 改变目录位置,至当前目录的上层目录
cd ../Public改变目录位置,至上一级目录下的Public 目录
3 cd /dir-name1/dir-name2 改变目录位置,至绝对路径(Full path) cd - 回到进入当前目录前的上一个目录
5. pwd (显示当前所在目录)
执行格式: pwd
6. du (查看目录大小)
执行格式: du [-s] 目录名
例: du dir1显示目录dir1及其子目录容量,以 kb 为单位
du -sdir1 显示目录 dir1 的总容量
7. 显示环境变量
echo $HOME 显示家目录
echo $PATH 显示可执行文件搜索路径
env 显示所有环境变量(可能很多, 最好用"env | more","env |grep PATH"等
)
4
8. 修改环境变量,在bash 下用export, 如:
export PATH=$PATH:/usr/local/bin
想知道 export 的具体用法,可以用 shell 的 help 命令:help export
二、文件操作
1.cat (查看文件,可以是二进制的内容)
执行格式:cat filename 或 more filename 或 cat filename|more 例: cat file1 以连续显示方式,查看文件 file1 的内容
more file1或 cat file1|more 以分页方式查看文件的内容
2. rm (删除文件)
执行格式: rm filename
3. cp (复制文件)
执行格式: cp [-r]source destination
例: cp file1 file2 将 file1 复制成 file2
cp file1 dir1 将 file1 复制到目录 dir1
cp /tmp/file1 将 file1 复制到当前目录
cp /tmp/file1 file2 将 file1 复制到当前目录名为 file2
cp -r dir1 dir2复制整个目录
4. mv (移动或更改文件、目录名称)
执行格式: mv source destination
例: mv file1 file2 将文件 file1,更名为 file2
mv file1 dir1 将文件 file1,移到目录 dir1 下
5 mv dir1 dir2 将目录dir1移到目录dir2下
5. diff (比较文件(可以是二进制的) 或目录的内容)
执行格式: diff [-r]name1 name2 (name1、name2 同为文件或目录) 例: diff file1 file2 比较 file1 与 file2 的不同处
diff -rdir1 dir2 比较 dir1 与 dir2 的不同处
6. grep (文件中字符串的查找)
执行格式:grep string file
例: grep abc file1 查找并列出串 abc 所在的整行文字
7. 文件或命令的路径寻找
执行格式一:whereis command 显示命令的路径
执行格式二:which command 显示路径及使用者所定义的别名 执行格式三:whatis command 显示命令的功能摘要
6 8. ln (建立文件或目录的链接)
例: ln source target1 建立source 文件(已存在) 的硬链接, 命名为target1
ln -s source target2 建立source 文件的符号链接, 命名为target2
三、系统询问及权限口令
1. who (查看系统中的使用者)
执行格式: who
2. chmod (文件属性的设置)
改变文件或目录的读、写、执行的允许权
执行格式: chmod [-R]mode name
其中:[-R]为递归处理, 将指定目录下所有文件及子目录一并处理
mode 为3位数字,是文件/目录读、写、执行允许权的缩写(r:read,数字代号为"4", w:write,数字代号为"2", x:execute,数字代号为"1")
7 mode : rwx rwx rwx 代表:
user group other
缩写: (u) (g) (o)
例:chmod 755 dir1 将目录dir1设定成任何人皆有读取及执行的权利,但只有拥有者可作写修改。其中7=4+2+1,5=4+1
chmod 700 file1 将 file1 设为拥有者可以读、写和执行
chmod u+x file2 将 file2,增加拥有者可执行的权利
chmod g+x file3 将 file3,增加组使用者可执行的权利
chmod o-rfile4 将 file4,除去其它使用者可读取的权利
3.chown (改变文件或目录所有权)
执行格式: chown [-R]username file/dirname
例: chown user file1 将文件 file1 改为 user 所有
chown -Ruser dir1 将目录dir1及其下所有文件和子目录,改为user 所有
4. groups (检查用户所在组名称)
执行格式: groups
5. chgrp (改变文件或目录的组拥有权)
执行格式: chgrp [-R]groupname file/dirname
例:chgrp vlsi file1 将文件 file1 改为 vlsi 组所有
chgrp -Rimage dir1 将目录 dir1 及其下所有文件和子目录,改为 image 群组
6. touch (改变文件或目录的最后修改时间)
执行格式:
touch file/dirname
8
四、进程操作
1. ps (查看系统目前的进程)
执行格式: ps [-aux]
例: ps 或 ps -x查看系统中属于自己的 process
ps -au查看系统中所有使用者的 process
ps -aux查看系统中包含系统内部及所有使用者的 process
ps -aux|grep apache 找出系统中运行的所有名称中带有"apache" 串的 process
2. jobs (查看正在 background 中执行的 process )
执行格式: jobs
3. kill (结束或终止进程)
执行格式: kill PID (PID 为利用ps 命令所查出的 process ID)
例: kill 456终止 process ID 为 456 的 process
4. command+& (后台执行 process )
执行格式: command &(在命令后加上&)
例: gcc file1 &在后台编译 file1.c
注意:按下^Z,暂停正在执行的process 。键入”bg ”,将所暂停的process 置入background 中继续执行。例: gcc file1 &
^Z
9 stopped
bg
5. kill% (结束或终止在 background 中的进程)
执行格式: kill %n
例: kill %1 终止在 background 中的第一个 job
kill %2 终止在 background 中的第二个 job
6. top (显示系统中程序的执行状态)
例: top 不断地更新、显示系统程序的执行状态
第一行显示的项目依次为当前时间、系统启动时间、当前系统登录用户数目、平均负载。 第二行为进程情况,依次为进程总数、运行进程数、休眠进程数、终止进程数、僵死进程数。 第三行为CPU 状态,依次为用户占用、系统占用、优先进程占用、闲置进程占用。
第四行为内存状态,依次为平均可用内存、已用内存、空闲内存、共享内存、缓存使用内存。 第五行为交换状态,依次为平均可用交换容量、已用容量、闲置容量、高速缓存容量。 PID 每个进程的ID 。
PPID 每个进程的父进程ID 。
UID 每个进程所有者的UID 。
USER 每个进程所有者的用户名。
PRI 每个进程的优先级别。
NI 该进程的优先级值。
SIZE 该进程的代码大小加上数据大小再加上堆栈空间大小的总数。单位是KB 。
TSIZE 该进程的代码大小。对于内核进程这是一个很奇怪的值。
DSIZE 数据和堆栈的大小。
TRS 文本驻留大小。
D 被标记为“不干净”的页项目。
LIB 使用的库页的大小。对于ELF 进程没有作用。
RSS 该进程占用的物理内存的总数量,单位是KB 。
SHARE 该进程使用共享内存的数量。
STAT 该进程的状态。其中S 代表休眠状态;D 代表不可中断的休眠状态;R 代表运行状态;Z 代表僵死状态;T 代表停止或跟踪状态。
10 TIME 该进程自启动以来所占用的总CPU 时间。如果进入的是累计模式,那么该时间还包括这个进程子进程所占用的时间。且标题会变成CTIME 。
%CPU 该进程自最近一次刷新以来所占用的CPU 时间和总时间的百分比。
%MEM 该进程占用的物理内存占总内存的百分比。
COMMAND 该进程的命令名称,如果一行显示不下,则会进行截取。内存中的进程会有一个完整的命令行按"ctrl+c"停止查看
7. pstree (以树状图显示执行的程序)
例: pstree -h 列出进程树并高亮标出当前执行的程序
8. vmstat (监视虚拟内存)
vmstat 对系统的虚拟内存、进程、CPU 活动进行监视,同时它也对磁盘和forks 和vforks 操作的个数进行汇总。
不足是:vmstat 不能对某个进程进行深入分析,它仅是一对系统的整体情况进行分析。
其中:
Procs
r: 等待运行的进程数 b: 处在非中断睡眠状态的进程数 w: 被交换出去的可运行的进程数。 Memory
swpd: 虚拟内存使用情况,单位:KB free: 空闲的内存,单位KB
buff: 被用来做为缓存的内存数,单位:KB
Swap
si: 从磁盘交换到内存的交换页数量,单位:KB/秒 so: 从内存交换到磁盘的交换页数量,单位:KB/秒
IO
bi: 发送到块设备的块数,单位:块/秒 bo: 从块设备接收到的块数,单位:块/秒 System
in: 每秒的中断数,包括时钟中断 cs: 每秒的环境(上下文)切换次数
CPU 按 CPU 的总使用百分比来显示
us: CPU 使用时间 sy: CPU 系统使用时间 id: 闲置时间
9. ipcs (分析共享内存、信号量和消息队列,相关命令ipcrm :用于给有权限的用户清除这些量,注意不要乱清除,除非该量确实失效了)
cof-lee
2018.01.03
问题解答:
我来补答