Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >运维面试题整理

运维面试题整理

作者头像
全栈程序员站长
发布于 2022-06-30 12:47:23
发布于 2022-06-30 12:47:23
1.4K00
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

文章目录

原题

前言

1. Nginx反向代理配置,此类url www.abc.com/refuse,禁止访问,返回403

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
location /www.abc.com/refuse { 
    

    return 403;
}

2. 如何使用iptables将本地80端口的请求转发到8080端口,当前主机IP为192.168.16.1,其中本地网卡eth0:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
iptables -t nat -A PREROUTING -p tcp -i eth0 --dport 8080 -j DNAT --to 192.168.16.1:80

3. 如何查看Linux系统当前的状态,cpu内存的使用情况及负载

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
系统 
# uname -a # 查看内核/操作系统/CPU信息 
# head -n 1 /etc/issue # 查看操作系统版本 
# cat /proc/cpuinfo # 查看CPU信息 
# hostname # 查看计算机名 
# lspci -tv # 列出所有PCI设备 
# lsusb -tv # 列出所有USB设备 
# lsmod # 列出加载的内核模块 
# env # 查看环境变量 
资源 
# free -m # 查看内存使用量和交换区使用量 
# df -h # 查看各分区使用情况 
# du -sh # 查看指定目录的大小 
# grep MemTotal /proc/meminfo # 查看内存总量 
# grep MemFree /proc/meminfo # 查看空闲内存量 
# uptime # 查看系统运行时间、用户数、负载 
# cat /proc/loadavg # 查看系统负载 

4. nginx如何重定义或者添加发往后端服务器的请求头

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
headers-more-nginx-module 模块用于添加,修改,或者清除 请求/响应头
  more_set_headers 用于添加、修改、清除响应头
    more_clear_headers 用于清除响应头
    more_set_input_headers 用于添加、修改、清除请求头
    more_clear_input_headers 用于清除请求头

5. 编写shell脚本,将当前目录下大于10K的文件转移到/tmp目录下

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#!/bin/bash
for Filename in $(ls -l |awk '$5 > 10240 {print $9}')
do
mv $Filename /tmp
done

6. 写出你所了解的门户网站的服务架构,可用什么方式实现的高可用、负载均衡?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
软负载: nginx+keepalived
lvs+keepalived 
应负载: F5

补充:

代理服务器一般使用nginx 作为反向代理
web服务器: 一般使用nginx
缓存服务器一般使用redis或者memcached
数据库服务器:一般使用mysql

常见的web集群:
apache+tomcat;nginx+tomcat;lvs+nginx+tomcat(lvs负责集群调度,nginx负责静态文件处理,tomcat负责动态文件)

LVS+keepalive 高可用。

7. nginx 日志过滤10点到12点之间访问IP排名和统计

nginx的日志格式如下图:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[root@zmedu-17 logs]# pwd
/usr/local/nginx/logs
[root@zmedu-17 logs]# ls
access.log  error.log  nginx.pid

[root@zmedu-17 logs]# cat access.log | grep "16/Jun/2020" | sed -n '/07:39:54/,/08:00:01/p' | awk '{print $1}' | sort | uniq -c | sort -t " " -k2 -n -r
      8 192.168.1.4

8. 在11月份内,每天的早上6点到12点,每隔2小时执行一次usr/bin/httpd.sh怎么实现

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
0 6-12/2 * 11 * /usr/bin/httpd.sh

9. 分布式文件存储是否有过了解和使用,了解过的有什么特性

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
FastDFS
 解决了大数据量的存储和负载均衡问题,特别适合中小文件为载体的在线服务,比如在线相册,视频网站等等。 网盘社区,广告和应用下载的存储。

补充:
单机时代:  在静态目录中存放文件资源。
优点:便利,项目直接引用目录,不需要复杂的技术
缺点: 如果作为前端网站使用,代码和文件耦合在一起,文件越多存放越混乱。如果流量大,静态文件访问会占用一定 的资源,影响业务的正常运行

独立文件服务器时代:
缺点:点击存在性能瓶颈,容灾,垂直扩展能力较差。
比如独立的图片服务器,项目上次文件的时候,通过ssh或者ftp上传到图片服务器的某个目录下,在通过nginx来访问此目录,返回一个独立域名的url地址。

分布式文件系统:
优点: 定时备份,如果一台down掉,迅速切换到另一台。扩展能力强,能够保证文件系统的可用性,也能够保证数据的完整性和唯一性

缺点: 系统复杂程度较高,需要更多服务器

常见的分布式文件系统还有: GlusterFS, GoogleFS, TFS, OSS

10. 使用netstat和awk命令统计下网络连接数:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[root@zmedu-17 ~]# netstat -n | awk '/^tcp/ {++state[$NF]} END {for(key in state) print key,"\t",state[key]}'
ESTABLISHED      3

补充:
CLOSED:无连接是活动的或正在进行
LISTEN:服务器在等待进入呼叫
SYN_RECV:一个连接请求已经到达,等待确认
SYN_SENT:应用已经开始,打开一个连接
ESTABLISHED:正常数据传输状态
FIN_WAIT1:应用说它已经完成
FIN_WAIT2:另一边已同意释放
ITMED_WAIT:等待所有分组死掉
CLOSING:两边同时尝试关闭
TIME_WAIT:另一边已初始化一个释放
LAST_ACK:等待所有分组死掉

