什么是linux?
linux是一套免费使用和自由传播的类unix操作系统,是一个基于posix和unix的多用户、多任务、支持多线程和多cpu的操作系统。它能运行主要的unix工具软件、应用程序和网络协议。它支持32位和64位硬件。linux继承了unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。
unix和linux有什么区别?
linux和unix都是功能强大的操作系统,都是应用广泛的服务器操作系统,有很多相似之处,甚至有一部分人错误地认为unix和linux操作系统是一样的,然而,事实并非如此,以下是两者的区别。
什么是 linux 内核?
linux的基本组件是什么?
就像任何其他典型的操作系统一样,linux拥有所有这些组件:内核,shell和gui,系统实用程序和应用程序。linux比其他操作系统更具优势的是每个方面都附带其他功能,所有代码都可以免费下载。
linux 的体系结构
从大的方面讲,linux 体系结构可以分为两块:
为什么 linux 体系结构要分为用户空间和内核空间的原因?
bash和dos之间的基本区别是什么?
linux 开机启动过程?
linux系统缺省的运行级别?
linux 使用的进程间通信方式?
linux 有哪些系统日志文件?
linux系统安装多个桌面环境有帮助吗?
什么是交换空间?
什么是root帐户?
什么是lilo?
什么是bash?
什么是cli?
什么是gui?
开源的优势是什么?
gnu项目的重要性是什么?
简单 linux 文件系统?
linux 支持 5 种文件类型,如下图所示:
linux 的目录结构是怎样的?
linux 文件系统的结构层次鲜明,就像一棵倒立的树,最顶层是其根目录:
常见目录说明:
什么是 inode ?
简述 linux 文件系统通过 i 节点把文件的逻辑结构和物理结构转换的工作过程?
什么是硬链接和软链接?
实际场景下,基本是使用软链接。总结区别如下:
raid 是什么?
一台 linux 系统初始化环境后需要做一些什么安全工作?
什么叫 cc 攻击?什么叫 ddos 攻击?
怎么预防 cc 攻击和 ddos 攻击?
什么是网站数据库注入?
如何过滤与预防?
数据库网页端注入这种,可以考虑使用 nginx_waf 做过滤与预防。
shell 脚本是什么?
什么是默认登录 shell ?
# chsh <用户名> -s <新shell># chsh thinkwon -s /bin/sh
在 shell 脚本中,如何写入注释?
注释可以用来描述一个脚本可以做什么和它是如何工作的。每一行注释以 # 开头。例子如下:
#!/bin/bash # this is a command echo “i am logged in as $user”
可以在 shell 脚本中使用哪些类型的变量?
shell脚本中 $? 标记的用途是什么?
root@localhost:~## ls /usr/bin/shar /usr/bin/shar root@localhost:~## echo $?
root@localhost:~## ls /usr/bin/share ls: cannot access /usr/bin/share: no such file or directory root@localhost:~## echo $? 2
bourne shell(bash) 中有哪些特殊的变量?
下面的表列出了 bourne shell 为命令行设置的特殊变量。
内建变量 解释 $0 命令行中的脚本名字 $1 第一个命令行参数 $2 第二个命令行参数
$9 第九个命令行参数 $## 命令行参数的数量 $* 所有命令行参数,以空格隔开
如何取消变量或取消变量赋值?
unset 命令用于取消变量或取消变量赋值。语法如下所示:
# unset <变量名>
shell 脚本中 if 语法如何嵌套?
if [ 条件 ] then 命令1 命令2 else if [ 条件 ] then 命令1 命令2
else 命令1 命令2
fi fi
在 shell 脚本中如何比较两个数字?
在 if-then 中使用测试命令( -gt 等)来比较两个数字。例如:
#!/bin/bash x=10 y=20 if [ $x -gt $y ] then echo “x is greater than y” else echo “y is greater than x” fi
shell 脚本中 case 语句的语法?
基础语法如下:
case 变量 in 值1) 命令1 命令2 最后命令 !! 值2) 命令1 命令2 最后命令 ;; esac
shell 脚本中 for 循环语法?
基础语法如下:
for 变量 in 循环列表 do 命令1 命令2 …. 最后命令 done
shell 脚本中 while 循环语法?
基础语法:
while [ 条件 ] do 命令… done
do-while 语句的基本格式?
do-while 语句类似于 while 语句,但检查条件语句之前先执行命令(lctt 译注:意即至少执行一次。)。下面是用 do-while 语句的语法:
do { 命令 } while (条件)
shell 脚本中 break 命令的作用?
shell 脚本中 continue 命令的作用?
如何使脚本可执行?
!/bin/bash 的作用?
#!/bin/bash 是 shell 脚本的第一行,称为释伴(shebang)行。
如何调试 shell脚本?
如何将标准输出和错误输出同时重定向到同一位置?
在 shell 脚本中,如何测试文件?
test 命令可以用来测试文件。基础用法如下表格:
test 用法 -d 文件名 # 如果文件存在并且是目录,返回true -e 文件名 # 如果文件存在,返回true -f 文件名 # 如果文件存在并且是普通文件,返回true -r 文件名 # 如果文件存在并可读,返回true -s 文件名 # 如果文件存在并且不为空,返回true -w 文件名 # 如果文件存在并可写,返回true -x 文件名 # 如果文件存在并可执行,返回true
在 shell 脚本如何定义函数呢?
$ diskusage () { df -h ; } 译注:下面是我给的shell函数语法,原文没有 [ function ] 函数名 [()] { 命令; [return int;] }
如何让 shell 就脚本得到来自终端的输入?
read 命令可以读取来自终端(使用键盘)的数据。read 命令得到用户的输入并置于你给出的变量中。例子如下:
# vi /tmp/test.sh #!/bin/bash echo ‘please enter your name’ read name echo “my name is $name” ## ./test.sh please enter your name thinkwon my name is thinkwon
如何执行算术运算?
判断一文件是不是字符设备文件,如果是将其拷贝到 /dev 目录下?
#!/bin/bash read -p "input file name: " filename if [ -c "$filename" ];then cp $filename /dev fi
添加一个新组为 class1 ,然后添加属于这个组的 30 个用户,用户名的形式为 stdxx ,其中 xx 从 01 到 30 ?
#!/bin/bash groupadd class1 for((i=1;i<31;i++)) do if [ $i -le 10 ];then useradd -g class1 std0$i else useradd -g class1 std$i fi done
编写 shell 程序,实现自动删除 50 个账号的功能,账号名为stud1 至 stud50 ?
#!/bin/bash for((i=1;i<51;i++)) do userdel -r stud$i done
写一个 sed 命令,修改 /tmp/input.txt 文件的内容?
[root@~]# cat -n /tmp/input.txt 1 000011111222 2 3 000011111222222 4 11111000000222 5 6 7 111111111111122222222222 8 2211111111 9 112222222 10 1122 11 # 删除所有空行命令 [root@~]## sed '/^$/d' /tmp/input.txt 000011111222 000011111222222 11111000000222 111111111111122222222222 2211111111 112222222 1122 # 插入指定的字符 [root@~]## sed 's#\(11111\)#aaa\1bbb#g' /tmp/input.txt 0000aaa11111bbb222 0000aaa11111bbb222222 aaa11111bbb000000222 aaa11111bbbaaa11111bbb11122222222222 22aaa11111bbb111 112222222 1122
如何选择 linux 操作系统版本?
一般来讲,桌面用户首选 ubuntu ;服务器首选 rhel 或 centos ,两者中首选 centos 。
如何规划一台 linux 主机,步骤是怎样?
请问当用户反馈网站访问慢,你会如何处理?
有哪些方面的因素会导致网站网站访问慢?
针对网站访问慢,怎么去排查?
怎么去解决?
linux 性能调优都有哪几种方法?
cat 命令
cat 命令用于连接文件并打印到标准输出设备上。
cat 主要有三大功能:
# cat filename
# cat > filename
只能创建新文件,不能编辑已有文件。
# cat file1 file2 > file
实例:
# cat -n log2012.log log2013.log
# cat -b log2012.log log2013.log log.log
cat >log.txt <<eof >hello >world >pwd=$(pwd) >eof ls -l log.txt cat log.txt hello world pwd=/opt/soft/test
tac log.txt pwd=/opt/soft/test world hello
chmod 命令
以文件 log2012.log 为例:
# -rw-r--r-- 1 root root 296k 11-13 06:03 log2012.log
第一列共有 10 个位置,第一个字符指定了文件类型。在通常意义上,一个目录也是一个文件。如果第一个字符是横线,表示是一个非目录的文件。如果是 d,表示是一个目录。从第二个字符开始到第十个 9 个字符,3 个字符一组,分别表示了 3 组用户对文件或者目录的权限。权限字符用横线代表空许可,r 代表只读,w 代表写,x 代表可执行。
常用参数:
-c # 当发生改变时,报告处理信息 -r # 处理指定目录以及其子目录下所有文件
权限范围:
u :# 目录或者文件的当前的用户 g :# 目录或者文件的当前的群组 o :# 除了目录或者文件的当前用户或群组之外的用户或者群组 a :# 所有的用户及群组
权限代号:
r :# 读权限,用数字4表示 w :# 写权限,用数字2表示 x :# 执行权限,用数字1表示 - :# 删除权限,用数字0表示 s :# 特殊权限
实例:
# chmod a+x t.log
# chmod u=r t.log -c
# chmod 751 t.log -c(或者:chmod u=rwx,g=rx,o=x t.log -c)
# chmod u+r,g+r,o+r -r text/ -c
chown 命令
-c # 显示更改的部分的信息 -r # 处理指定目录及子目录
实例:
# chown -c mail:mail log2012.log
# chown -c :mail t.log
# chown -cr mail: test/
cp 命令
-i # 提示 -r # 复制目录及目录内所有项目 -a # 复制的文件与原文件时间一样
实例:
# cp -ai a.txt test
# cp -s a.txt link_a.txt
find 命令
用于在文件树中查找文件,并作出相应的处理。
# find pathname -options [-print -exec -ok ...]
pathname: # find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。 -print: # find命令将匹配的文件输出到标准输出。 -exec: # find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' { } \;,注意{ }和\;之间的空格。 -ok: # 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。
-name # 按照文件名查找文件 -perm # 按文件权限查找文件 -user # 按文件属主查找文件 -group # 按照文件所属的组来查找文件。 -type # 查找某一类型的文件,诸如: b - # 块设备文件 d - # 目录 c - # 字符设备文件 l - # 符号链接文件 p - # 管道文件 f - # 普通文件
实例:
# find -atime -2
# find ./ -name '*.log'
# find /opt -perm 777
# find -size +1000c
# find -size 1000c
-exec 参数后面跟的是 command 命令,它的终止是以 ; 为结束标志的,所以这句命令后面的分号是不可缺少的,考虑到各个系统中分号会有不同的意义,所以前面加反斜杠。{} 花括号代表前面find查找出来的文件名。
head 命令
head 用来显示档案的开头至标准输出中,默认 head 命令打印其相应文件的开头 10 行。
# -n<行数> 显示的行数(行数为复数表示从最后向前数)
实例:
# head 1.log -n 20
# head -c 20 log2014.log
# head -n -10 t.log
less 命令
less 与 more 类似,但使用 less 可以随意浏览文件,而 more 仅能向前移动,却不能向后移动,而且 less 在查看之前不会加载整个文件。
-i # 忽略搜索时的大小写 -n # 显示每行的行号 -o <文件名> # 将less 输出的内容在指定文件中保存起来 -s # 显示连续空行为一行 /字符串: # 向下搜索“字符串”的功能 ?字符串: # 向上搜索“字符串”的功能 n: # 重复前一个搜索(与 / 或 ? 有关) n: # 反向重复前一个搜索(与 / 或 ? 有关) -x <数字> # 将“tab”键显示为规定的数字空格 b # 向后翻一页 d # 向后翻半页 h # 显示帮助界面 q # 退出less 命令 u # 向前滚动半页 y # 向前滚动一行 # 空格键 滚动一行 # 回车键 滚动一页 [pagedown]: # 向下翻动一页 [pageup]: # 向上翻动一页
实例:
# ps -aux | less -n
# less 1.log 2.log
可以使用 n 查看下一个,使用 p 查看前一个。
ln 命令
功能是为文件在另外一个位置建立一个同步的链接,当在不同目录需要该问题时,就不需要为每一个目录创建同样的文件,通过 ln 创建的链接(link)减少磁盘占用量。
链接分类:软件链接及硬链接
需要注意:
常用参数:
-b # 删除,覆盖以前建立的链接 -s # 软链接(符号链接) -v # 显示详细处理过程
实例:
# ln -sv source.log link.log
# ln -v source.log link1.log
# ln -sv /opt/soft/test/test3 /opt/soft/test/test5
locate 命令
locate 通过搜寻系统内建文档数据库达到快速找到档案,数据库由 updatedb 程序来更新,updatedb 是由 cron daemon 周期性调用的。默认情况下 locate 命令在搜寻数据库时比由整个由硬盘资料来搜寻资料来得快,但较差劲的是 locate 所找到的档案若是最近才建立或 刚更名的,可能会找不到,在内定值中,updatedb 每天会跑一次,可以由修改 crontab 来更新设定值 (etc/crontab)。
locate 与 find 命令相似,可以使用如 *、? 等进行正则匹配查找
-l num # (要显示的行数) -f # 将特定的档案系统排除在外,如将proc排除在外 -r # 使用正则运算式做为寻找条件
实例:
# locate pwd
# locate /etc/sh
# locate -r '^/var.*reason$'(其中.表示一个字符,*表示任务多个;.*表示任意多个字符)
more 命令
功能类似于 cat, more 会以一页一页的显示方便使用者逐页阅读,而最基本的指令就是按空白键(space)就往下一页显示,按 b 键就会往回(back)一页显示。
+n # 从笫 n 行开始显示 -n # 定义屏幕大小为n行 +/pattern # 在每个档案显示前搜寻该字串(pattern),然后从该字串前两行之后开始显示 -c # 从顶部清屏,然后显示 -d # 提示“press space to continue,’q’ to quit(按空格键继续,按q键退出)”,禁用响铃功能 -l # 忽略ctrl+l(换页)字符 -p # 通过清除窗口而不是滚屏来对文件进行换页,与-c选项相似 -s # 把连续的多个空行显示为一行 -u # 把文件内容中的下画线去掉
常用操作命令:
enter # 向下 n 行,需要定义。默认为 1 行 ctrl+f # 向下滚动一屏 空格键 # 向下滚动一屏 ctrl+b # 返回上一屏 = # 输出当前行的行号 :f # 输出文件名和当前行的行号 v # 调用vi编辑器 !命令 # 调用shell,并执行命令 q # 退出more
实例:
# more +3 text.txt
# ls -l | more -5
按空格显示下 5 行。
mv 命令
移动文件或修改文件名,根据第二参数类型(如目录,则移动文件;如为文件则重命令该文件)。
当第二个参数为目录时,第一个参数可以是多个以空格分隔的文件或目录,然后移动第一个参数指定的多个文件到第二个参数指定的目录中。
实例:
# mv test.log test1.txt
# mv llog1.txt log2.txt log3.txt /test3
# mv -i log1.txt log2.txt
(4)移动当前文件夹下的所有文件到上一级目录
# mv * ../
rm 命令
删除一个目录中的一个或多个文件或目录,如果没有使用 -r 选项,则 rm 不会删除目录。如果使用 rm 来删除文件,通常仍可以将该文件恢复原状。
# rm [选项] 文件
实例:
# rm -i *.log
# rm -rf test
# rm -- -f*
tail 命令
用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件。
-f 循环读取 # (常用于查看递增的日志文件) -n<行数> # 显示行数(从后向前)
# ping 127.0.0.1 > ping.log &
后台运行:可使用 jobs -l 查看,也可使用 fg 将其移到前台运行。
# tail -f ping.log
(查看日志)
touch 命令
linux touch命令用于修改文件或者目录的时间属性,包括存取时间和更改时间。若文件不存在,系统会建立一个新的文件。
ls -l 可以显示档案的时间记录。
# touch [-acfm][-d<日期时间>][-r<参考文件或目录>] [-t<日期时间>][--help][--version][文件或目录…]
a # 改变档案的读取时间记录。 m # 改变档案的修改时间记录。 c # 假如目的档案不存在,不会建立新的档案。与 --no-create 的效果一样。 f # 不使用,是为了与其他 unix 系统的相容性而保留。 r # 使用参考档的时间记录,与 --file 的效果一样。 d # 设定时间与日期,可以使用各种不同的格式。 t # 设定档案的时间记录,格式与 date 指令相同。 –no-create # 不会建立新档案。 –help # 列出指令格式。 –version # 列出版本讯息。
实例:
#$ touch testfile #修改文件的时间属性
# $ ls -l testfile #查看文件的时间属性 # 原来文件的修改时间为16:09 # -rw-r--r-- 1 hdd hdd 55 2011-08-22 16:09 testfile
# $ touch testfile #修改文件时间属性为当前系统时间 # $ ls -l testfile #查看文件的时间属性 # 修改后文件的时间属性为当前系统时间 # -rw-r--r-- 1 hdd hdd 55 2011-08-22 19:53 testfile
使用指令"touch"时,如果指定的文件不存在,则将创建一个新的空白文件。例如,在当前目录下,使用该指令创建一个空白文件"file",输入如下命令:
# $ touch file #创建一个名为“file”的新的空白文件
vim 命令
vim是从 vi 发展出来的一个文本编辑器。代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。
基本上 vi/vim 共分为三种模式,分别是命令模式(command mode),输入模式(insert mode)和底线命令模式(last line mode)。
简单的说,我们可以将这三个模式想成底下的图标来表示:
whereis 命令
whereis 命令只能用于程序名的搜索,而且只搜索二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。whereis 及 locate 都是基于系统内建的数据库进行搜索,因此效率很高,而find则是遍历硬盘查找文件。
常用参数:
-b # 定位可执行文件。 -m # 定位帮助文件。 -s # 定位源代码文件。 -u # 搜索默认路径下除可执行文件、源代码文件、帮助文件以外的其它文件。
实例:
# whereis locate
# whereis -s locate
# whereis -m locate
which 命令
在 linux 要查找某个文件,但不知道放在哪里了,可以使用下面的一些命令来搜索:
which # 查看可执行文件的位置。 whereis # 查看文件的位置。 locate # 配合数据库查看文件位置。 find # 实际搜寻硬盘查询文件名称。
which 是在 path 就是指定的路径中,搜索某个系统命令的位置,并返回第一个搜索结果。使用 which 命令,就可以看到某个系统命令是否存在,以及执行的到底是哪一个位置的命令。
常用参数:
# -n 指定文件名长度,指定的长度必须大于或等于所有文件中最长的文件名。
实例:
# which ls
# which which
# which cd(显示不存在,因为 cd 是内建命令,而 which 查找显示是 path 中的命令)
查看当前 path 配置:
# echo $path
或使用 env 查看所有环境变量及对应值
grep 命令
强大的文本搜索命令,grep(global regular expression print) 全局正则表达式搜索。
grep 的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到标准输出,不影响原文件内容。
命令格式:
# grep [option] pattern file|dir
常用参数:
-a n --after-context显示匹配字符后n行 -b n --before-context显示匹配字符前n行 -c n --context 显示匹配字符前后n行 -c --count 计算符合样式的列数 -i # 忽略大小写 -l # 只列出文件内容符合指定的样式的文件名称 -f # 从文件中读取关键词 -n # 显示匹配内容的所在文件中行数 -r # 递归查找文件夹
grep 的规则表达式:
^ #锚定行的开始 如:'^grep'匹配所有以grep开头的行。 $ #锚定行的结束 如:'grep$'匹配所有以grep结尾的行。 . #匹配一个非换行符的字符 如:'gr.p'匹配gr后接一个任意字符,然后是p。 * #匹配零个或多个先前字符 如:'*grep'匹配所有一个或多个空格后紧跟grep的行。 .* #一起用代表任意字符。 [] #匹配一个指定范围内的字符,如'[gg]rep'匹配grep和grep。 [^] #匹配一个不在指定范围内的字符,如:'[^a-fh-z]rep'匹配不包含a-r和t-z的一个字母开头,紧跟rep的行。 \(..\) #标记匹配字符,如'\(love\)',love被标记为1。 \< #锚定单词的开始,如:'\<grep'匹配包含以grep开头的单词的行。 \> #锚定单词的结束,如'grep\>'匹配包含以grep结尾的单词的行。 x\{m\} #重复字符x,m次,如:'0\{5\}'匹配包含5个o的行。 x\{m,\} #重复字符x,至少m次,如:'o\{5,\}'匹配至少有5个o的行。 x\{m,n\} #重复字符x,至少m次,不多于n次,如:'o\{5,10\}'匹配5--10个o的行。 \w #匹配文字和数字字符,也就是[a-za-z0-9],如:'g\w*p'匹配以g后跟零个或多个文字或数字字符,然后是p。 \w #\w的反置形式,匹配一个或多个非单词字符,如点号句号等。 \b #单词锁定符,如: '\bgrep\b'只匹配grep。
实例:
# ps -ef | grep svn
# ps -ef | grep svn -c
# cat test1.txt | grep -f key.log
# grep -lr '^grep' /tmp
# grep '^[^x]' test.txt
# grep -e 'ed|at' test.txt
wc 命令
wc(word count)功能为统计指定的文件中字节数、字数、行数,并将统计结果输出
命令格式:
# wc [option] file
命令参数:
-c # 统计字节数 -l # 统计行数 -m # 统计字符数 -w # 统计词数,一个字被定义为由空白、跳格或换行字符分隔的字符串
实例:
# wc text.txt
# 7 8 70 test.txt
# cat test.txt | wc -l
cd 命令
# cd [目录名]
说明:切换当前目录至 dirname。
实例:
# cd /
# cd ~
# cd -
# cd !$
df 命令
显示磁盘空间使用情况。获取硬盘被占用了多少空间,目前还剩下多少空间等信息,如果没有文件名被指定,则所有当前被挂载的文件系统的可用空间将被显示。默认情况下,磁盘空间将以 1kb 为单位进行显示,除非环境变量 posixly_correct 被指定,那样将以512字节为单位进行显示:
-a # 全部文件系统列表 -h # 以方便阅读的方式显示信息 -i # 显示inode信息 -k # 区块为1024字节 -l # 只显示本地磁盘 -t # 列出文件系统类型
实例:
# df -l
# df -hat
du 命令
du 命令也是查看使用空间的,但是与 df 命令不同的是 linux du 命令是对文件和目录磁盘使用的空间的查看:
# du [选项] [文件]
-a # 显示目录中所有文件大小 -k # 以kb为单位显示文件大小 -m # 以mb为单位显示文件大小 -g # 以gb为单位显示文件大小 -h # 以易读方式显示文件大小 -s # 仅显示总计 -c或--total # 除了显示个别目录或文件的大小外,同时也显示所有目录或文件的总和
实例:
# du -h scf/
# du -ah scf/
# du -hc test/ scf/
# du -hc --max-depth=1 scf/
ls命令
就是 list 的缩写,通过 ls 命令不仅可以查看 linux 文件夹包含的文件,而且可以查看文件权限(包括目录、文件夹、文件权限)查看目录信息等等。
常用参数搭配:
ls -a # 列出目录所有文件,包含以.开始的隐藏文件 ls -a # 列出除.及..的其它文件 ls -r # 反序排列 ls -t # 以文件修改时间排序 ls -s #以文件大小排序 ls -h # 以易读大小显示 ls -l # 除了文件名之外,还将文件的权限、所有者、文件大小等信息详细列出来
实例:
# ls -lhrt
# ls -lrs
# ls -l t*
# ls | sed "s:^:`pwd`/:"
# find $pwd -maxdepth 1 | xargs ls -ld
mkdir 命令
mkdir 命令用于创建文件夹。
可用选项:
实例:
# mkdir t
# mkdir -p /tmp/test/t1/t
pwd 命令
pwd 命令用于查看当前工作目录路径。
实例:
# pwd
# pwd -p
rmdir 命令
从一个目录中删除一个或多个子目录项,删除某目录时也必须具有对其父目录的写权限。
注意:不能删除非空目录
实例:
# rmdir -p parent/child/child11
ifconfig 命令:
iptables 命令:
iptables ,是一个配置 linux 内核防火墙的命令行工具。功能非常强大,对于我们开发来说,主要掌握如何开放端口即可。例如:
# iptables -a input -p tcp --dport 80 -j accep
netstat 命令
linux netstat命令用于显示网络状态。
利用netstat指令可让你得知整个linux系统的网络情况。
语法:
# netstat [-accefghilmnnoprstuvvwx][-a<网络类型>][--ip]
参数说明:
-a或–all # 显示所有连线中的socket。 -a<网络类型>或–<网络类型> # 列出该网络类型连线中的相关地址。 -c或–continuous # 持续列出网络状态。 -c或–cache # 显示路由器配置的快取信息。 -e或–extend # 显示网络其他相关信息。 -f或–fib # 显示fib。 -g或–groups # 显示多重广播功能群组组员名单。 -h或–help # 在线帮助。 -i或–interfaces # 显示网络界面信息表单。 -l或–listening # 显示监控中的服务器的socket。 -m或–masquerade # 显示伪装的网络连线。 -n或–numeric # 直接使用ip地址,而不通过域名服务器。 -n或–netlink或–symbolic # 显示网络硬件外围设备的符号连接名称。 -o或–timers # 显示计时器。 -p或–programs # 显示正在使用socket的程序识别码和程序名称。 -r或–route # 显示routing table。 -s或–statistice # 显示网络工作信息统计表。 -t或–tcp # 显示tcp传输协议的连线状况。 -u或–udp # 显示udp传输协议的连线状况。 -v或–verbose # 显示指令执行过程。 -v或–version # 显示版本信息。 -w或–raw # 显示raw传输协议的连线状况。 -x或–unix # 此参数的效果和指定"-a unix"参数相同。 –ip或–inet # 此参数的效果和指定"-a inet"参数相同。
实例:
[root@centos6 ~ 13:20 #55]# netstat -lnp active internet connections (only servers) proto recv-q send-q local address foreign address state pid/program name tcp 0 0 0.0.0.0:22 0.0.0.0:* listen 1035/sshd tcp 0 0 :::22 :::* listen 1035/sshd udp 0 0 0.0.0.0:68 0.0.0.0:* 931/dhclient active unix domain sockets (only servers) proto refcnt flags type state i-node pid/program name path unix 2 [ acc ] stream listening 6825 1/init @/com/ubuntu/upstart unix 2 [ acc ] stream listening 8429 1003/dbus-daemon /var/run/dbus/system_bus_socket
[root@centos6 ~ 13:22 #58]# netstat -an active internet connections (servers and established) proto recv-q send-q local address foreign address state tcp 0 0 0.0.0.0:22 0.0.0.0:* listen tcp 0 0 192.168.147.130:22 192.168.147.1:23893 established tcp 0 0 :::22 :::* listen udp 0 0 0.0.0.0:68 0.0.0.0:*
用 netstat 命令配合其他命令,按照源 ip 统计所有到 80 端口的 established 状态链接的个数?
严格来说,这个题目考验的是对 awk 的使用。
首先,使用 netstat -an|grep established 命令。结果如下:
tcp 0 0 120.27.146.122:80 113.65.18.33:62721 established tcp 0 0 120.27.146.122:80 27.43.83.115:47148 established tcp 0 0 120.27.146.122:58838 106.39.162.96:443 established tcp 0 0 120.27.146.122:52304 203.208.40.121:443 established tcp 0 0 120.27.146.122:33194 203.208.40.122:443 established tcp 0 0 120.27.146.122:53758 101.37.183.144:443 established tcp 0 0 120.27.146.122:27017 23.105.193.30:50556 established
ping 命令
linux ping命令用于检测主机。
执行ping指令会使用icmp传输协议,发出要求回应的信息,若远端主机的网络功能没有问题,就会回应该信息,因而得知该主机运作正常。
# ping -c 2 www.baidu.com
telnet 命令
linux telnet命令用于远端登入。
执行telnet指令开启终端机阶段作业,并登入远端主机。
语法:
# telnet [-8acdeffklrx][-b<主机别名>][-e<脱离字符>][-k<域名>][-l<用户名称>][-n<记录文件>][-s<服务类型>][-x<认证形态>][主机名称或ip地址<通信端口>]
参数说明:
-8 # 允许使用8位字符资料,包括输入与输出。 -a # 尝试自动登入远端系统。 -b<主机别名> # 使用别名指定远端主机名称。 -c # 不读取用户专属目录里的.telnetrc文件。 -d # 启动排错模式。 -e<脱离字符> # 设置脱离字符。 -e # 滤除脱离字符。 -f # 此参数的效果和指定"-f"参数相同。 -f # 使用kerberos v5认证时,加上此参数可把本地主机的认证数据上传到远端主机。 -k<域名> # 使用kerberos认证时,加上此参数让远端主机采用指定的领域名,而非该主机的域名。 -k # 不自动登入远端主机。 -l<用户名称> # 指定要登入远端主机的用户名称。 -l # 允许输出8位字符资料。 -n<记录文件> # 指定文件记录相关信息。 -r # 使用类似rlogin指令的用户界面。 -s<服务类型> # 设置telnet连线所需的ip tos信息。 -x # 假设主机有支持数据加密的功能,就使用它。 -x<认证形态> # 关闭指定的认证形态。
实例:
# 登录ip为 192.168.0.5 的远程主机 telnet 192.168.0.5
date 命令
显示或设定系统的日期与时间。
命令参数:
-d<字符串> # 显示字符串所指的日期与时间。字符串前后必须加上双引号。 -s<字符串> # 根据字符串来设置日期与时间。字符串前后必须加上双引号。 -u # 显示gmt。 %h # 小时(00-23) %i # 小时(00-12) %m # 分钟(以00-59来表示) %s # 总秒数。起算时间为1970-01-01 00:00:00 utc。 %s # 秒(以本地的惯用法来表示) %a # 星期的缩写。 %a # 星期的完整名称。 %d # 日期(以01-31来表示)。 %d # 日期(含年月日)。 %m # 月份(以01-12来表示)。 %y # 年份(以00-99来表示)。 %y # 年份(以四位数来表示)。
实例:
# date +%y%m%d --date="+1 day" //显示下一天的日期
date -d "nov 22" 今年的 11 月 22 日是星期三 date -d '2 weeks' 2周后的日期 date -d 'next monday' (下周一的日期) date -d next-day +%y%m%d(明天的日期)或者:date -d tomorrow +%y%m%d date -d last-day +%y%m%d(昨天的日期) 或者:date -d yesterday +%y%m%d date -d last-month +%y%m(上个月是几月) date -d next-month +%y%m(下个月是几月)
free 命令
显示系统内存使用情况,包括物理内存、交互区内存(swap)和内核缓冲区内存。
命令参数:
-b # 以byte显示内存使用情况 -k # 以kb为单位显示内存使用情况 -m # 以mb为单位显示内存使用情况 -g # 以gb为单位显示内存使用情况 -s<间隔秒数> # 持续显示内存 -t # 显示内存使用总合
实例:
free free -k free -m
# free -t
# free -s 10
kill 命令
发送指定的信号到相应进程。不指定型号将发送sigterm(15)终止指定进程。如果任无法终止该程序可用"-kill" 参数,其发送的信号为sigkill(9) ,将强制结束进程,使用ps命令或者jobs 命令可以查看进程号。root用户将影响用户的进程,非root用户只能影响自己的进程。
常用参数:
-l # 信号,若果不加信号的编号参数,则使用“-l”参数会列出全部的信号名称 -a # 当处理当前进程时,不限制命令名和进程号的对应关系 -p # 指定kill 命令只打印相关进程的进程号,而不发送任何信号 -s # 指定发送信号 -u # 指定用户
实例:
# kill -9 $(ps -ef | grep pro1)
ps 命令
ps(process status),用来查看当前运行的进程状态,一次性查看,如果需要动态连续结果使用 top
ps 工具标识进程的5种状态码:
d # 不可中断 uninterruptible sleep (usually io) r # 运行 runnable (on run queue) s # 中断 sleeping t # 停止 traced or stopped z # 僵死 a defunct (”zombie”) process
命令参数:
-a # 显示所有进程 a # 显示所有进程 -a # 显示同一终端下所有进程 c # 显示进程真实名称 e # 显示环境变量 f # 显示进程间的关系 r # 显示当前终端运行的进程 -aux # 显示所有包含其它使用的进程
实例:
# ps -ef
# ps -a
# ps -aux | grep apache
# ps aux | grep '(cron|syslog)'
rpm 命令
linux rpm 命令用于管理套件。
rpm(redhat package manager) 原本是 red hat linux 发行版专门用来管理 linux 各项套件的程序,由于它遵循 gpl 规则且功能强大方便,因而广受欢迎。逐渐受到其他发行版的采用。rpm 套件管理方式的出现,让 linux 易于安装,升级,间接提升了 linux 的适用度。
# 查看系统自带jdk rpm -qa | grep jdk # 删除系统自带jdk rpm -e --nodeps 查看jdk显示的数据 # 安装jdk rpm -ivh jdk-7u80-linux-x64.rpm
top 命令
显示当前系统正在执行的进程的相关信息,包括进程 id、内存占用率、cpu 占用率等
常用参数:
-c # 显示完整的进程命令 -s # 保密模式 -p # <进程号> 指定进程显示 -n # <次数>循环显示次数
实例:
top - 14:06:23 up 70 days, 16:44, 2 users, load average: 1.25, 1.32, 1.35 tasks: 206 total, 1 running, 205 sleeping, 0 stopped, 0 zombie cpu(s): 5.9%us, 3.4%sy, 0.0%ni, 90.4%id, 0.0%wa, 0.0%hi, 0.2%si, 0.0%st mem: 32949016k total, 14411180k used, 18537836k free, 169884k buffers swap: 32764556k total, 0k used, 32764556k free, 3612636k cached pid user pr ni virt res shr s %cpu %mem time+ command 28894 root 22 0 1501m 405m 10m s 52.2 1.3 2534:16 java
前五行是当前系统情况整体的统计信息区。
第一行,任务队列信息,同 uptime 命令的执行结果,具体参数说明情况如下:
第二行,tasks — 任务(进程),具体信息说明如下:
第三行,cpu状态信息,具体属性说明如下:
5.9%us — # 用户空间占用cpu的百分比。 3.4% sy — # 内核空间占用cpu的百分比。 0.0% ni — # 改变过优先级的进程占用cpu的百分比 90.4% id — # 空闲cpu百分比 0.0% wa — # io等待占用cpu的百分比 0.0% hi — # 硬中断(hardware irq)占用cpu的百分比 0.2% si — # 软中断(software interrupts)占用cpu的百分比
备注:在这里cpu的使用比率和windows概念不同,需要理解linux系统用户空间和内核空间的相关知识!
第四行,内存状态,具体信息如下:
32949016k total — # 物理内存总量(32gb) 14411180k used — # 使用中的内存总量(14gb) 18537836k free — # 空闲内存总量(18gb) 169884k buffers — # 缓存的内存量 (169m)
第五行,swap交换分区信息,具体信息说明如下:
32764556k total — # 交换区总量(32gb) 0k used — # 使用的交换区总量(0k) 32764556k free — # 空闲交换区总量(32gb) 3612636k cached — # 缓冲的交换区总量(3.6gb)
第六行,空行。
第七行以下:各进程(任务)的状态监控,项目列信息说明如下:
pid — # 进程id user — # 进程所有者 pr — # 进程优先级 ni — # nice值。负值表示高优先级,正值表示低优先级 virt — # 进程使用的虚拟内存总量,单位kb。virt=swap+res res — # 进程使用的、未被换出的物理内存大小,单位kb。res=code+data shr — # 共享内存大小,单位kb s — # 进程状态。d=不可中断的睡眠状态 r=运行 s=睡眠 t=跟踪/停止 z=僵尸进程 %cpu — # 上次更新到现在的cpu时间占用百分比 %mem — # 进程使用的物理内存百分比 time+ — # 进程使用的cpu时间总计,单位1/100秒 command — # 进程名称(命令名/命令行)
top 交互命令
h # 显示top交互命令帮助信息 c # 切换显示命令名称和完整命令行 m # 以内存使用率排序 p # 根据cpu使用百分比大小进行排序 t # 根据时间/累计时间进行排序 w # 将当前设置写入~/.toprc文件中 o或者o #改变显示项目的顺序
yum 命令
yum( yellow dog updater, modified)是一个在fedora和redhat以及suse中的shell前端软件包管理器。
基於rpm包管理,能够从指定的服务器自动下载rpm包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软体包,无须繁琐地一次次下载、安装。
yum提供了查找、安装、删除某一个、一组甚至全部软件包的命令,而且命令简洁而又好记。
实例:
安装 pam-devel
# [root@www ~]# yum install pam-devel
bzip2 命令
gzip 命令
tar 命令
用来压缩和解压文件。tar 本身不具有压缩功能,只具有打包功能,有关压缩及解压是调用其它的功能来完成。
弄清两个概念:打包和压缩。打包是指将一大堆文件或目录变成一个总的文件;压缩则是将一个大的文件通过一些压缩算法变成一个小文件
常用参数:
-c # 建立新的压缩文件 -f # 指定压缩文件 -r # 添加文件到已经压缩文件包中 -u # 添加改了和现有的文件到压缩包中 -x # 从压缩包中抽取文件 -t # 显示压缩文件中的内容 -z # 支持gzip压缩 -j # 支持bzip2压缩 -z # 支持compress解压文件 -v # 显示操作过程
有关 gzip 及 bzip2 压缩:
# gzip 实例:压缩 gzip filename .tar.gz 和.tgz 解压:gunzip filename.gz 或 gzip -d filename.gz # 对应:tar zcvf filename.tar.gz tar zxvf filename.tar.gz # bz2实例:压缩 bzip2 -z filename .tar.bz2 解压:bunzip filename.bz2或bzip -d filename.bz2 # 对应:tar jcvf filename.tar.gz 解压:tar jxvf filename.tar.bz2
实例:
# tar -cvf log.tar 1.log,2.log 或tar -cvf log.*
# tar -zcvf /tmp/etc.tar.gz /etc
# tar -ztvf /tmp/etc.tar.gz
# tar --exclude /home/dmtsai -zcvf myfile.tar.gz /home/* /etc
unzip 命令
如对本文有疑问, 点击进行留言回复!!
linux下文本编辑器vim的使用方法(复制、粘贴、替换、行号、撤销、多文件操作)
网友评论