Shell面试题

1.shell是什么,有哪些常用的shell?

Shell是一种命令行解释器,能够解释用户输入的命令并将其转化为操作系统内核可以理解的指令。常用的shell有以下几种:

  1. Bourne Shell(sh):是Unix系统的默认shell,可以在几乎所有的Unix系统上使用,其语法比较基础。

  2. Bash Shell(bash):是Bourne Shell的改进版本,几乎成为了Linux系统默认的shell,也可以在大部分Unix系统上使用。

  3. Korn Shell(ksh):是由AT&T Bell实验室开发的一种Unix shell,语法比Bourne Shell更强大,支持命令补全等特性。

  4. C Shell(csh):是一个与Bourne Shell类似的shell,其语法更加接近C语言的语法,主要用于交互式的使用。

  5. Z Shell(zsh):是一种功能更强大的shell,提供了多种命令行辅助功能,例如路径扩展、命令补全、历史命令搜索等。

在面试中,可能会问到shell的基础语法、常见命令及其用法、重定向、管道、变量、循环、判断等方面的问题。此外,也可能会问到在实际工作中如何利用shell编写脚本来自动化操作、处理数据等。

2.shell脚本编程基础,如变量、判断、循环、函数、数组等。

Shell脚本编程是自动化运维中必备的一项技能,本回答将为您介绍Shell脚本编程的基础知识,包括变量、判断、循环、函数、数组等。

  1. 变量

在Shell脚本中,变量定义时不需要声明类型,赋值方式如下:

variable_name=value

其中,变量名必须以字母或下划线开头,后面跟字母、数字或下划线,等号两侧不能有空格。

使用变量时,用$符号加上变量名,如:

echo $variable_name

注意,变量的值使用双引号引起来时,会被解释器解释为一个字符串,而不是一个变量名。如果要使用变量的值,可以使用${variable_name}形式。

     2.判断

在Shell脚本中,可以使用if语句来进行条件判断,语法如下:

if [ condition ]
then
    command1
    command2
    ...
fi

其中,condition是一个测试条件,可以使用各种测试命令进行测试,例如:

  • -z:判断字符串是否为空;
  • -n:判断字符串是否非空;
  • -eq:判断两个数是否相等;
  • -ne:判断两个数是否不相等;
  • -lt:判断一个数是否小于另一个数;
  • -le:判断一个数是否小于等于另一个数;
  • -gt:判断一个数是否大于另一个数;
  • -ge:判断一个数是否大于等于另一个数;
  • -e:判断文件是否存在;
  • -f:判断文件是否为普通文件;
  • -d:判断文件是否为目录;
  • -x:判断文件是否可执行。

3.循环

在Shell脚本中,可以使用forwhile循环语句来实现循环控制。

for循环语句的语法如下

for variable_name in value1 value2 ... valuen
do
    command1
    command2
    ...
done

其中,variable_name为变量名,value1 value2 ... valuen为可枚举的值,用空格分隔。

while循环语句的语法如下:

while [ condition ]
do
    command1
    command2
    ...
done

其中,condition是一个测试条件,只有当测试条件为真时,循环会一直执行。

4.函数

在Shell脚本中,可以使用函数来封装一段可重复使用的代码。函数定义的语法如下:

function_name () {
    command1
    command2
    ...
    return value
}

其中,function_name为函数名,command1 command2 ...为函数体,return value为返回值。

在函数调用时,使用function_name即可调用函数,并传递参数。具体可以参考下面的示例:

#!/bin/bash

# 定义函数
function print_name {
  echo "Hello, $1"
}

# 调用函数
print_name "Alice"

以上示例中,print_name是一个函数,可以接收一个参数,并输出一个带有参数的字符串。在函数调用时,使用print_name并传递参数"Alice",就可以执行函数并输出结果。

在函数中,还可以使用return语句返回值,例如: 

#!/bin/bash

# 定义函数
function add {
  sum=$(($1 + $2))
  return $sum
}

# 调用函数
add 3 5

# 获取函数返回值
result=$?
echo "3 + 5 = $result"

以上示例中,add是一个函数,接收两个参数,并计算它们的和,然后使用return语句返回结果。在调用函数时,传递参数35,并使用$?获取函数的返回值,最后输出结果。

3. shell中的管道、重定向、正则表达式等相关知识。

管道(|)用于将一个命令的输出传递给另一个命令作为输入,例如:

ls | grep foo

