沥泉科技 Golang 社招技术面

网安小厂,只有技术面HR面,岗位是Golang运开,特点是30-50%时间驻场,其他时间公司做开发。
都是些小厂经典问题,比较简单。HR特别在意到岗时间,电信这边离职流程才走完30%,个还得一个月才能到岗...

1.自我介绍
2.在职状态
3.goroutine和channel是什么,工作中怎么使用这两种东西协作的?
    答了基础概念、异步任务、阻塞、超时取消之类的东西
4.有缓冲的channel和无缓冲的channel区别是什么?
    答了阻塞、缓存两种作用以及讨论了在关闭时收发的情况
5.defer关键字的执行顺序?
    先进后出
6.自定义错误处理你自己设计过吗?
    我在自己的开源工具包里面封装过一个,用于处理不同业务类型的错误。首先是错误接口的结构体,包含code错误码、type错误类型、msg错误信息、err原始错误,然后是New()声明错误实例,Error()返回自定义错误,NewWithType()自定义错误类型,NewWithCode(),UnWarp()拿到原始错误,Is()判断两个错误是否一致
7.内存管理和垃圾回收机制
    答了三色标记法的原理和4个流程(初始标记、并发标记、重新标记和并行清理)以及那个流程会导致STW。答了debug.SetGCPercent设置GC频率,值越高GC频率越低,debug.SetMemoryLimit设置内存限制,用sync.pool可以复用来减少内存消耗
8.Go的Map并发安全吗?若不安全怎么实现一个并发安全的Map?
    不安全,Go自带sync.Map是轻量级的安全的map。如果要实现可以用atomic包的原子方法或者CAS自旋锁来实现,最简单的方式是用mutex和RWMutex来进行加锁
9.我看你的项目用了SOA架构,什么是SOA架构为什么这样设计?
10.看你用的最多的是Fiber框架,为什么选这个框架,和Gin框架有什么区别?
    Fiber在25年后端框架性能排名第28,,而Gin在230名左右。Fiber使用的是类似Express.js的异步模型所以性能高,但是有致命弱点是计算密集型任务下会导致整个进程阻塞,核心优化点是在加密之类的计算密集型任务时需要开协程执行避免阻塞,但是高并发需要控制并发量避免大量goroutine使资源耗尽
11.多线程任务、定时任务如何排查错误?
    还没上线的就打断点debug,压测工具看那一部分出问题了或者每一部分都写好单元测试保证代码质量。上线的就查时序指标图、数据库最近记录、日志,哪个定时任务的记录断了就说明问题出在这一块
12.pprof你用过吗?
    pprof是标准库,默认开的端口是6060,go tool pprof ...就可以进行分析,也可以导出本地数据,像是Gin、Fiber这样的框架都有官方认可的pprof中间件,直接使用即可。
13.自己部署过CI/CD这种流水线吗?
    没有,自己平时用Git,实习公司用的SVN,在实习公司也给非技术人员部署过Windows环境的SVN仓库。
14.以前参加过驻场开发是吧?
    在深圳、广州、佛山、厦门轮流驻场过,大概10月到年底验收结束
15.有了解过网安相关的开发吗?
     了解过一点,我平时WAF接触的多一点,封装过CorazaWAF来作为轻量***,玩过长亭雷池、1Panel、宝塔,以前会配nginx,现在能简单写一点openresty配置。用过UFW、iptables,***的原理懂一点,包括QUIC、openssl、零信任的概念
16.C++了解多少?多久能上手?会调试吗?
    平时只用来做题没学过开发相关内容,有基础,一个月左右,大学选修课学过linux环境GDB调试不过现在忘了
17.愿意走go+CPP或者go+Rust的双栈路线吗?
    愿意
18.Docker用的比较熟练是吧?什么程度?
    了解过K8S,平时基本都用Docker-Compose,很少直接使用Docker启动镜像。了解过怎么构建镜像
