2 min read
前言
之前的月余 学习了一下 GO 语言,基础知识过的很快,但是上手之后发现Go真实博大精深,我才窥知一角,不由得 要把心得体会记下来随时看看。
缘起
最开始做了个获取elasticsearch的demo,但是到后来处理未知结构json的时候发现了很大的问题,原生的解析方式有两种,已知结构的可以定义一个结构体,未知结构的需要解析到interface里面,通过类型判断达到解析的目的,这种方式对于多字段来说无疑是个悲剧, 还有就是用第三方的包,虽然解析上和类型推断上方便了很多但是多字段的问题依然没有解决。或许现在已经有了很好的方案但是我觉得对于超多字段的超多层级json的解析go 这里还是短板,如果不区分类型都转为泛型对于后面的逻辑处理并不友好。
上面先拍了一转头,下面就是amazing, go channel 这种协程真的是非常舒服,初学时候的是否制定channel 大小,阻塞还是非阻塞的channel都是一种选择,也需要深入了解,尤其是网络编程上面的使用,我的新练手项目的一部分已经提交了 这准确说就是个客户端, dorylus 可以让我们分布式的执行cronjob,master-slave 模式我更喜欢称为manager-worker 模式,我目前实现了worker 部分,但是核心的manager 部分只实现了手动切换,还没敢提交,并且近期发现woker有很多不足。 整个项目想法很简单就是先起一个tcp服务端,利用cron 定时器做基础,开出不同的协程执行每一个用户定义任务,执行完回写log,可以向该worker 发起停止信号重新开始信号,回收worker 机器实时状态,如cpu mem lb 信息等,为监控和智能调整做准备。还需要的功能就是job 探针和多worker并行,单worker车轮模式执行和断点续传(保护现场再还原)。这些功能当然都是必要的。
大多数的开发兴趣都是源自一个很小的点,比如想偷懒(各种小工具),或者想获取更多内容(爬虫)。想起用nodejs 做的小爬虫,又萌生了用go做一个的想法。
Ronchi
Readmore posts by this author.
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 编译型语言、解释型语言、静态类型语言、动态类型语言概念与区别
- 计算机语言发展的三个阶段:机器语言、汇编语言与高级语言
- 凹 (“Wa”) 语言:可以嵌入 Go 语言环境的脚本语言
- Rust语言恰巧是一门解决了Go语言所有问题的语言
- 获取系统语言/当前 App支持语言
- 【Go 语言教程】Go 语言简介
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。