重定向符号(>和<)用于将命令的输入或输出从一个位置转移到另一个位置。例如:

ls > filelist.txt

会将ls命令的输出写入到名为filelist.txt的文件中。

正则表达式是一种强大的文本匹配工具,它允许您根据特定模式搜索和操作文本。在常见的shell工具中,如grep、sed和awk中使用正则表达式来搜索和处理文本数据。例如:

grep 'pattern' file.txt

会在file.txt文件中查找与指定模式匹配的行,并将其输出到屏幕上。

此外,通配符也是一种有用的文本匹配工具,它允许您使用特殊字符来匹配多个字符。在shell中,星号(*)和问号(?)是最常用的通配符。例如:

ls *.txt

会列出当前目录中所有扩展名为.txt的文件。

 grep、sed和awk是常见的Linux/Unix命令行工具,它们都支持正则表达式用于搜索和处理文本数据。

 

  1. grep grep(全称:global regular expression print)是一个强大的文本搜索工具,它使用正则表达式在文件中搜索匹配的文本,并将结果输出到屏幕上或写入文件。常见的用法包括:
  • 搜索单个文件:grep 'pattern' filename
  • 搜索多个文件:grep 'pattern' file1 file2 ...
  • 递归搜索目录下的所有文件:grep -r 'pattern' directory
  1. sed sed(全称:stream editor)是一个非交互式的文本编辑器,它可以自动化执行基本的文本转换任务。sed通常用于从文件或管道流中读取输入,并将转换后的输出写回到文件或发送到另一个进程。常见的用法包括:
  • 替换匹配行中的文本:sed 's/pattern/replacement/g' filename
  • 删除匹配行:sed '/pattern/d' filename
  • 匹配某一行范围内的文本并进行替换:sed '3,5 s/pattern/replacement/g' filename
  1. awk awk是一种类似于sed的文本处理工具,它可以在文件或管道流中执行更复杂的操作,例如格式化文本、计算统计数据等等。awk的主要特点是可以定义变量和函数来处理文本。常见的用法包括:
  • 打印指定列的数据:awk '{print $1,$3}' filename
  • 格式化输出:awk '{printf "%-10s %-8s %s\n", $1, $2, $3}' filename
  • 计算数据:awk '{sum += $1} END {print sum}' filename(计算filename文件中第一列的总和)

4.如何在shell中处理文件,如文件操作、文本处理等。

在shell中,件操作和文本处理是非常常见的任务。以下是一些常用的命令和技巧:

1.文件操作

  • 列出当前目录下的文件:ls
  • 创建新目录:mkdir dirname
  • 移动或重命名文件:mv oldname newname
  • 复制文件:cp source dest
  • 删除文件:rm filename

2.文本处理

  • 查看文件内容:cat filename
  • 压缩/解压文件:gzip filename(压缩), gunzip filename.gz(解压)
  • 按行读取文件内容:while read line; do echo $line; done < filename
  • 搜索匹配文本:grep 'pattern' filename
  • 提取或替换文本:sed -n 's/pattern/replacement/gp' filename
  • 格式化输出:awk '{printf "%-10s %-8s %s\n", $1, $2, $3}' filename

3.文件权限和用户管理

  • 修改文件权限:chmod u+x filename(为当前用户添加可执行权限)
  • 查看当前用户:whoami
  • 查看系统中所有用户:cut -d: -f1 /etc/passwd
  • 添加新用户:sudo adduser username
  • 授权用户sudo权限:sudo usermod -aG sudo username

这些命令只是Linux/Unix shell中可用的众多工具的一部分。熟练掌握这些命令的使用方法可以有效地提高生产力并简化日常管理任务。

提取或替换文本:sed -n 's/pattern/replacement/gp' filename
 

这个命令是在Linux/Unix操作系统中使用sed命令来查找并替换文本的命令。具体解释如下:

  • sed:在Linux/Unix shell中用于处理和转换文本的流编辑器命令。
  • -n:指定sed命令不输出模式空间(匹配的行),只输出经过编辑后的内容。
  • s:表示执行替换操作,将匹配到的字符串替换成固定字符串或者另一个正则表达式。
  • pattern:要匹配的文本(可以使用正则表达式)。
  • replacement:要替换为的文本(可以使用正则表达式)。
  • g:全局替换标记,即替换所有匹配的文本而不仅仅是第一个。
  • p:打印命令,在替换完成后将被编辑的行打印出来。

