在 2025 收官前,看清 Data + AI 的真实走向,点击查看 BUILD 大会精华版 了解详情
写点什么

Go 的四年与成长

  • 2013-11-13
  • 本文字数:1816 字

    阅读完需:约 6 分钟

2013 年 11 月 10 日,开源项目 Go 庆祝了它的四周年纪念日(Go 第一版发布于2012 年三月;这里说的四周年,是从最初项目创建之日开始计算的)。Go 由Robert Griesemer、Rob Pike 和Ken Tompson 在Google 创建,随后Ian Taylor 和Russ Cox 也在开源之前加入了项目。以下是来自其 FAQ 的一段摘录:

Go 的诞生,源自对现有系统编程的语言和环境的挫败感。编程已经变得太过艰难,而其中部分原因应当归咎于语言的选择。开发者必须在高效编译、高效执行与易于开发之间做出抉择;然而,在主流编程语言中,并不存在一门语言能够同时实现三方面因素。侧重易用性胜过安全和效率的程序员们,会转而使用动态类型语言,例如 Python 和 JavaScript,而不是 C++,而且他们在一定程度上或许也丢开了 Java。

Go 尝试着将动态类型解释语言在编程方面的易用性,与静态类型编译语言的效率和安全性进行结合。它的目标还包括成为支持网络和多核计算的现代语言。最后,它还需要成为一门“快速的语言”:最多花费几秒钟,就能够在单台电脑上构建起大型可执行程序。要满足这些目标,必须解决大量语言问题:兼顾表达性和轻量级类型的系统;支持并发和垃圾回收;拥有严格的依赖规范;以及其他需要解决的问题。这些问题无法通过类库和工具来完美解决,只有一门全新的语言才有可能搞定这一切。

Go 当前最新版本是 2013 年 5 月发布的 1.1 版;1.2 版预计将在本月下旬问世,另外在一份兼容性文档中提到了未来的程序与Go 1 之间的兼容性,暗示了Go 所采用的兼容性的前瞻性方法,正是其他编译式语言所缺乏的。

从发布到现在,已经有许多公司开始使用Go,例如轻量容器中的应用打包工具 Docker 、自动创建机器映像的 Packer 、提供分布式信息发送平台的 Bitly’s NSQ 、提供基础设施自动化的 Canonical’s JuJu ,以及其他许多公司。甚至自由软件基金会也在谈论用Go 取代Java 作为默认语言。Docker 团队也在一场演讲中,阐述了为何他们会选择使用Go。

而对DevOps 人群来说,其主要价值在于,Go 程序永远静态地链接到单一可执行程序中——该程序可被部署在目标平台上。因此,系统并不需要预先安装任何额外二进制文件,也无需操心同时运行不同版本的程序会产生冲突。这个特性能够与像Linux 和Java 这样的打包系统相媲美——它们拥有覆盖多个位置的类库,并要求特定的安装位置,或是一个用来预先构建路径的解析器。(下行风险是,在所有程序的静态二进制文件中,通用类库不断重复出现;但同时硬盘空间的价格并不昂贵。相反,对于运行许多进程的系统来说,服务器上的内存压力或许是更现实的问题——不重复载入某个类的映像,而是只载入一次的话,将有效减少内存压力。幸而,Devops 工具一般并不会长时间运行。)

对高可用性和多线程程序来说,主要好处是Go 的 goroutines ——它采用与 Erlang 或 Occam 相似的方式,允许执行多线程来服务收到的请求。这三者都是基于 Hoare 的通讯顺序进程( Communicating Sequential Processes ),简称 CSP。CSP 并不处理内存和进程访问,相反,每个 CSP 都拥有一个消息 / 任务的传入队列,并且能够依次将这些消息 / 任务发送给其他 CSP。CSP 支持阻塞和异步操作;每个(阻塞的)CSP 都拥有一个返回值,一般被作为返回消息发送给始发的 CSP。

Cloud Foundry 最近把它的命令行工具从Ruby 换成了Go ,以实现无需任何特定前置条件极可使用命令的目的。实际上,现在它是一个用来与后端服务沟通的轻量级工具;而且现在不再由客户端来执行复杂的验证程序,而是由它与后端沟通来完成繁重工作。这意味着该工具现在不再需要频繁升级,同时体积也得以缩小。