11. 在linux下,假设nginx日志的路径为opt/logs/access.logs,日志不能自动分割,请写出一个简单的脚本,让日志每天能够定时自动分割

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#! /bin/bash
base_path='/usr/local/nginx/logs'
log_path=$(date -d yesterday +"%Y%m")
minute=$(date -d "1 minute ago" +"%Y%m%d-%H:%M")
 
mkdir -p $base_path/$log_path
echo $base_path/access.log
mv $base_path/access.log $base_path/$log_path/access_$minute.log
echo $base_path/$log_path/access_$minite.log
kill -USR1 `cat /usr/local/nginx/logs/nginx.pid`

#crontab -l
* * 1 * * eck_nginx_log.sh

12. 写出raid的几种模式,以及他们的特点

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
raid  名称 特点

raid0 提高读写性能,最少两块容量为N的硬盘,容量为2N

raid1 提高数据安全性,提高读取性能,不能提高写入性能,2003自带raid1功能,最少两块容量为N的硬盘,容量为N

raid10 先提高安全性,再提高性能,最少4块容量为N的硬盘,容量为2N,RAID10RAID01在安全性方面要强(体现在容错率上)

raid01 先提高性能,再提高安全性,最少4块容量为N的硬盘,容量为2N

raid5 提升安全性,安全性低于raid10(三块盘的情况下),大文件读写没有优势,小文件读写能力低于raid10,最低三块盘,容量为2快盘