因此,运行这个命令将会查找filename文件中所有出现的pattern,并将其替换为replacement,并且只输出经过替换的行。如果不加-p参数,则不输出经过替换的行。

格式化输出:awk '{printf "%-10s %-8s %s\n", $1, $2, $3}' filename
 

这个命令是在Linux/Unix操作系统中使用awk命令来格式化输出文本的命令。具体解释如下:

  • awk:在Linux/Unix shell中用于处理和转换文本的流编辑器命令,可以用于格式化文本、计算统计数据等等。

  • '{printf "%-10s %-8s %s\n", $1, $2, $3}':指定了awk的程序,其中printf命令实现了格式化输出功能。

    • %-10s:表示占用10个字符的左对齐字符串(%s)。
    • %-8s:表示占用8个字符的左对齐字符串(%s)。
    • %s\n:表示字符串后换行符。
  • $1, $2, $3:这些是awk的变量,表示当前处理行中的第1、2、3列。

  • filename:要进行处理的文件路径和名称。

因此,运行这个命令将会逐行读取filename文件中的内容,并将每一行的第1、2、3列分别格式化输出。其中第一列占用10个字符的空间,第二列占用8个字符的空间,都是左对齐的。这样可以使得输出看起来更整齐清晰。

查看系统中所有用户:cut -d: -f1 /etc/passwd
 

这个命令是在Linux/Unix操作系统中使用cut命令来截取/etc/passwd文件中的第一列,以冒号为分隔符。具体解释如下:

  • cut:在Linux/Unix shell中用于从文件或输入流中提取文本行、列或字符的命令。
  • -d:指定分隔符,这里使用了冒号作为分隔符。
  • : 指定了分隔符,即冒号。
  • -f1:指定需要提取的字段,这里是第一个字段(即用户名)。
  • /etc/passwd:要进行操作的文件路径和名称。

因此,运行这个命令将会输出/etc/passwd文件中所有用户的用户名,每行一个。

5. 如何进行进程管理和系统管理,如进程的查看和控制、定时任务、系统监控等

在Linux/Unix操作系统中,进程管理和系统管理是非常重要的任务。以下是一些常用的命令和技巧:

1.进程管理

  • 查看当前运行的进程:ps aux
  • 杀死指定的进程:kill pid
  • 根据名称搜索和杀死进程:pkill process_name
  • 后台启动进程:nohup command &
  • 查看进程占用的资源情况:top

2.系统管理

  • 定时执行任务:crontab -e(编辑cron表达式)
  • 查看系统日志文件:tail /var/log/messages
  • 监控系统负载和资源使用情况:htop
  • 查看CPU、内存和磁盘使用情况:free -h, df -h
  • 查看网络连接情况:netstat -an
  • 关闭或重启系统:sudo shutdown -h now(立即关闭计算机),sudo reboot(重新启动计算机)

这些命令只是Linux/Unix shell中可用的众多工具的一部分。熟练掌握这些命令的使用方法可以有效地提高生产力并简化日常管理任务。同时,为了更好地了解和监控系统的状态,我们还可以使用一些第三方工具,如Zabbix、Nagios等,它们可以通过图形化界面展示系统的监控数据,并提供报警、故障诊断等功能。

top是一种在Linux/Unix操作系统中常用的进程管理工具,可以查看当前所有进程的资源占用情况,如CPU、内存、IO等等。有些Linux/Unix系统甚至将top作为默认的进程管理工具。

使用top命令,我们可以实时查看系统的运行状态和各个进程的运行情况,从而快速定位和解决系统性能问题。以下是top命令的常见用法:

  • 查看当前所有进程的信息:直接输入top命令即可。
  • 排序进程:按照CPU使用率(%CPU)、内存使用率(%MEM)或进程ID(PID)排序,使用Shift+P、Shift+M或Shift+N。
  • 查看特定用户的进程:按下U键,输入用户名,然后按Enter即可。
  • 显示或隐藏不同的系统信息:按下数字键1~9,可以切换显示或隐藏不同的系统信息,例如CPU、内存、Swap、进程数等等。
  • 中断或终止指定进程:选中要中断或终止的进程,在命令行输入k或者K,然后输入对应进程的PID,并选择信号类型(通常是15),最后按Enter即可。

总之,top命令是一个非常强大的进程管理工具,在排查系统性能问题和优化系统性能方面都非常有用。使用它可以帮助我们快速了解系统的运行情况并进行必要的调整。

