【Go面试】工作经验篇 (持续整合)

这里写目录标题

    • 什么是逃逸分析
    • 服务端怎么接受客户端上传的文件
    • 说一下对gin框架的理解
    • gin有哪些常用中间件
    • gin怎么用swagger写接口文档
    • nginx一般是用来做什么
    • 如果调用方法经常超时怎么办
    • gin中怎么和mysql通信
    • 从mysql调数据到redis,如何同步
    • 延时双删
    • redis ,mysql都不存在用户请求的数据怎么办(缓存穿透)
    • redis大Key问题
    • 你们小组有哪些人,都是怎么工作的
    • 最有成就感的事
    • 发展方向
    • 看重公司哪一点
    • 业务和技术哪个重要
    • 遇到过什么困难,怎么解决
    • 反问内容
    • prompt书写有什么技巧
    • 你认为为什么prompt会有很多不同的模板,不同业务场景适合用不同的与大模型交互的方式吗
    • 对大模型的认识以及自己的运用或者工作时的运用
    • 使用大模型的时候大交互拆成小交互会对token优化多少
    • 怎么样排查慢查询
    • k8s了解嘛?
    • 一个地方Post请求过多怎么处理(或者消息过多)

什么是逃逸分析

其核心目的是确定在程序执行过程中,对象的引用是否“逃逸”出了其创建的作用域

1.减少逃逸就可以把对象分配到栈上,减少垃圾回收的压力

2.没逃逸出线程就不用对这个对象做支持多线程的处理

3.如果创建后没有外部引用就会被视为死代码消除

逃逸的情况:

全局变量,传参,返回值,多线程,外部数据结构(全局数据结构或指针)

服务端怎么接受客户端上传的文件

package mainimport ("github.com/gin-gonic/gin""net/http"
)func main() {//创建gin框架的路由引擎r := gin.Default()//定义一个处理post请求的路由,并尝试获取名为file的文件,如果出现错误就返回对应错误信息r.POST("/upload", func(c *gin.Context) {// 声明接收文件的变量file, err := c.FormFile("file")if err!= nil {c.String(http.StatusBadRequest, "接收文件出错: %v", err)return}// 保存文件err = c.SaveUploadedFile(file, "./"+file.Filename)if err!= nil {c.String(http.StatusInternalServerError, "保存文件出错: %v", err)return}c.String(http.StatusOK, "文件上传成功: %s", file.Filename)})// 启动服务r.Run(":8080")
}

说一下对gin框架的理解

gin是一个厉害的Go语言web框架

从路由上说利用Trie树算法快速匹配路由,

中间件上可以像链条穿起来,和工作流一样,内置Logger等中间件,

社区活跃,提供丰富解决思路和插件

基于httprouter构建,底层实现高效,高并发优秀,资源占用少

gin有哪些常用中间件

日志,跨域,权限

gin怎么用swagger写接口文档

1.引入所需包(gin-swagger和其他包)

2.根目录下swag init,生成配置文件

3.在go文件中用特定格式写路由,函数,参数,返回值等信息

package mainimport ("net/http""github.com/gin-gonic/gin""github.com/swaggo/files""github.com/swaggo/gin-swagger"_ "your-project-name/docs" // 这里导入生成的 docs 包,注意要替换为实际项目名
)// @title Swagger Example API
// @version 1.0
// @description This is a sample server celler server.
// @termsOfService http://swagger.io/terms/// @contact.name API Support
// @contact.url http://www.swagger.io/support
// @contact.email support@swagger.io// @license.name Apache 2.0
// @license.url http://www.apache.org/licenses/LICENSE-2.0.html// @host localhost:8080
// @BasePath /api/v1
func main() {r := gin.Default()// 路由组v1 := r.Group("/api/v1"){// @Summary 获取用户信息// @Description 根据用户 ID 获取用户信息// @Tags 用户管理// @Accept  json// @Produce  json// @Param   id     path    int     true        "用户 ID"// @Success 200 {object} User "成功获取用户信息"// @Failure 400 {object} gin.H "无效的请求参数"// @Failure 404 {object} gin.H "用户未找到"// @Router /users/{id} [get]v1.GET("/users/:id", func(c *gin.Context) {// 函数体})// @Summary 创建用户// @Description 创建一个新用户// @Tags 用户管理// @Accept  json// @Produce  json// @Param   user     body    User     true        "用户信息"// @Success 201 {object} User "成功创建用户"// @Failure 400 {object} gin.H "无效的用户信息"// @Router /users [post]v1.POST("/users", func(c *gin.Context) {// 函数体})}// 配置 Swagger UI 路由r.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerFiles.Handler))r.Run(":8080")
}// User 结构体,用于示例
type User struct {ID   int    `json:"id"`Name string `json:"name"`
}

