Go语言1

栏目: Go · 发布时间: 6年前

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做一个的想法。

Share on:

Ronchi

Readmore posts by this author.


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

JavaScript Patterns

JavaScript Patterns

Stoyan Stefanov / O'Reilly Media, Inc. / 2010-09-21 / USD 29.99

What's the best approach for developing an application with JavaScript? This book helps you answer that question with numerous JavaScript coding patterns and best practices. If you're an experienced d......一起来看看 《JavaScript Patterns》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

URL 编码/解码
URL 编码/解码

URL 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器