19.讲讲Docker-compose
    我最近做新项目有去docker-compose的仓库看过,目前最新版本v5.0.1,v3、v4版本被官方放入遗产仓库,追求稳定选择v2版本追求性能选择v5。docker-compose是一个轻量级的容器编排器,多用于单机部署,毫秒级启动,通过写好的docker-compose.yaml来定制化启动镜像,可以配置持久化目录、限制cpu和内存、健康检查等
20.Docker的网络模式有几种?
    bridge桥接,宿主机、容器、容器间通信,有独立ip;none无网络通信,适用于离线计算之类的容器;container,容器组里面的容器可以通信;overlay,跨主机的容器通信,多用于分布式;还有个忘了(应该是host,同桥接但是无独立ip,宿主机和容器共享,多用于高性能应用)
21.你做的这个开源工具包是干嘛的怎么设计的?
    这个开源工具包是做的SteamWebAPI的上层封装,帮助有此需求且使用Go的开发者快速接入。因为Steam官方的SDK仅提供C++版本,并且文档极其简略,根据25年一年的接入经验就做了这个。统一初始化入口,链式配置,用于初始化实例,第一层接口分为dev(接入api.steam...)、store(接入store.steam...)、crawler(爬虫)、A2S、util(相关开发工具)5个模块。每个模块都有自己的通用方法,可以请求到原始字节流,使用泛型将原始字节流转换为原始模型,原始模型到精简模型的转换,包括各种图片字段返回的后缀拼接官方目前使用的前缀的url预处理。爬虫模块二次封装gocolley,有自己独立的链式配置,默认开启自定义的退避规则、IP池轮转、User-Agent轮转、refer轮转等,提供通用爬取方法和保存本地文件的方法。A2S是封装了官方推荐的三方A2S库,该库遵循SteamA2S规则可以请求到游戏服务器的相关数据,可以用于开发查服器等工具。Util是封装了一些SteamAPI开发中大概率会用到的工具方法,包括BBCode、HTML、MD三者间的转换、令牌的获取等。此外还封装了专属的错误以及Zap日志。已实现的接口双语文档覆盖率100%
22.你写的这个压缩工具是干嘛的?怎么实现的?
    这是我在学习Cobra CLI框架的时候原创的一个实战练习的课件。这个小工具核心功能是压缩/解压缩/加密/解密,提供zip、7Z、tar.gz三种压缩,支持批量、分卷等操作,加密支持AES、DES,其中还用到了PBKDF2秘钥派生低等技术,后续根据这个项目我还封装了一个支持MD5、PBKDF2、Argon2、Scrypt、Bcrypt五种方式加密和验证的工具包并做了基准测试,在CSDN的文章可以看到源码
23.看你对redis、kafka、es都熟悉,简单讲讲es的工作原理
    ES对文本内容使用了分词的技术把每个词前缀提取出来通过倒排表建立倒排索引,这样可以根据搜索词快速找到对应的文章,不过我做过的项目都比较小用不到ES,我平时都使用PGSQL的向量来建立Gin倒排索引来进行查询的。
24.Redis平时怎么用的?
    Redis有很多数据类型,Zset可以用来做排行榜,bitmap可以用来记录极大数据量的用户签到,Geo可以存储地理位置,Stream可以传输流式数据作为生产者和消费者,redis的原子性操作还可以用来做自增。但redis用的最多的还是用于缓存键值,避免流量直接打到数据库上,我用的最多的适用于存储JWT和存储网站每个模块主页面上永不过期的热点数据。
25.什么时候会用到kafka?
    我在监控项目中使用kafka比较多,kafka主要用作于流式数据的传输和消息队列,比如采集/停止指令的下发,告警状态的推送,此外kafka最大的优势是削峰填谷,在业务高峰期存储处理不过来的请求,在业务低峰期逐步消费