再用swag init 生成docs目录和文件

nginx一般是用来做什么

作为反向代理服务器,

1.可以把客户端的请求转发到后端的多个服务器上实现负载均衡,

2.可以直接提供静态资源

3.或者配置SSL证书实现HTTPS,加密传输

4.配置缓存,减少服务器负担

Traefik和nginx类似,但是traefik是一个反向代理和负载均衡器,为k8s环境设计.动态服务发现,自动更新路由规则

如果调用方法经常超时怎么办

1.超时重试

2.拉长超时时间

3.检查网络状态,带宽,打日志检查请求的服务有没接收到请求

4.缓存和负载均衡

gin中怎么和mysql通信

1.引入依赖

2.配置数据库连接

3.定义数据模型

4.编写增删改查操作sql

从mysql调数据到redis,如何同步

https://www.ppmy.cn/news/1564625.html?action=onClick

分为 一致性要求较高 允许延迟一致

1.一致性要求较高:使用共享锁和排他锁或者延时双删策略,确保缓存和数据库数据一致性,(对性能有影响)

2.允许延迟一致:使用消息队列,异步更新缓存,保证最终的一致性,(有延迟)

延时双删

场景:

  • 当有多个线程或进程可能同时操作数据时,为了避免缓存和数据库的数据不一致,延时双删可以发挥重要作用。
  • 例如,在一个电商系统中,当更新商品信息时,可能会出现以下情况:
    • 线程 A 更新商品信息到数据库,同时删除缓存。
    • 线程 B 此时读取商品信息,由于缓存已删除,它会从数据库读取旧信息并写入缓存。
    • 线程 A 后续的更新操作完成,但是线程 B 写入的旧信息仍在缓存中,导致数据不一致。

解决:

1.写数据库前删除缓存的数据,(确保后续操作不会读到旧缓存)

2.更新数据库

3.延时后第二次删除缓存(确保之前因为并发读取而写入的旧数据被清除)

延迟时间短可能无法清除旧数据

为了避免sleep的性能影响可以使用消息队列延迟删除

redis ,mysql都不存在用户请求的数据怎么办(缓存穿透)

就是缓存穿透

1.缓存空值

2.布隆过滤器

3.前置业务校验

4.黑名单限制特殊IP或用户

redis大Key问题

大Key问题就是redis的键值(key,value)对中,Key或Value很大.导致redis在处理这个数据时IO耗时很高或者费内存,再由于redis单线程导致redis会处于长时阻塞,甚至不可用.

检测 redis-cli --bigkeys 扫描所有的键识别大Key,大致检测大Key

解决

1.避免大量数据存在一个键上

2.数据拆分,把列表,哈希或者集合 中元素拆成多个子元素

3.数据压缩,或者缩减储存数据大小(优化数据结构)

你们小组有哪些人,都是怎么工作的


1.表达人数,和对应职位人数(5人,2后端,1前端,1测试,1产品)
2.个人负责哪部分,表达出个人的重要程度,以及自己职责
3.表达团结一致和融入小组迅速
4.可以反问HR贵公司组织架构是否类似,并且回复和自己之前的架构很像可以快速融入

最有成就感的事

待补充…

发展方向

待补充…

看重公司哪一点

待补充

业务和技术哪个重要

待补充

遇到过什么困难,怎么解决

待补充

反问内容

待补充

prompt书写有什么技巧

1.易读易知官方友善
2.指定角色,不同角色对事物认知不同
3.指定生成的结果格式(json)
4.重要要求的放在前面,末尾重复再次强调
5.减少幻觉(幻觉就是不能让他跳出角色设定,例如:作为一个AI我拒绝回答…)设置在没把握回答或者拒绝回答时,回复提问者固定格式的格式回答
6.可以动态设置多个标签枚举,让AI回答固定标签内容

你认为为什么prompt会有很多不同的模板,不同业务场景适合用不同的与大模型交互的方式吗

对大模型的认识以及自己的运用或者工作时的运用

使用大模型的时候大交互拆成小交互会对token优化多少

