企业shell面试题及解答
1、面试题:使用for循环在/tmp目录下批量创建10个html文件,其中每个文件需要包含10个随机小写字母加固定字符串template,示例如下
aaesdffbnv_template.html
方法1:
cd /tmp
for ((i=;i<;i++));do touch `echo $RANDOM | md5sum | sed 's/[^a-z]//g' | cut -c -`_template.html;done
方法2:
cd /tmp for i in `seq `;do touch `openssl rand -base64 | sed 's/[^a-z]//g' | cut -c -`_template.html;done
2、面试题:批量改名 将以上所得的文件名中的template全部改成leon,并且将html改成大写
方法1:
rename template.html leon.HTML *.html
方法2:
ls *.html | awk -F '_' '{print "mv "$0" "$1"_leon.HTML"}' | bash
3、面试题:批量10个系统账号template01到template10并设置密码(密码为随机数)
方法1:
for i in `seq -w 01 10`;do useradd -M template$i;echo $RANDOM |md5sum | cut -c 1-10 | tee -a passwd.log | template$i;done
方法2:
echo template{..} | tr " " "\n" | sed -r 's#(.*)#useradd \1;pass=`echo $RANDOM | md5sum | cut -c 1-10`;echo "$pass"|passwd --stdin \1;echo -e "\1\t`echo "$pass"`" >> /tmp/passwd.log#g' | bash
方法3:
echo template{..} | xargs -n1 useradd;echo template{..}:`cat /dev/urandom|tr -dc -|fold -w8|head -1` | xargs -n1|tee -a pass.txt|chpasswd
4、面试题:写一个脚本,判断192.168.8.0/24网路里,当前在线的IP有哪些
方法1:
#!/bin/bash G
for i in `seq `
do
{
ping -c -W 192.168..$i &>/dev/null
if [ $? -eq ];then
echo "192.168.8.$i is alive" ?
fi ?
}& #shell的并发检测功能,批量ping,快速返回结果
done
方法2:使用namp(需要安装namp)
nmap -sP 192.168.8.0/ | awk '/Nmap scan report for/{print $NF}' #1到2秒返回结果
5、面试题:写一个shell脚本以解决DDOS攻击生产的问题
请根据Web日志或网络连接数,监控当某个IP并发连接数或短时间内PV达到100时,即调用防火墙命令封掉该对应的IP:防火墙的命令为:
iptables -I INPUT -s IP -j DROP
参考此脚本:
#!/bin/bash
#Author Template
#Time -- :
file=$
log_file=/tmp/tmp.log JudgeExt(){
if expr "$1" : ".*\.log" &> /dev/null;then
:
else
echo "Usage: $0 xxx.log"
exit
fi
} IpCount(){ grep "ESTABLISHED" $ | gawk -F "[ :]+" '{++S[$(NF-3)]} END {for (key in S) print S[key],key}' | sort -rn -k1 | head - > $log_file } ipt(){
local ip=$
if [ `iptabls -L -n | grep "$ip" | wc -l` -lt ];then
iptabls -I INPUT -s $ip -j DROP
echo "$line is dorpped" >> /tmp/drop_list_$(date +%F).log
fi } main(){ JudgeExt $file
while true
do
IpCount $file
while read line
do
ip=`echo $line | gawk '{print $2}'`
count=`echo $line | gawk '{print $1}'`
if [ $count -gt ];then
ipt $ip
fi
done < $log_file
sleep done
}
main
6、面试题:请用脚本实现Mysql数据库分库备份
#!/bin/bash
echo -e [`date +"%Y-%m-%d %H:%M:%S"`] start
#system time
time=`date +"%y-%m-%d"`
#host IP
host="127.0.0.1"
#database backup user
user="root"
#database password
passwd="yourpasswd"
#Create a backup directory
mkdir -p /backup/db/"$time"
#list database name
all_database=`/usr/bin/mysql -u$user -p$passwd -Bse 'show databases'`
#in the table from the database backup
for i in $all_database
do
/usr/bin/mysqldump -u$user -p$passwd $i > /backup/db/"$time"/"$i"_"$time".sql
done
echo -e [`date +"%Y-%m-%d %H:%M:%S"`] end
exit
7、面试题:请用脚本实现Mysql数据库分库分表备份
#!/bin/bash
PATH="/application/mysql/bin:$PATH"
DBPATH=/server/backup
MYUSER=root
MYPASS=
SOCKET=/data//mysql.sock
MYCMD="mysql -u$MYUSER -p$MYPASS -S $SOCKET"
MYDUMP="mysqldump -u$MYUSER -p$MYPASS -S $SOCKET"
[ ! -d "$DBPATH" ] && mkdir $DBPATH for dbname in `$MYCMD -e "show database;" | sed '1,2d' | egrep -v "mysql|schema"`
do
mkdir $DBPATH/${dbname}_$(date +%F) -p
for table in `$MYCMD -e "show tables from $dbname;"| sed '1d'`
do
$MYDUMP $dbname $table | gzip > $DBPATH/${dbname}_$(date +%F)/${dbname}_${table}.sql.gz
done
done
8、面试题:请开发一个shell脚本,比较两个整数的大小,通过传参的方式
#!/bin/bash a=$
b=$ Usage(){ echo "Usage:$0 NUM1 NUM2"
exit
} [ $# -ne ] && { ##判断传参个数
Usage
} expr $a + &> /dev/null #使用expr只能计算两个整数的原理,判断传入的参数是否为整数
RETVAL_A=$?
expr $b + &> /dev/null
RETVAL_B=$? [ $RETVAL_A -ne -o $RETVAL_B -ne ] && { echo "you must input integer "
exit
} if [ "$a" -lt "$b" ];then
echo "$a < $b"
elif [ "$a" -gt "$b" ];then
echo "$a > $b"
else
echo "$a = $b"
fi
exit
9、面试题:打印选择菜单,按照选择一键安装不同的web服务
#!/bin/bash
PS3="Enter option: " #设置提示符
stty erase ^h #设置退格删除键为backspace
trap "echo Goodbye..." EXIT #检测到exit信号,输出Goodbye
select option in "install LNMP" "install LANP" "Exit"
do
case $option in
"install LNMP")
sh install_lnmp.sh
;;
"install LANP")
sh install_lamp.sh
;;
"Exit")
exit
;;
*)
echo ""
;;
esac
done
10、Web及Mysql服务异常监测
网站监测:
#!/bin/bash
#Author Template
#Time -- :
url_list=(
http://www.cnblogs.com/Template/
http://www.baidu.com
http://127.0.0.1
) . /etc/init.d/functions
function wait(){ echo -n "3 秒后执行检查."
for ((i=;i<;i++))
do
echo -n "." ;sleep
done
echo
} function check_url(){
wait
for ((i=;i<`echo ${#url_list[*]}`;i++))
do
wget -o /dev/null -T --tries= --spider ${url_list[$i]} &> /dev/null
if [ $? -eq ];then
action "${url_list[$i]}" /bin/true
else
action "${url_list[$i]}" /bin/false fi
((check_count++))
done
} main(){
while true
do
check_url
echo "------------check count:${check_count}------------------"
sleep
done }
main
Mysql监测:
方法1:
#!/bin/bash
if [ "`netstat -tlunp | grep 3306 | awk -F "[ :]+" '{print $4}'`" = "" ];then
echo "Mysql is Running"
else
echo "Mysql is Stopped"
/etc/init.d/mysqld start
fi
方法2:
#!/bin/bash
if [ `netstat -tlunp | grep "" | wc -l` -gt ];then
echo "Mysql is Running"
else
echo "Mysql is Stopped"
/etc/init.d/mysqld start
fi
方法3:
#!/bin/bash
if [ `lsof -i tcp: | wc -l` -gt ];then
echo "Mysql is Running"
else
echo "Mysql is Stopped"
/etc/init.d/mysqld start
fi
11、面试题:写出网络服务独立进程模式下Rsync的系统启动脚本,例如:/etc/init.d/rsyncd {start|stop|restart}
#!/bin/bash
# chkconfig:
#description Rsyncd start stop script . /etc/init.d/functions function Usage(){
echo "Usage:$0 {start | stop | restart}"
exit
} function start (){
rsync --daemon
sleep if [ `netstat -tlunp | grep rsync | wc -l` -ge ];then
action "rsyncd started" /bin/true
else
action "rsyncd started" /bin/false
exit
fi
} function stop(){
killall rsync &> /dev/null
sleep
if [ `netstat -tlunp | grep rsync|wc -l` -eq ];then
action "rsyncd stopped" /bin/true
else
action "rsyncd stopped" /bin/false
exit
fi
} function restart(){
stop && start
} case "$1" in
"start")
start
;;
"stop")
stop
;;
"restart")
restart
;;
*)
Usage
esac
12、面试题:请写出mysql多实例启动脚本
#!/bin/bash
port=
mysql_user="root"
mysql_pwd=""
CmdPath="/application/mysql/bin"
mysql_sock="/data/${port}/mysql.sock"
. /etc/init.d/functions start(){
if [ ! -e "$mysql_sock" ];then
printf "Starting MySQL...\n"
/bin/sh ${CmdPath}/mysqld_safe --defaults-file=/data/${port}/my.cnf >& > /dev/null &
[ $? -eq ] && action "Mysql start" /bin/true || action "Mysql start" /bin/false
else
printf "MySQL is running...\n"
exit
fi
} stop(){
if [ ! -e "$mysql_sock" ];then
printf "MySQL is stopped...\n"
exit
else
printf "Stoping MySQL...\n"
${CmdPath}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S /data/${port}/mysql.sock shutdown
[ $? -eq ] && action "Stop mysql" /bin/true || action "Stop mysql" /bin/false
fi
} restart(){
printf "Restarting MySQL...\n"
stop
sleep
start
} Usage(){
echo "Usage: /data/${port}/mysql (start|stop|restart)"
exit
} case "$1" in start)
start
;;
stop)
stop
;;
restart)
restart
;;
*)
Usage
;;
esac
企业shell面试题及解答的更多相关文章
- 企业Shell面试题及企业运维实战案例(三)
1.企业Shell面试题1:批量生成随机字符文件名案例 使用for循环在/oldboy目录下批量创建10个html文件,其中每个文件需要包含10个随机小写字母加固定字符串oldboy,名称示例如下: ...
- 企业Shell面试题5:解决DOS攻击生产案例
企业Shell面试题5:解决DOS攻击生产案例 写一个Shell脚本解决DOS攻击生产案例. 请根据web日志或者或者网络连接数,监控当某个IP并发连接数或者短时内PV达到100(读者根据实际情况设定 ...
- 兄弟连 企业shell笔试题 1-15
这些题目收集自网络,对比原来的答案,又根据实际情况重新编写了自己的答案 企业实践题1: (生产实战案例):监控MySQL主从同步是否异常,如果异常,则发送短信或者邮件给管理员.提示:如果没主从同步环境 ...
- 兄弟连 企业shell笔试题 16-31
企业实践题16:企业案例:写网络服务独立进程模式下rsync的系统启动脚本 例如:/etc/init.d/rsyncd{start|stop|restart} .要求:1.要使用系统函数库技巧.2.要 ...
- 企业shell面试题:获取51CTO博客列表倒序排序考试题
#!/bin/sh PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin HTMLFILE=/home/oldboy/ht ...
- Shell面试题8:筛选符合长度的单词案例
企业Shell面试题8:筛选符合长度的单词案例 利用bash for循环打印下面这句话中字母数不大于6的单词(某企业面试真题). I am oldboy teacher welcome to oldb ...
- Shell面试题4:扫描网络内存活主机案例
19.1.4企业Shell面试题4:扫描网络内存活主机案例 写一个Shell脚本,判断10.0.0.0/24网络里,当前在线的IP有哪些? [root@st153 tools]# cat check_ ...
- 大数据技术之_09_Flume学习_Flume概述+Flume快速入门+Flume企业开发案例+Flume监控之Ganglia+Flume高级之自定义MySQLSource+Flume企业真实面试题(重点)
第1章 Flume概述1.1 Flume定义1.2 Flume组成架构1.2.1 Agent1.2.2 Source1.2.3 Channel1.2.4 Sink1.2.5 Event1.3 Flum ...
- 【转载】JAVA常见面试题及解答(精华)
JAVA常见面试题及解答(精华) 1)transient和volatile是java关键字吗?(瞬联) 如果用transient声明一个实例变量,当对象存储时,它的值不需要维持.例如: ...
随机推荐
- python_魔法方法(一):构造和析构
魔法方法总是被双下划线包围,例如:__init__() 魔法方法是面向对象的python的一切,它的魔力体现在总能在合适的时候调用. 先来介绍析构和构造的三个魔法方法: __init__():构造方法 ...
- 16-----client、offset、scroll 系列
1.client 代码如下: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...
- git——解决“fatal: Authentication failed for 'https://github.com/balabala”
平复一下心情,到底如何在github上将队友和owner的仓库连接?如何push代码到远程仓库???找了巨多教程,终于解决了~ 刚到公司不久,开始学着用git,在提交代码的时候怎么都提不上去! 解决办 ...
- C数据结构与算法-算法复杂度
算法复杂度分为时间复杂度T(n)和空间复杂度F(n) 时间复杂度:也就是执行算法程序所需的时间,与硬件的速度.编程语言的级别.编译器的优化.数据的规模.执行的频度有关,前三个有很大的不确定性,所以衡量 ...
- 使用gulp构建工具
之前一个demo中用的是grunt,照着grunt用到的插件找了下gulp的,总体使用还算顺畅,说实话并不觉得学习成本有降低什么的,差不多.不过也遇到一些问题: 1.gulp.dest()输出目录需要 ...
- UVALive 7511 L - Multiplication Table 数学模拟题,暴力
给定一副表,问其是否合法. 思路:当全部是?的时候,是合法的. 如果不是,那么,就找到一个数字,把它拆成若干个a*b的形式,去判断其它点是否合法即可. 拆分数字的时候,只需要枚举到sqrt(n),因为 ...
- IDEA/Eclipse安装 Alibaba Java Coding Guidelines 插件
为了让开发者更加方便.并且达到快速规范代码格式的目的并实行起来,阿里巴巴基于<阿里巴巴Java开发规约>手册内容,研发了一套自动化的IDE检测插件(IDEA.Eclipse).它就是Ali ...
- 《C#高效编程》读书笔记12-使用推荐成员初始化器而不是赋值语句
通常来说类都有不止一个构造函数.随着时间推移,成员变量的增加,构造函数的个数也会不断的增加.预防这种情况的最好方法是,在声明变量的时候就进行初始化,而不是在每个构造函数中进行. //初始化变量时声明 ...
- Soft skill
不要害怕让别人看到自己的无知 作为高级程序员的一个好处是,当别人问一些我不懂的问题时,我可以很淡然地告诉他们: 这个东西我也不懂,因为以前没有遇到过,不过我可以看一下,然后再告诉你. 当我还是一个初级 ...
- 安装flask-mysqldb的时候,提示 mysql_config not found 的解决方法
解决办法: sudo apt-get install libmysqlclient-dev sudo updatedb locate mysql_config 然后进入mysql_config的路径( ...