26.哪些GPT用的多?都怎么用的?
    国产豆包国外GPT,专门写代码的暂时没用过。最开始会让AI提供一些技术方案,审核后选出一套适合当前场景的,让AI搭建原始架构,我在每一个部分进行定制化修改,然后让AI再次评估漏洞我再次审核和修改,重复这个流程,经过几次迭代整个架构就基本成型了。
27.看你现在是网络工程师维护做得多,平时有做开发吗?
    下班之后至少一半时间是在做开发,有一份开发的兼职工作。
28.反问(公司业务、项目组近况)
    网安公司、驻场二开+运开,基本都在成都本地驻场,军工项目会封闭式开发,单次最多驻场1个月。部门刚成立,就面试官一个人,忙不过来了
29.到岗时间?之前薪水?公积金比例?
    上周已提离职,最快2月初(可恶的电信,下辈子再去电信基层直接跳了),税后6000包吃住最高档6险2金。

HR问了我几次有没有可能提前回成都,大致是过了,但是确实国企离职效率极其低下,不可抗力,暂时没有下文。
全部评论
楼主最后去了吗,待遇怎么样
点赞 回复 分享
发布于 03-02 15:29 福建
开了11k,至少不是很丢人
点赞 回复 分享
发布于 01-12 15:46 新疆
这家公司招人很着急嘛
点赞 回复 分享
发布于 01-04 18:39 浙江

相关推荐

头像
03-17 10:17
已编辑
绥化学院 Java
现在入门AI应该走哪些方...
点赞 评论 收藏
分享
02-28 19:07
已编辑
成都理工大学 Java
一面2.12一面是产品leader面的,整体来说偏业务面试官叫我共享屏幕演示Agent平台1 你的这个Agent平台做了什么?2 Agent平台的盈利模式是什么?3 平台的用户画像?4 做这个项目的核心目标是什么?5 实习中的规则引擎解决了什么问题?6 场景题:给出一个关于广告创意平台的场景,如何设计Agent赋能7 了解过哪些Agent框架主要是说了python的一些框架8 整体职业规划二面(技术面)2.271 个人信息:- 请做一个自我介绍。- 在你的项目里,挑一个技术难度大或有成就感的点介绍一下。- 你的技术栈主要是Java,对其他语言有接触吗?- 你平时工作中用过哪些AI编程工具?- 对Python掌握如何?相比Java有什么优势或劣势?- 如果要做Go开发,你介意转语言吗?- 对Go有哪些了解?说了一下协程和虚拟线程,提了一下Go用于云原生比较多2 实习:- 多版本快照模型和乐观锁解决并发更新问题,你们是怎么处理的?- 回滚时如何保证线上实例不受影响?- RTE从150ms降到25ms,你们如何定义和拆分核心链路和非核心链路?- 非核心链路执行失败,如何保证核心链路的数据一致性?- 应用程序关闭优化,进程关闭耗时325秒,你们是如何监控的?- 业务池未响应,具体原因是什么?- 关闭长任务时的数据一致性如何保证?- 使用本地消息表如何在重启后恢复数据?3 Agent项目- MCP网关实现协议转换,你们的MCP协议解决了什么问题?- 大模型(LLM)的熔断和降级是如何处理的?- 多跳检索是怎么实现的?循环检索策略是什么?4 MySQL和Redis- MySQL、Redis使用频率及场景是什么?- MySQL的InnoDB为什么用B+树做索引?- 联合查询索引怎么建?- 如果只用联合索引的非最左字段查询,会失效吗?总结归纳了MySQL索引失效了根本原因是破坏了索引的有序性- MySQL事务一致性是如何保障的?这里延申比较多,从ACID开始答,提到了SQL语句执行顺序和WAL,最后说了一下怎么选择事务隔离级别- Redis常见的数据结构有哪些?- 排行榜类型的数据结构应该用哪种?为什么?- MySQL和Redis之间如何保证数据一致性?没有说太多具体方案,主要是提了一下自己的理解5 平时怎么使用AI工具?
点赞 评论 收藏
分享
评论
9
18
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务