简单任务不会优化多少,复杂任务会优化一点,但是连贯性和网络,时间开销会更大

怎么样排查慢查询

1.最简单:慢查询日志. 设置超过多少秒认为慢查询 这个一般是运维在设置

2.找到问题sql 查慢查询原因: EXPLAIN 查询执行计划
查看是否命中索引,扫描行数

3.优化查询条件,使得命中索引,避免select * ,避免Where子句使用函数(可能导致索引失效)

4.加索引,或者分区分表

5.提升内存,磁盘或CPU

k8s了解嘛?

开源容器编排平台,用于自动化容器部署管理的,
主从架构:
主: 配置,控制,管理,调度
从:执行实际的任务,管理容器生命周期,管理网络代理,负载均衡,

主要单元:
pod:一个pod对应一个或多个容器,
service:服务 包含多个pod

场景:微服务部署,持续部署和集成(CI/CD) ,开发云原生应用

优势:高可用,弹性,资源合理管理

一个地方Post请求过多怎么处理(或者消息过多)

消息风暴
0.nginx负载均衡(post请求时)
1.消息队列缓冲,削峰填谷(如果实时性不高)
2.熔断和限流(如果数据不是很重要)
3.合并和压缩(如果重复消息较多)
4.分布式处理负载
5.创建协程异步处理

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/6287.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vs code为不同项目设置不同的背景图

