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.


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

查看所有标签

猜你喜欢:

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

集体智慧编程

集体智慧编程

Toby Segaran / 莫映、王开福 / 电子工业出版社 / 2015-3 / 79.00元

《集体智慧编程》以机器学习与计算统计为主题背景,专门讲述如何挖掘和分析Web 上的数据和资源,如何分析用户体验、市场营销、个人品味等诸多信息,并得出有用的结论,通过复杂的算法来从Web 网站获取、收集并分析用户的数据和反馈信息,以便创造新的用户价值和商业价值。全书内容翔实,包括协作过滤技术(实现关联产品推荐功能)、集群数据分析(在大规模数据集中发掘相似的数据子集)、搜索引擎核心技术(爬虫、索引、查......一起来看看 《集体智慧编程》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具