6.如何进行安全管理和用户管理,如权限管理、用户管理、日志查看等。

安全管理和用户管理包括以下步骤:

  1. 权限管理:根据不同的用户权限,设置对应的访问控制策略,确保只有授权用户可以访问受保护的资源或操作。

  2. 用户管理:创建、修改、删除用户账号,并为每个用户分配相应的权限和角色。

  3. 日志查看:查看系统日志、安全日志等,及时发现异常情况和安全事件。

  4. 安全防护:实施网络安全策略,包括防火墙、入侵检测系统、反病毒软件等,保证网络安全和数据安全。

要进行安全管理和用户管理,需要具备相关知识和技能。可以通过学习相关的安全管理和用户管理课程,或参考相应的安全管理手册和文档来获取帮助。同时,也需要了解最新的安全威胁和漏洞,及时更新软件补丁和升级安全防护设备。


 

下面是安全管理和用户管理的具体操作

  1. 权限管理:根据需要,创建不同的用户组或角色,为每个组或角色分配相应的访问权限。可以使用ACL(Access Control List)来设置文件或目录的权限;在数据库中,可以通过GRANT和REVOKE语句来授予或撤销用户的权限。

  2. 用户管理:创建、修改、删除用户账号,并为每个用户分配相应的权限和角色。可以使用命令行工具(如useradd、usermod、userdel等)或GUI界面来管理用户账号。

  3. 日志查看:查看系统日志、安全日志等,及时发现异常情况和安全事件。可以使用命令行工具(如tail、grep等)或专门的日志查看软件来查看日志。

  4. 安全防护:实施网络安全策略,包括防火墙、入侵检测系统、反病毒软件等,保证网络安全和数据安全。可以使用相应的安全设备或软件来提高安全性。

这些操作都需要管理员或具有相关权限的用户执行,并且需要按照安全规范和最佳实践进行操作,确保系统的安全和稳定性。

  • 1
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
一、课程简介随着技术的飞速发展,经过多年的数据积累,各互联网公司已保存了海量的原始数据和各种业务数据,所以数据仓库技术是各大公司目前都需要着重发展投入的技术领域。数据仓库是面向分析的集成化数据环境,为企业所有决策制定过程,提供系统数据支持的战略集合。通过对数据仓库中数据的分析,可以帮助企业改进业务流程、控制成本、提高产品质量等。二、课程内容本次精心打造的数仓项目的课程,从项目架构的搭建,到数据采集模块的设计、数仓架构的设计、实战需求实现、即席查询的实现,我们针对国内目前广泛使用的Apache原生框架和CDH版本框架进行了分别介绍,Apache原生框架介绍中涉及到的技术框架包括Flume、Kafka、Sqoop、MySql、HDFS、Hive、Tez、Spark、Presto、Druid等,CDH版本框架讲解包括CM的安装部署、Hadoop、Zookeeper、Hive、Flume、Kafka、Oozie、Impala、HUE、Kudu、Spark的安装配置,透彻了解不同版本框架的区别联系,将大数据全生态系统前沿技术一网打尽。在过程中对大数据生态体系进行了系统的讲解,对实际企业数仓项目中可能涉及到的技术点都进行了深入的讲解和探讨。同时穿插了大量数仓基础理论知识,让你在掌握实战经验的同时能够打下坚实的理论基础。三、课程目标本课程以国内电商巨头实际业务应用场景为依托,对电商数仓的常见实战指标以及难点实战指标进行了详尽讲解,具体指标包括:每日、周、月活跃设备明细,留存用户比例,沉默用户、回流用户、流失用户统计,最近连续3周活跃用户统计,最近7天内连续3天活跃用户统计,GMV成交总额分析,转化率及漏斗分析,品牌复购率分析、订单表拉链表的设计等,让学生拥有更直观全面的实战经验。通过对本课程的学习,对数仓项目可以建立起清晰明确的概念,系统全面的掌握各项数仓项目技术,轻松应对各种数仓难。四、课程亮点本课程结合国内多家企业实际项目经验,特别加入了项目架构模块,从集群规模的确定到框架版本选型以及服务器选型,手把手教你从零开始搭建大数据集群。并且总结大量项目实战中会遇到的问,针对各个技术框架,均有调优实战经验,具体包括:常用Linux运维命令、Hadoop集群调优、Flume组件选型及性能优化、Kafka集群规模确认及关键参数调优。通过这部分学习,助学生迅速成长,获取前沿技术经验,从容解决实战问

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值