当前位置:首页 > 文章列表 >golang

golang
golang专题下共有 1368 篇文章
  • Golang文件监控:fsnotify实时监听教程
    Golang文件监控:fsnotify实时监听教程
    在Go语言中,fsnotify包可用于实时监控文件或目录变化,支持多种事件类型,并可通过递归监听实现目录树监控。使用步骤如下:1.安装fsnotify包并导入;2.创建watcher实例并添加监听路径;3.启动goroutine循环处理事件;4.根据事件类型(如Create、Write、Remove等)执行相应逻辑;5.注意递归监听需结合filepath.WalkDir手动实现,同时考虑性能优化与跨平台兼容性问题。
    Golang· Go教程   |  2个月  |   golang 文件监控 fsnotify 文件变化 实时监听 319浏览 收藏
  • Golang搭建KnativeServerless平台实战
    Golang搭建KnativeServerless平台实战
    要使用Golang开发Knative自定义扩展,需理解其扩展机制并掌握控制器运行时工具。1.熟悉Knative提供的CRD、Webhook、Autoscaler等扩展点及其基于controller-runtime的实现方式;2.按照kubebuilder或operator-sdk初始化项目结构,定义CRD并编写Reconciler逻辑,部署为Deployment形式监听资源变化;3.开发Webhook时注意启用TLS、生成合法证书并正确配置MutatingWebhookConfiguration或Vali
    Golang· Go教程   |  1个月  |   golang 控制器 Serverless Knative 自定义扩展 319浏览 收藏
  • Golang值类型赋值接口的装箱与逃逸分析
    Golang值类型赋值接口的装箱与逃逸分析
    将值类型赋值给接口时会触发装箱操作并导致内存逃逸。1.装箱过程包括在堆上分配内存、拷贝数据、存储类型信息,并创建包含指针和类型描述符的接口值;2.内存逃逸因编译器无法确定变量生命周期或大小超出栈限制而发生,装箱必然导致逃逸;3.使用gobuild-gcflags'-m'可判断逃逸情况;4.逃逸会影响性能并增加GC压力;5.避免方法包括减少接口使用、使用类型断言、传递指针类型;6.接口由etype和data组成,分别指向类型信息和实际数据;7.空接口虽灵活但性能损耗较大,应避免过度使用。理解这些机制有助于提
    Golang· Go教程   |  2个月  |   golang 性能 接口 装箱 内存逃逸 318浏览 收藏
  • Golang常量技巧:const与iota详解
    Golang常量技巧:const与iota详解
    在Go语言中,const用于定义编译期确定且不可变的常量,适合表示数学常数、状态码等不变数据;1.常量可无类型,根据上下文自动转换,也可显式指定类型;2.iota是常量生成器,从0开始,在每个const块内递增,适用于枚举场景;3.可通过占位符\_跳过值、通过表达式设置起始值、结合位运算定义标志;4.const支持分组定义,可在包级或函数内部使用,但不能进行运行时计算;5.常见误区包括对常量取地址、混用不同类型、逻辑混乱的分组,应避免此类误用以提升代码质量。
    Golang· Go教程   |  1个月  |   golang const 位运算 枚举 iota 318浏览 收藏
  • Golang错误预警集成Prometheus告警规则
    Golang错误预警集成Prometheus告警规则
    用Golang实现错误预警系统的方法是:1.使用prometheus/client_golang库捕获错误并转化为Prometheus指标,例如通过计数器记录错误次数;2.配置Prometheus抓取应用暴露的指标;3.通过PromQL定义告警规则,设置错误率阈值触发告警;4.配置Alertmanager处理并路由告警通知到指定渠道;5.Golang应用接收Webhook执行具体告警动作。选择客户端库时优先考虑官方维护的prometheus/client_golang,性能敏感场景可选fastly/go-
    Golang· Go教程   |  1个月  |   golang prometheus 错误预警 告警规则 Alertmanager 318浏览 收藏
  • GolangTCP粘包处理与自定义拆包方案
    GolangTCP粘包处理与自定义拆包方案
    TCP粘包问题的解决核心在于自定义应用层协议以标识消息边界,并在接收端正确拆包处理。1.TCP粘包是其正常行为,由发送方合并小包、接收方读取慢或数据过大被分片等原因引起。2.协议设计要点包括:消息头包含固定长度字段(如int32)标识消息体长度,结构清晰易编解码。3.Golang实现拆包流程为:持续读取数据至缓冲区,判断是否含完整消息头和消息体,满足条件则提取处理,否则等待后续数据。4.实际开发建议使用bufio.Reader、成熟框架如gRPC,注意字节序一致、缓冲区管理及拆包逻辑独立运行,同时处理连接
    Golang· Go教程   |  1个月  |   golang TCP粘包 自定义协议 拆包 消息边界 318浏览 收藏
查看更多
课程推荐
  • Golang深入理解GPM模型
    Golang深入理解GPM模型
    Golang深入理解GPM调度器模型及全场景分析,希望您看完这套视频有所收获;包括调度器的由来和分析、GMP模型简介、以及11个场景总结。
    474次学习
  • Go语言课程Gin框架实战
    Go语言课程Gin框架实战
    Gin是一个用Go(Golang)编写的HTTPweb框架。它是一个类似于 martini 但拥有更好性能的API框架,由于 httprouter,速度提高了近40倍。如果你需要极好的性能,使用Gin吧。
    338次学习
  • Golang云原生架构师课程
    Golang云原生架构师课程
    Go是一门并发支持、垃圾回收的编译型系统编程语言;本课程转载自哔哩哔哩:https://www.bilibili.com/video/BV1Mh411M7A
    204次学习
  • Go编程基础视频教程
    Go编程基础视频教程
    Go是一门并发支持、垃圾回收的编译型系统编程语言,旨在创造一门具有在静态编译语言的高性能和动态语言的高效开发之间拥有良好平衡点的一门编程语言。我们收集了这套《Go编程基础视频教程》,希望能够帮助大家更好的学习go语言。
    167次学习
  • Golang进阶实战编程
    Golang进阶实战编程
    本课程是在《Go语言基础视频》基础之上录制的,是Go语言基础的后半部分。包括包的管理,IO操作,Go语言最大的亮点:高并发,goroutine,channel,反射等。本视频主要为了帮助Go语言的初学者,从零到一的快速入门。学完本套课程,可以学会如果通过包管理Go项目,并发模型,以及并发实现,channel通道如何传递数据,反射等等。
    129次学习
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码