vs code不同项目显示不同的背景图 效果展示 项目1-图 {"background.enabled": true, "background.interval": 0,"background.customImages": ["file:///C:/Users/Administrator/Pictures/bg.png"],"background.style": {&q…

防火墙安全策略

目录 一.拓扑信息 二.需求分析 三.命令行详细配置信息 1.配置IP 2.交换机配置 3.修改安全区域 4.安全策略 四.web界面详细配置 1.配置IP和设置安全区域 2.交换机配置 3.安全策略 五.测试 一.拓扑信息 二.需求分析 1.VLAN 2属于办公区域;VLAN 3属于生…

OpenStack基础架构

openstack是一套IaaS云的解决方案,是一个开源的云计算管理平台 每一台物理机上都会有一个nova服务器 虚拟化其实是在nova主机里启用的 COW技术: 这么来看,3个物理机上产生10个虚拟机,所以把服务分散到10个虚拟机上和分散到4个虚拟…

[论文阅读] (36)CS22 MPSAutodetect:基于自编码器的恶意Powershell脚本检测模型

《娜璋带你读论文》系列主要是督促自己阅读优秀论文及听取学术讲座,并分享给大家,希望您喜欢。由于作者的英文水平和学术能力不高,需要不断提升,所以还请大家批评指正,非常欢迎大家给我留言评论,学术路上期…

如何实现各种类型的进度条

文章目录 1 概念介绍2 使用方法3 示例代码 我们在上一章回中介绍了浮动按钮相关的内容,,本章回中将介绍进度条相关的Widget,闲话休提,让我们一起Talk Flutter吧。 1 概念介绍 进度条是常用的组件之一,它主要用来显示某种动作的完成进度。Flu…

arcgis短整型变为长整型的处理方式

1.用QGIS的重构字段工具进行修改,亲测比arcgis的更改字段工具有用 2.更换低版本的arcgis10.2.2,亲测10.5和10.6都有这个毛病,虽然官方文档里面说的是10.6.1及以上 Arcgis10.2.2百度链接:https://pan.baidu.com/s/1HYTwgnBJsBug…

C#,入门教程(04)——Visual Studio 2022 数据编程实例:随机数与组合

上一篇: C#,入门教程(03)——Visual Studio 2022编写彩色Hello World与动画效果https://blog.csdn.net/beijinghorn/article/details/123478581 C#,入门教程(01)—— Visual Studio 2022 免费安装的详细图文与动画教程https://blog.csdn.net…

【前端】Hexo 部署指南_hexo-deploy-git·GitHub Actions·Git Hooks

文章目录 前言基于 hexo-deploy-git基于 GitHub Actions基于 Git Hooks云平台端服务器端Git HooksSSHNginx 本地机端原理参考 前言 原文地址:https://blog.dwj601.cn/FrontEnd/Hexo/hexo-deployment/ #mermaid-svg-dfuCXqzZCx5I07IO {font-family:"trebuchet …

双指针+前缀和习题(一步步讲解)

前言:如果解决下面这几道题有些问题,或者即使看了我画的过程图也不理解的可以去看看我的上一篇文章,有可能会对你有帮助。 一、《数值元素的目标和》---来自AcWing 数组元素的目标和 给定两个升序排序的有序数组 A和 B,以及一个…

springboot 配置redis

环境配置 springboot3.4 redis5.0.14 redis准备参考下面文章 window下安装redis以及启动 redis客户端安装 引入依赖 <!-- 集成redis依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-…

TODO: Linux 中的装机硬件测试工具

TODO: Linux 中的装机硬件测试工具 装机时需要测一些硬件参数&#xff0c;希望选择一些跨平台的开源软件。 https://linux.do/t/topic/22175 https://www.baeldung-cn.com/linux/system-testing-tools https://blog.csdn.net/weixin_45358801/article/details/142701279

LabVIEW 太阳能光伏发电系统智能监控

本文介绍了基于 LabVIEW 的太阳能光伏发电监控系统的设计与实现&#xff0c;着重探讨了其硬件配置、软件架构以及系统的实现方法。该系统能够有效提高太阳能光伏发电的监控效率和精确性&#xff0c;实现了远程监控和数据管理的智能化。 ​ 项目背景 在当前能源紧张与环境污染…

doris:Broker Load

Broker Load 通过 MySQL API 发起&#xff0c;Doris 会根据 LOAD 语句中的信息&#xff0c;主动从数据源拉取数据。Broker Load 是一个异步导入方式&#xff0c;需要通过 SHOW LOAD 语句查看导入进度和导入结果。 Broker Load 适合源数据存储在远程存储系统&#xff0c;比如对…

WPF5-x名称空间

1. x名称空间2. x名称空间内容3. x名称空间内容分类 3.1. x:Name3.2. x:Key3.3. x:Class3.4. x:TypeArguments 4. 总结 1. x名称空间 “x名称空间”的x是映射XAML名称空间时给它取的名字&#xff08;取XAML的首字母&#xff09;&#xff0c;里面的成员&#xff08;如x:Class、…

网站HTTP改成HTTPS

您不仅需要知道如何将HTTP转换为HTTPS&#xff0c;还必须在不妨碍您的网站自成立以来建立的任何搜索排名权限的情况下进行切换。 为什么应该从HTTP转换为HTTPS&#xff1f; 与非安全HTTP于不同&#xff0c;安全域使用SSL&#xff08;安全套接字层&#xff09;服务器上的加密代…

煤矿场景下拖链检测数据集VOC+YOLO格式21407张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;21407 标注数量(xml文件个数)&#xff1a;21407 标注数量(txt文件个数)&#xff1a;2140…

栈和队列(C语言)

目录 数据结构之栈 定义 实现方式 基本功能实现 1&#xff09;定义&#xff0c;初始化栈 2&#xff09;入栈 3&#xff09;出栈 4&#xff09;获得栈顶元素 5)获得栈中有效元素个数 6&#xff09;检测栈是否为空 7&#xff09;销毁栈 数据结构之队列 定义 实现方…

Flutter鸿蒙化中的Plugin

Flutter鸿蒙化中的Plugin 前言鸿蒙项目内PluginFlutter端实现鸿蒙端实现创建Plugin的插件类注册Plugin 开发纯Dart的package为现有插件项目添加ohos平台支持创建插件配置插件编写插件内容 参考资料 前言 大家知道Flutter和鸿蒙通信方式和Flutter和其他平台通信方式都是一样的&…

探索JavaScript前端开发:开启交互之门的神奇钥匙(二)

目录 引言 四、事件处理 4.1 事件类型 4.2 事件监听器 五、实战案例&#xff1a;打造简易待办事项列表 5.1 HTML 结构搭建 5.2 JavaScript 功能实现 六、进阶拓展&#xff1a;异步编程与 Ajax 6.1 异步编程概念 6.2 Ajax 原理与使用 七、前沿框架&#xff1a;Vue.js …

DeepSeek-R1:性能对标 OpenAI,开源助力 AI 生态发展

DeepSeek-R1&#xff1a;性能对标 OpenAI&#xff0c;开源助力 AI 生态发展 在人工智能领域&#xff0c;大模型的竞争一直备受关注。最近&#xff0c;DeepSeek 团队发布了 DeepSeek-R1 模型&#xff0c;并开源了模型权重&#xff0c;这一举动无疑为 AI 领域带来了新的活力。今…