随着 Go 1.2 即将在下周到来,该语言也做出了改变:增加了对三索引切片(slice)的支持。此前,表达式 a[1:10] 将把数组中的 1 到 10 个元素进行切片;而现在 a[1:2:10] 将以间隔方式切出元素。一项细小的澄清是,对于使用 nil 的地方,如果取消引用会引起恐慌。其他变化请参考发行注记

一些针对的Go 批评家指出,该语言使用了一种旧式的编程返回码风格,而不是得到更广泛采用的基于异常的风格;另外与Erlang(函数式编程,没有可变状态)不同,goroutines 能够传送字典(map)。由于默认情况下字典是非同步的,因此这有可能会导致内存冲突。不过,目前很明确的是,Go 非常适合针对特定细分领域的用例;而且无论从哪方面与Java 和Erlang 这样的语言进行对比,Go 都可以被看作轻量级语言;同时,与纯C 相比,Go 或许是个更安全的选择。

查看英文原文: Go Fourth and Grow

2013-11-13 04:293337
用户头像

发布了 256 篇内容, 共 88.4 次阅读, 收获喜欢 10 次。

关注

评论

发布
暂无评论
发现更多内容

tiup目录冲突检测不健全导致的节点被destroy问题以及解决

TiDB 社区干货传送门

TiDB 数据库开发规范

TiDB 社区干货传送门

AskTUG 论坛迁移实战:Discourse 从 PostgreSQL 到 MySQL 到 TiDB

TiDB 社区干货传送门

【文章】精选实践汇总1

TiDB 社区干货传送门

实践案例

某业务升级5.0解决慢SQL问题

TiDB 社区干货传送门

实践案例 故障排查/诊断

TiDB 集群的可用性详解及 TiKV Label 规划

TiDB 社区干货传送门

TiDB 底层架构

TiDB 5.0 异步事务特性体验——基于X86和ARM混合部署架构

TiDB 社区干货传送门

常见问题排查之 -- DM 主键冲突的原因及排查思路

TiDB 社区干货传送门

【精选实践】TiDB 在马上消费金融核心账务系统归档及跑批业务下的实践

TiDB 社区干货传送门

实践案例

端到端的实时计算:TiDB + Flink 最佳实践

TiDB 社区干货传送门

实践案例

5.0 新特性试用体验之 Clustered Index

TiDB 社区干货传送门

实践案例 TiDB 底层架构 版本测评 新版本/特性发布 性能测评

招募体验官!构建实时数仓 - 当 TiDB 遇见 Pravega

TiDB 社区干货传送门

tidb开发规范

TiDB 社区干货传送门

SQL只是CRUD?

TiDB 社区干货传送门

TiDB 底层架构

如果你的 kubelet 运行在容器中,使用 local static provisioner 要注意一个问题

TiDB 社区干货传送门

基于阿里云ECS部署的TiDB 2.1.14升级到4.0.0-rc实践

TiDB 社区干货传送门

管理与运维 安装 & 部署

【TiDB 最佳实践系列】开发 Java 应用使用 TiDB 的最佳实践

TiDB 社区干货传送门

实践案例

【TiDB DevCon 2020】金融专题论坛演讲视频汇总

TiDB 社区干货传送门

【TiDB 4.0 新 Feature 原理及实践】 Dashboard 触手体验

TiDB 社区干货传送门

写冲突场景下的悲观/乐观事务模型选择

TiDB 社区干货传送门

实践案例

TiKV 集群部署 注意事项

TiDB 社区干货传送门

几分钟读懂 TiDB HTAP

TiDB 社区干货传送门

移动云基于 TiDB 实现 serverless 数据库服务

TiDB 社区干货传送门

【热门问题】关于近期签名过期的处理合集

TiDB 社区干货传送门

【TiDB 最佳实践系列】乐观锁事务

TiDB 社区干货传送门

实践案例

TiDB at ZaloPay Infrastructure & Lesson Learned

TiDB 社区干货传送门

日本大型移动支付软件 PayPay 的 TiDB 迁移实践

TiDB 社区干货传送门

PD 分配 TS 的 QPS 上限揭密

TiDB 社区干货传送门

NewSQL 在微众银行核心批量场景的应用

TiDB 社区干货传送门

实践案例

一次热点问题排查经历

TiDB 社区干货传送门

故障排查/诊断

Flink + TiDB,体验实时数仓之美

TiDB 社区干货传送门

实践案例

Go的四年与成长_DevOps & 平台工程_Alex Blewitt_InfoQ精选文章