练习题二下

1.1 第8题

linux 系统运行级别一般为 0-6,请分别写出每个级别的含义。

1.1.1 运行级别的含义

0 关机

1 单用户模式

2 多用户模式 没有NFS

3 完全的多用户 命令行模式

4 没有使用

5 图形化界面模式

6 重启

1.1.2 临时切换运行级别

init 5 临时修改

1.1.3 查看运行级别

runlevel 显示运行级别

1.1.4 永久修改运行级别

修改文件 /etc/inittab

1.2 第9题

希望防火墙,仅在 3 级别上开机自启动,该如何做?

1.2.1 --level

在--level后加数字指定运行级别 on 开 off 关

[root@znix ~]# chkconfig --level 3  iptables on

[root@znix ~]# chkconfig |grep ipt

iptables       0:off   1:off   2:off   3:on    4:off   5:off   6:off

[root@znix ~]# chkconfig --level 3  iptables off

[root@znix ~]# chkconfig |grep ipt

iptables        0:off   1:off   2:off   3:off   4:of

1.3 第13题

etc/目录为 linux 系统的默认的配置文件及服务启动命令的目录

   a.请用 tar打包/etc 整个目录(打包及压缩)

   b.请用 tar打包/etc 整个目录(打包及压缩,但需要排除/etc/services 文件)

   c.请把 a 点命令的压缩包,解压到/tmp 指定目录下(最好只用 tar命令实现)

1.3.1 创建压缩包

创建压缩包的时候尽量使用相对路径

[root@znix ~]# tar zcvf  /tmp/etc.tar.gz     /etc/

筐(压缩包的名字) 要压缩的文件

[root@znix ~]# ls -lh /tmp/etc.tar.gz

-rw-r--r-- 1 root root 9.3M Aug 25 09:34 /tmp/etc.tar.gz

z----压缩工具 gzip  通过gzip软件进行压缩

c----create 创建压缩包

v----显示 创建/解压 的过程

f----指定压缩包的位置和名字

1.3.2 查看压缩包的内容

查看压缩包的内容时可以不加z参数,系统会自动选择。

[root@znix tmp]# tar ztf etc.tar.gz

t----显示或者列表

1.3.3 解压缩

解压不指定路径的时候会解压到当前路径。

[root@znix tmp]# tar zxf etc.tar.gz

x----extract 解压

指定解压路径

-C (大写c) 指定解压路径

[root@znix ~]# tar xf /tmp/etc.tar.gz  -C /tmp/

[root@znix ~]# ls -ld /etc/

drwxr-xr-x. 78 root root 4096 Aug 25 09:42 /etc/

1.3.4 排除指定文件

--exclude  后面加上等号填上要排除的文件

[root@znix /]# tar zcf /tmp/etc-paichu.tar.gz /etc/ --exclude=etc/services

[root@znix /]# tar tf /tmp/etc-paichu.tar.gz |grep "services"

etc/init/readahead-disable-services.conf

1.3.5 压缩时的提示

