1.Go语言之前编程的痛点
(1)为什么会设计Go语言?
我们先来了解一下Go的作者和主要核心开发者们:Robert Griesemer, Rob Pike 和 Ken Thompson。设计Go语言是为了解决当时Google开发遇到的以下这些问题:
-
大量的C++代码,同时又引入了Java和Python;
-
成千上万的工程师;
-
数以万计行的代码;
-
分布式的编译系统;
-
数百万的服务器;
其主要有以下几个方面的痛点:
-
编译慢;
-
失控的依赖;
-
每个工程师只是用了一个语言里面的一部分;
-
程序难以维护(可读性差、文档不清晰等);
-
更新的花费越来越长;
-
交叉编译困难;
所以,他们当时设计Go的目标是为了消除各种缓慢和笨重、改进各种低效和扩展性。Go是由那些开发大型系统的人设计的,同时也是为了这些人服务的;它是为了解决工程上的问题,不是为了研究语言设计;它还是为了让我们的编程变得更舒适和方便。
但是结合Google当时内部的一些现实情况,如很多工程师都是C系的,所以新设计的语言一定要易学习,最好是C-like的语言;因为有太多的分布式系统、太多的开发者,所以新的语言一定要可以Scale,这个包括开发、工程师、代码、部署和依赖;20年没有出新的语言了,所以新设计的语言必须是现代化的(例如内置GC)等情况,他们觉得要实现这个目标就需要Go成为一个大家都认可的语言。
最后根据实战经验,他们向着目标设计了Go这个语言,其主要的特色有:
-
没有继承的OO;
-
强一致类型;
-
Interface但是不需要显示申明(Duck Type);
-
Function 和Method;
-
没有异常处理(Error is value);
-
基于首字母的可访问特性;
-
不用的Import或者变量引起编译错误;
-
完整而卓越的标准库包;
Go发布之后,很多公司特别是云计算公司开始用Go重构他们的基础架构,很多都是直接采用Go进行了开发。这几年火到爆的Docker、Kubernetes就是采用Go开发的。我们来看看目前为止采用Go的一些国内外公司,国外的如Google、Docker、Apple、Cloud Foundry、CloudFlare、Couchbase、CoreOS、Dropbox、MongoDB、AWS等公司,国内的如阿里云CDN、百度、小米、七牛云、PingCAP、华为、金山软件、猎豹移动、饿了么等公司。
(2)Go主要应用的系统。
上面那些基本上就是Go的历史背景和设计初衷,那么目前Go主要应用于哪些系统呢?
目前Go主要应用在下面这些系统:
①Web服务器编程,以前你如果使用C或者C++做的那些事情,用Go来做很合适,例如处理日志、数据打包、虚拟机处理、文件系统等。
②容器开发:Docker,使开发高效且可预测;Kubernetes,也称为K8s,是一个开源系统,用于自动化容器化应用程序的部署,扩展和管理。
③微服务、分布式系统、数据库代理器等,例如gRPC、Etcd等。
④Web网络编程,这一块目前应用最广,包括Web应用、API应用、下载应用,而且Go内置的net/http包足够强大,基本就涵盖了常用的Web应用方法了。
⑤数据库,前一段时间Google开发的Groupcache,Couchbase的部分组建,Tidb,Cockroachdb,Influxdb等。
⑥云平台,目前国外很多云平台