13. 写一个脚本,查找15天前以png结尾的文件并删除

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#!/bin/bash
find /picture/*.png* -type f  -mtime +15 -exec rm  { 
   } \;

14. 对于服务器的监控使用过哪类工具及其特点

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
zabbix, prometheus, cacti ,nagios

15. 作为运维工程师,你对该职位的认识和理解有哪些,日常工作中应该怎么做

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
做运维岗位带给你的改变: 
16.  可以认识更多的人,同时也能被更多的人认识, 对于一个喜欢沟通和交流的我来说,更能够在这个岗位上干的长久。
17.  运维人员临场应变能力和处理突发事件的能力会随着工作经验的增长而增强。更容易养成未雨绸缪,思维上得到锻炼,考虑问题更全面,细致,透彻,且内心承受能来强大
18. 运维能力不是高学历可以搞定的,需要的是勤奋努力,善于总结 

其次: 运维不是单纯的运维维护,而是运维规范和规则的制定者以及安全运维规范的忠实维护者和践行者。

在工作中应该做什么?
1. 监控,报警,线上部署
2. 脚本自动化,工具自动化
3. 故障处理

要弄懂底层原理,比如监控: 任何的监控都是: 收集数据,存储数据,数据分析,数据指标展示,告警五个部分。理解了这个,对于任何监控你可以去分析,哪个模块是在分析数据,哪个模块是在收集数据,能不能用其他的代替。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/131919.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
高薪offer,只因做对了这套笔试题
FastDFS 解决了大数据量的存储和负载均衡问题,特别适合中小文件为载体的在线服务,比如在线相册,视频网站等等。网盘社区,广告和应用下载的存储。 补充: 单机时代:在静态目录中存放文件资源。 优点:便利,项目直接引用目录,不需要复杂的技术 缺点:如果作为前端网站使用,代码和文件耦合在一起,文件越多存放越混乱。如果流量大,静态文件访问会占用一定 的资源,影响业务的正常运行 独立文件服务器时代: 缺点:点击存在性能瓶颈,容灾,垂直扩展能力较差。 比如独立的图片服务器,项目上次文件的时候,通过ssh或者ftp上传到图片服务器的某个目录下,在通过nginx来访问此目录,返回一个独立域名的url地址。 分布式文件系统: 优点:定时备份,如果一台down掉,迅速切换到另一台。扩展能力强,能够保证文件系统的可用性,也能够保证数据的完整性和唯一性 缺点:系统复杂程度较高,需要更多服务器 常见的分布式文件系统还有:GlusterFS, GoogleFS, TFS, OSS
互联网老辛
2020/06/23
4410
Linux运维跳槽必备的40道面试精华题
过一次年,结婚、存款、父母养老,一系列向钱看的事都在碾压我们本来还挺简单的神经,但难过没有出路,唯有找到好的方法和事业方向,才能实现一步一个脚印的逆袭。
小小科
2018/09/28
3.1K0
Tomcat面试题+http面试题+Nginx面试题+常见面试题
1、Tomcat的缺省端口是多少?怎么修改? 答:缺省端口是8080,若要修改,可以进入Tomcat的安装目录下找到conf目录下的server.xml文件,找到该文件中的Connector字段中的port。 2、Tomcat有哪几种connector运行模式(服务的请求方式)? 答:三种。修改它的运行模式需要在主配置文件中找到connector字段中的protocol进行修改
全栈程序员站长
2022/09/02
1.3K0
Linux运维工程师面试题 -- 精校版
1)运维是指大型组织已经建立好的网络软硬件的维护,就是要保证业务的上线与运作的正常,在他运转的过程中,对他进行维护,他集合了网络、系统、数据库、开发、安全、监控于一身的技术运维又包括很多种,有DBA运维、网站运维、虚拟化运维、监控运维、游戏运维等等。
浩Coding
2021/08/06
3.6K0
linux运维面试题总结「建议收藏」
4、一个ext3的文件分区,当使用touch test.file命令创建一个新文件时报错,报错的信息是显示磁盘已满,但是采用df -h命令查看磁盘大小时,只使用了60%的磁盘空间,为什么会出现这个情况,说说你的理由
全栈程序员站长
2022/08/22
2.1K0
linux运维面试题总结「建议收藏」
03 . Nginx日志配置及日志切割
access_log /usr/local/nginx/logs/b_test/access.log;
iginkgo18
2020/09/27
2.5K0
系统运维面试题
大家好,又见面了,我是你们的朋友全栈君。 目录 1.什么是运维?什么是游戏运维? 2.在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的? 3.请描述下linux 系统的开机启动过
全栈程序员站长
2022/09/05
3K0
Nginx服务器的日志管理及配置
这说明 该server, 它的访问日志的文件是 logs/host.access.log ,
架构师精进
2020/03/19
1.6K0
Nginx服务器的日志管理及配置
Nginx的日志管理和用定时任务完成日志切割
#log_format main '$remote_addr(远程IP) - $remote_user(远程用户) [$time_local](访问时间) "$request"(请求方式) '
星哥玩云
2022/07/04
6770
Nginx的日志管理和用定时任务完成日志切割
oracle运维面试试题,运维面试题「建议收藏」
linux系统启动过程详解:http://www.linuxeye.com/Linux/340.html
全栈程序员站长
2022/07/01
7840
运维面试题(每日一题)
默认生产环境中,三台服务器均可满足访问外网需求;但最终目标是完成服务器01与服务器03之间的不同网段间通讯,即服务器01的10.0.0.10主机IP地址可以正常访问服务器03的10.0.1.10主机IP地址
全栈程序员站长
2022/08/10
5.2K0
运维面试题(每日一题)
elk面试题_百家公司运维面试题汇总
备注: 这一我在去年国庆节期间,整理的整个19年,学员的面试遇到的问题,整理出来之后发给后期的学员,让他们做参考和学习,看看公司会面试哪些问题。
全栈程序员站长
2022/09/06
1.6K0
运维面试题(1024水篇)
NETWORK 1 请描述TCP/IP协议中主机与主机之间通信的三要素 参考答案 IP地址(IP address) 子网掩码(subnet mask) IP路由(IP router)
全栈程序员站长
2022/09/13
2.5K0
运维猫-面试题总结-55道
ps -A -o stat,ppid,pid,cmd | grep -e '^[Zz]' | awk '{print $2}' | xargs kill -9
胡齐
2019/11/18
1.1K0
给小白的Nginx入门指南-30分钟从小白到专家
h以前写过一些Nginx的文章,但都是用到什么说什么,没有一个完整系统的总结。趁最近有时间,打算将Nginx相关的内容重新整理一下。
架构师精进
2021/07/01
7.2K0
【Linux运维面试题】三剑客笔试题集合
1.在给定文件中查找与条件相符字符串的命令及查找某个目录下相应文件的命令为:(多选)(AC)
kubernetes中文社区
2020/06/03
2.9K0
Nginx日志配置
众所周知,线上如果出现事故我们通常都是查看日志去进行问题定位并且进行修复。使用好Nginx日志有利于我们线上进行修复异常问题。在Nginx中日志主要分为两种:access_log(访问日志)和error_log(错误日志)。通过查看access_log我们可以查看用户ip,浏览器信息及请求时间等信息,通过查看error_log我们可以查看线上出错的具体信息,可以帮助我们定位异常的原因。本篇文章主要带领大家详细了解Nginx如何配置日志。本文将会涉及到的日志配置指令:
创译科技
2019/09/06
1.4K0
Nginx日志配置
运维必须掌握的27道Linux面试题
GPL:(通用公共许可证):一种授权,任何人有权取得、修改、重新发布自由软件的权力。
全栈程序员站长
2022/08/27
8680
Nginx教程_nginx docker
mv $base_path/access.log $base_path/$log_path/access_$day.log
全栈程序员站长
2022/11/19
8370
Nginx 日志切割:按日期管理日志文件,提升运维效率
在日常运维中,Nginx 的访问日志和错误日志会随着时间的推移不断增长,最终可能导致日志文件过大,影响管理和分析的效率。为了解决这个问题,我们可以将日志按日期切割,生成每日的独立日志文件。这不仅方便日志的管理,还能更高效地进行问题排查和数据分析。以下是具体的操作步骤,希望能帮助到你。
神秘泣男子
2024/12/24
3570
Nginx 日志切割:按日期管理日志文件,提升运维效率
相关推荐
高薪offer,只因做对了这套笔试题
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验