Removing leading `/' from member names

把压缩包中的文件最前面的斜线删除

压缩包里的内容 绝对路径>>>相对路径

原因:

解压的时候会按照压缩包内的路径进行解压,从根目录打包会覆盖其他文件

系统解决办法:

出于安全的考虑,把绝对路径前面的'/'去掉,变成相对路径

1.3.6 相对路径压缩

先进入根目录再进行压缩。

[root@znix /]# tar zcf /tmp/etc.tar.gz etc/

一条命令,进入根目录并且压缩。

[root@znix ~]# cd / && tar zcf /tmp/data.tar.gz etc/

&& 表示前面的执行好了,再执行后面的

[root@znix ~]# cd / && tar zcf /tmp/etcbak.tar.gz etc/

[root@znix /]# ll /tmp/etcbak.tar.gz

-rw-r--r-- 1 root root 9733401 Aug 25 10:54 /tmp/etcbak.tar.gz

1.4 第13题

创建环境

[root@znix /]# mkdir /oldboy ; echo "I am oldboy,myqq is 31333741">/oldboy/oldboy.txt

[root@znix oldboy]# cat oldboy.txt

I am oldboy,myqq is 31333741

现在需要从文件中过滤出“oldboy”和“31333741”字符串,请给出命令。

1.4.1 方法一 sed+sed

先用sed命令将前面的部分替换为空,经过管道,sed在将后面的部分替换为空。

[root@znix oldboy]# sed 's#I am ##g' oldboy.txt |sed 's#,myqq is##g'

oldboy 31333741

1.4.2 方法二 sed+awk

sed将逗号换为空格,awk以空格为分隔符,print输出列的内容,$3表示第三列,$NF 表示最后一列

[root@znix oldboy]# sed 's#,# #g' oldboy.txt |awk '{print $3,$NF}'

oldboy 31333741

1.4.3 方法三 awk

使用-F指定分隔符,这里指定为逗号和空格,print 需要在{}中才可以使用。

-F 指定分隔符,表示每一列的结束标记

[root@znix oldboy]# awk -F "[, ]" '{print $3,$6}' oldboy.txt

oldboy 31333741

1.4.4 方法四 sed+cut

先用sed将逗号替换为空格,然后再用cut 切割。

-d 表示用什么切割,这里指定为空格,-f3,6表示第三和六列。

[root@znix oldboy]# sed 's#,# #g' oldboy.txt|cut -d ' ' -f3,6

oldboy 31333741

1.4.5 显示为oldboy,31333741

awk在'{print $3","$NF}'里面写双引号里面写什么就显示什么

[root@znix oldboy]# awk -F "[ ,]"  '{print $3","$NF}' oldboy.txt

oldboy,31333741

1.5 第14题

查看/etc/services文件内容有多少行

1.5.1 显示行数 wc

[root@znix oldboy]# wc -l /etc/services

10774 /etc/services

-l 显示文件有多少行

1.5.2 检查进程是否运行(wc运用)

ps命令,查看正在运行的进程,-ef 显示系统中正在运行的进程

[root@znix ~]# ps -ef

[root@znix ~]# ps -ef|grep "/sshd"

root       1450      1  0 Aug24 ?        00:00:00 /usr/sbin/sshd

root       4965   4846  0 12:32 pts/0    00:00:00 grep /sshd

使用wc命令查看行数

数字大于2时表示程序运行。

[root@znix ~]# ps -ef|grep "/sshd"|wc -l

2

1.6 第15题

过滤出/etc/services  文件包含 3306或 1521 两数据库端口的行的内容。

1.6.1 使用grep命令

[root@znix ~]# grep -E "3306|1521" /etc/services

mysql           3306/tcp                        # MySQL

mysql           3306/udp                        # MySQL

ncube-lm        1521/tcp                # nCube License Manager

ncube-lm        1521/udp                # nCube License Manager

       "|" 表示或者,必须加在引号中。属于正则表达式。

1.6.2 使用egrep

egrep时grep的高级版,与grep -E 相同。

[root@znix ~]# egrep "3306|1521" /etc/services

mysql           3306/tcp                        # MySQL

mysql           3306/udp                        # MySQL

ncube-lm        1521/tcp                # nCube License Manager

ncube-lm        1521/udp                # nCube License Manager

1.7 命令行及shell中加单引号和加双引号的区别

1.7.1 单引号

所见即所得, 单引号里的内容会原封不动的显示出来

[root@znix ~]# echo '$LANG $(hostname)'

$LANG $(hostname)

1.7.2 双引号

会解析里面的特殊符号

[root@znix ~]# echo "$LANG $(hostname)"

en_US.UTF-8 znix

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏pangguoming

Nodejs开发框架Express3.0开发手记–从零开始

转载请注明出处: http://blog.fens.me/nodejs-express3/ 程序代码已经上传到github有需要的同学,自行下载。 http...

40812
来自专栏Samego开发资源

Linux之sed文本处理命令

1624
来自专栏零基础使用Django2.0.1打造在线教育网站

零基础使用Django2.0.1打造在线教育网站(十四):用户密码找回

努力与运动兼备~~~有任何问题可以加我好友或者关注微信公众号,欢迎交流,我们一起进步!

3421
来自专栏好好学java的技术栈

java工程师必备linux常用命令,这篇文章就够了

bash 是一个为GNU计划编写的Unix shell。它的名字是一系列缩写:Bourne-Again SHell — 这是关于Bourne shell(sh)...

3091
来自专栏JavaWeb

Java Source Attacher插件(Eclipse自动下载jar包源码)

4087
来自专栏数据之美

shell 学习笔记(19)

声明:转载需署名出处,严禁用于商业用途! 1801.关于 nohup 后台运行的问题: nohup就是拒绝hup信号,没什么其他用途, 如...

2475
来自专栏用户2442861的专栏

IntelliJ IDEA配置Spark使用

第二步下载插件 首先启动intelliJ IDEA:在命令行终端中,进入$IDEA_HOME/bin目录,输入./idea.sh进行启动,进入如下界面,然后...

4991
来自专栏破晓之歌

Django 开源相册组件介绍 django-photologue

下载地址:https://github.com/jdriscoll/django-photologue

2344
来自专栏Python

linux每日命令(27):chmod命令

chmod命令用于改变linux系统文件或目录的访问权限。用它控制文件或目录的访问权限。该命令有两种用法。一种是包含字母和操作符表达式的文字设定法;另一种是包含...

1041
来自专栏码生

证书报错解决方法:Code=3000 "未找到应用程序的“aps-environment”的授权字符串"

1:如果你的项目中已经添加了 KeychainAccessGroups.plist 文件,在此文件中新增一对键值

4083

扫码关注云+社区

领取腾讯云代金券