简单高效:几乎全部主流的编程语言如Java、C++、PHP、Python、JavaScript等等都是能够用于服务端开发的,Go语言做为后起之秀,在语言层面具备语法简洁、执行效率高(底层语言)的特色;相比之下,Java和Python、PHP都显得低效,C++则太过麻烦,而Go则能够作到简单与高效兼顾;java
下面咱们来看下这几个领域有哪些成功的开源项目。golang
Docker(容器)
到如今,Docker几乎是Go再难找到也难以复制的一个成功案例。Docker项目在2014年9月份就拿到了C轮4000万美圆融资,版本迭代速度超快,目前从GitHub看到已有78个版本,而它仅仅是再2013年初才正式开始的一个项目而已。目前,国内Docker技术推广也进行的如火如荼,好比 Docker中文社区,CSDN也创建了 Docker专区。
Docker团队之因此喜欢用Go语言,主要是Go具备强大的标准库、全开发环境、跨平台构建的能力。算法
Kubernetes(容器)
Kubernetes是2014年夏天Google推出的Kubernetes,基于Docker,其目的是让用户经过Kubernetes集群来进行云端容器集群的管理,而无需用户进行复杂的设置工做。系统会自动选取合适的工做节点来执行具体的容器集群调度处理工做。其核心概念是Container Pod(容器仓)。数据库
Etcd & Fleet(分布式数据库)
etcd是由CoreOS开发并维护键值存储系统,它使用Go语言编写,并经过Raft一致性算法处理日志复制以保证强一致性。目前,Google的容器集群管理系统Kubernetes、开源PaaS平台Cloud Foundry和CoreOS的Fleet都普遍使用了etcd。
Fleet则是一个分布式的初始化系统。它们之因此选择使用Go语言,则是由于Go语言对跨平台的良好支持,以及其背后的强大社区。编程
Deis(云服务平台)
Deis是一个基于Docker和CoreOS的开源PaaS平台,旨在让部属和管理服务器上的应用变得轻松容易。它能够运行在AWS、GCE以及Openstack平台下。后端
Flynn(云服务平台)
Flynn是一个使用Go语言编写的开源PaaS平台,可自动构建部署任何应用到Docker容器集群上运行。Flynn项目受到Y Combinator的支持,目前仍在开发中,被称为是下一代的开源PaaS平台。缓存
Lime(桌面应用)
相对上面的几款Go语言在云端和服务器端以外,Lime则显得比较特殊。Lime则是一款用Go语言写的桌面编辑器程序,被看作是著名编辑器Sublime Text的开源实现。服务器
Revel(Web框架)
Revel是一个高生产力的Go语言Web框架。Revel框架支持热编译,当编辑、保存和刷新源码时,Revel会自动编译代码和模板;全栈特性,支持路由、参数解析、缓存、测试、国际化等功能。并发
InfluxDB(分布式数据库)
一个Go语音编写的开源分布式的时序、事件和指标数据库,无需外部依赖。其设计目标是实现分布式和水平伸缩扩展。框架
Syncthing(云盘)
一款用Go语言编写的开源云存储和同步服务工具,用户的数据将由本身彻底控制,全部的通讯全都加密,每一个访问节点都用加密证书验证。该项目被认为是Dropbox和 BitTorrent Sync的开源替代,Syncthing之因此选择Go语言,也是出于跨平台考虑。
Gogs(自助Git服务)
Gogs则是一款由国人无闻( GitHub)开发的自助Git服务项目。Gogs的目标是打造一个最简单、最快速和最轻松的方式搭建自助Git服务。据做者称,之因此选择使用Go语言开发,就是Go容许Gogs能够经过独立的二进制分发,且对跨平台有良好支持。
原文连接:https://blog.csdn.net/u010986776/article/details/87276303