京东运维开发已Offer 分享一下面经
昨天上午美团三面,今早京东发Offer了。在这里分享一下面经,可能不是很有普适性。
京东时间线:
3月27投递,3月28号测评,4月4号一面,4月11号上午二面,4月11号下午HR面,4月18号OC,4月20号Offer。
楼主的技术栈:Go,Linux,Docker,k8s,CNCF。
一面是两个面试官,一个面试官问开发,一个面试官问运维。
一面
开发部分
- 项目的背景
- 自我介绍
- 项目遇到的问题,怎么解决的
- golang怎么传参
- golang的切片
- golang的map
- golang传参map进去会改变函数外的map吗
- golang的channel原理
- golang的互斥锁和读写锁原理
- gin框架和grpc(简历里写了使用过gin和grpc)
- C#的事件(简历里写了了解C#)
- python的迭代器、装饰器、with,with怎么释放的资源(简历里写了了解python)
- 写题 旋转数组
运维部分
- 用过什么Linux
- 给了一个`ls`命令的截图问每一列什么意思 (所有者 所属组 其他人 权限)
- 软链接
- 进入一个目录需要什么权限
- 对一个文件增删改查 需要什么权限
- 找出文件夹及其子文件下的所有以 `.log` 结尾的文件中的所有error开头的错误行,查找用find
- xargs命令
- 看你命令中用了管道,说一下管道
- 知道管道传递文件描述符了吗,0 1 2都代表什么
- 知道init进程吗,说一说systemd,知道centos6怎么管理的吗(/etc/init.d)
- 怎么知道systemctl运行的是哪个程序 (/usr/lib/system/systemd/sshd.service)
- 查看cpu的命令(lscpu、top、htop)
- top命令中你关注的资源情况是什么(load average)
- load average中的三个数字代表什么,怎么得来的(1分钟、5分钟、15分钟)
- cpu的占用率是怎么计算的,占用率能超过100%吗
- 你觉得cpu占用率达到多少就不太好了
- 怎么查看内存?(free -m)
- 讲讲swap,内存占用率是怎么计算的
- free -m中你关心的字段有哪些 (free和used)
- buff/cache的比较
- 怎么设置ip地址 ifconfig和ip命令的区别,哪个好一点(net-tools包和iproute2包)
- 怎么查看监听在8080端口的是哪个进程(netstat -tnlp | grep 8080)
- 知道/proc吗,里边重要的字段是什么、知道/sys吗,里边有什么(这个当时没回答出来)
- 讲下inode
- 目录是怎么存储的 目录块中的结构是什么
- 手写Dockerfile 构建一个hello-world镜像 使用两层架构
- Docker CMD和ENTRYPOINT的区别
- Docker是怎么实现隔离和资源限制的
- Docker exec -it进入容器的原理是什么
- Docker容器间怎么通信 (说到了veth-pair,问我知道Tap吗,我说只知道TUN)
- 容器怎么和外网通信 (要有去有回 SNAT)
- 顺势问了 DNAT在哪里用到过,有什么场景(Kubernetes Service的iptables链)
- Kubernetes Pod跨主机怎么通信(阿里和京东都问了)
- 知道VTEP吗
- 进程和线程
- 线程轻量在什么地方
- 进程和线程的共享内存、栈、堆
- 进程和线程的之间什么资源是私有的、什么是共有的
- 用什么命令查看磁盘,磁盘的占用情况 (lsblk fdisk cfdisk df -h)
- 删掉一个大文件,文件已经不在了,但是空间仍然被占用,为什么(可能和inode有关)
- 反问
二面
二面面试官问了问项目,问了问日志怎么做,问了下Linux的启动流程,然后就闲聊了
#京东信息集散地#