七牛云存储使用Go语言架设网站的经验分享

所属分类: 网站运营 / 建站经验 阅读数: 97
收藏 0 赞 0 分享

Go 语言是谷歌 2009 年首次推出并在 2012 年正式发布的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:七牛之所以开发 Go,是因为过去10多年间软件开发的难度令人沮丧。Google 对 Go 寄予厚望,其设计是让软件充分发挥多核心处理器同步多工的优点,并可解决面向对象程序设计的麻烦。它具有现代的程序语言特色,如垃圾回收,帮助开发者处理琐碎但重要的内存管理问题。Go 的速度也非常快,几乎和 C 或 C++ 程序一样快,且能够快速开发应用程序。

最初去评估Go语言最重要的原因是,七牛没有找到一门合适的语言。从云计算领域的主要技术方案看,最受欢迎的是C++和Java。七牛知道亚马逊是用了Java。我个人尝试Java做服务端开发是在2007年金山实验,Java的风格比较拘束或严谨,与我推崇的编程风格不合,并且在分布式系统开发上没有显著的优势,所以才会关注Erlang(也因此有了ECUG社区)、Go等小众语言。在我评估完Go语言后,我认为它是云计算领域最合适的开发语言。

如果说到 Java 曾经的流行,我们会联想到 SSH(Struts + Spring + Hibernate);如果提到 Python,也会联想到 Django;如果提到 Ruby,会联想到 Ruby on Rails;如果提到 JavaScript,会联想到 NodeJS;如果提到 PHP,更是一堆长江后浪推前浪前浪死在沙滩上的 Web 开发框架。这些编程语言社区的繁荣昌盛无一例外都和 Web 开发息息相关,且最终沉淀下来的都是各种五花八门各有千秋的众多 Web 开发框架。可以说,我们当前所面临和 Web 开发的技术选型,从未有过如此的繁荣。繁荣的背后,衬托的是一个大江东流去不复还的 PC Web 时代。


稳定性来说,云计算都是假设单机是可以宕机的,要在单机的不可靠下让整个集群可靠(这种宕机甚至不为用户所感知)。七牛并不担心单个进程的稳定性,哪怕Go程序每天会挂一次,对七牛而言,也是可以接受的。

Go语言入门门槛非常之低。有任何其他语言的背景,学习Go语言只需要一周的时间。**七牛面试从来不问你会不会Go语言。七牛关心的是开发者的能力与七牛业务的匹配度,比如他算法基础如何、是否擅长网络编程、是否适合创业(对事情的责任感)等等。

Go 语言的哪些特点最吸引人?

并发

Go 最大的特色就是在语言层面天生支持并发,不需要像其他大多数编程语言那样需要开发者自行实现或借助第三方类库实现并发编程,Go 在语言级别支持的并发编程,其逻辑简化得通俗易懂简单好上手。

性能

不同于大多数脚本或解释性的高阶编程语言,用 Go 编写的代码直接了当编译成机器码高效执行。

简洁

25 个关键字即表达你能想到的所有招式,没有也不需要有任何多余,想干啥事就 go 一下。

跨平台

x86、AMD64 (x86_64)、ARM;Linux、Windows、Darwin (OSX)、FreeBSD、Android (计划Go 1.4) 几乎全平台支持,真正做到一份源码,随处编译,到处运行。


Go 语言都有哪些常见的应用场景?

作为一个 Go 语言的重度用户来看,当前除了不适合拿来造操作系统以外在操作系统之上应用级的事情都能干。再更具体一点,比如说适用于这样一些使用场景:

系统应用

以前要用 C/C++ 做的系统应用,现在都可以用 Go 来写,事半功倍,而且 Go 完美包容 C 源代码,两者互相调用还可以混合编译从而无缝集成。

网络应用

包含了常见的服务端编程比如 Web 和 API Service,以前用 PHP / Python / Ruby / Java 干的事情现在都可以用 Go 更加简单清晰的来写。再比如还可以拿来做一些 Proxy(代理)如网络穿透软件等,你懂的。

分布式系统

基于 Go 强大的系统编程加网络编程,打造各种跨网络的分布式系统服务,Go 社区有不少和分布式系统相关的开源产物。

各种形态的存储和数据库应用

比如 groupcache,influxdb 等。

客户端应用

包括带界面的桌面软件,以及后续可以想像的移动端应用(比如对 Android 的支持)。

云服务(PaaS)

如基于 Go 打造的七牛云存储(分布式对象存储系统),比如基于 Go 编写的 Docker(一款开源的容器虚拟化产物)。

Go 能做的事情,包含但不限于以上罗列的使用场景。

比如 Web 开发。大多数编程语言之上的 Web 开发框架都是遵照 MVC 的处理流程去开发 Web 应用:Model 部分封装数据,Controller 部分处理业务逻辑,View 部分植入变量填充模板页面。而大部分 Web 框架关于 MVC 的三部分都是在 Server-side 处理,比如对 View 部分的处理都是在 Server-side 通过程序动态对模版变量求值后再拼接组装成 HTML 页面输出给浏览器去呈现。而 Go 开发 Web 应用,并不依赖任何 Web 开发框架,用内置的标准库就可以轻而易举地实现:比如使用 net/http 标准库就可以数行代码构建一个完整的 Web 骨架应用;再比如,通过关键字 struct 封装一个数据结构就可以表达原本 MVC 框架中需要用厚重的 ORM (Object-Relational Mapping) 才能表达的那部分。大道至简,这可以说是 Go 的哲学。在 View 这一层,Go 也有相应标准库提供支持,但更推荐的做法,是当下比较流行的 MVVM (Model-View-ViewModel):Server-side 只输出 JSON,浏览器 DOM 作为 View 层,前端 JavaScript 充当 Contoller 部分;这样,不仅减少了 Server-side 的资源消耗还有中间传输的网络流量,而且前端可以更灵活和更丰富,后端也可以更轻盈和更高效,也更有利于项目的分工和协作。


Go 语言在七牛中都开发了些什么服务?在七牛的代码量中,Go 语言使用占多少比例?

七牛主要使用 Go 开发了以下服务和工具:

分布式存储系统 ( Distributed Key/Value Storage)
数据处理服务 (Data Processing)
网络接口服务 (RESTful API Service)
消息队列服务(Message Queue Service)
日志处理系统 (Log Service)
Web 网站 (不含前端 JavaScript)
CLI 命令行和 GUI 图形界面工具
其他辅助工具
总的来讲,Go 在七牛七牛的工程中代码覆盖率超过 90% 。还有 10% 不能覆盖的原因是七牛给开发者自助使用的 Web 界面需要用 JavaScript 编程来实现酷炫的前端,以及七牛为开发者准备了多达超过 10 种编程语言的 SDK 。

我们再来看看 Go 在当下这个多核时代的作为。不得不说,Go 最大的特色就是在语言层面天然支持并发,在 Go 程序里边,你可以通过在一个函数调用前使用关键字 go 即可让该函数 func 运行成为一个独立的 goroutine,goroutine 可以理解成一种比线程更加轻盈更省开销的轻量级协程。Go 的并发模型就是通过系统的线程来多路派遣这些独立函数的执行,使得每个用关键字 go 执行调用的函数可以运行成为一个单位协程。当⼀个协程阻塞的时候,调度器就会自动把其他协程安排到另外的线程中去执行,从而实现程序的无等待并行化运行。且调度的开销非常小,单核 CPU 调度的规模不下于每秒百万次,这使得我们能够创建大量的 goroutines,从而可以很轻松地编写并发程序达到我们想要的目的。

同时,Go 在语言层面还引入了 channel 这一内置类型来实现并发执行体 goroutines 之间的消息传递,通信靠 channels 来传递消息。Go 遵循 CSP(Communicating sequential processes) 并发模型,通过通信来共享内存而不是用共享内存的方式进行通信。Go 的并发里边没有共享内存,更没有内存锁,这一切都有利于进行更为安全和简单的并行程序编写。

更多精彩内容其他人还在看

医疗行业怎么做好网站建设?建站注意事项及经验

踏足互联网,医疗行业可以将自身优势资源整合到网站中去,为大家提供病理知识、在线咨询或者预约就诊服务等。那么如何做好医疗行业的网站建设呢?本期为大家分享一些在建站过程中需要注意的东西和建站经验,希望能给大家带来帮助
收藏 0 赞 0 分享

企业应该怎么策划自己的网站?规划网站注意事项总结

网站建设虽然是一个比较复杂的过程,包括网站策划、网页设计、程序开发、上传网页、发布网站等,那么企业应该怎么策划自己的网站?下面为大家介绍规划网站注意事项,来看看吧
收藏 0 赞 0 分享

大众点评网站的支付系统构建经验分享

大众点评网站的服务器端在迭代的同时保持了很好的扩展性和可用性,这里我们来看一下大众点评网站的支付系统构建经验分享,主要以大众点评的支付渠道网关系统为核心.
收藏 0 赞 0 分享

网易蜂巢的容器运维管理服务使用指南

网易蜂巢提供对Docker容器的警报和性能监控服务,通过图形化面板操作十分简洁,这里前提假设服务器端已经架设在容器中,那么接下来就让我们来看网易蜂巢的容器运维管理服务使用指南
收藏 0 赞 0 分享

为什么认为自助建站不适合SEO?自助建站工具搭建出来的网站对SEO的支持如何?

最近有一个做SEO优化朋友询问为什么自助建站做出来的网站排名很难做上去?自助建站工具搭建出来的网站真的适合SEO吗?本文将提供相关内容供大家了解,希望对大家有所帮助和启发
收藏 0 赞 0 分享

支持支付宝的高性价比美国VPS主机Pzea的购买及使用评测

Pzea一直是低价位VPS的人气之选,在美国三个大城市分别建有机房,且构建于KVM虚拟机之上,性能较为出众,接下来就为大家来分享一下这个支持支付宝的高性价比美国VPS主机Pzea的购买及使用评测
收藏 0 赞 0 分享

网站页面一定需要HTML静态化吗 实战说明静态化的必要性

很多刚开始运营网站的伙伴们都要知道网站内的页面需要进行URL优化吗?如设置静态化等,对此,本文就为大家解析一下网站静态化的必要性,有兴趣的朋友们可以了解下哦
收藏 0 赞 0 分享

移动端界面设计之尺寸基础知识学习

这篇文章主要为大家详细介绍了移动端界面设计之尺寸基础知识,通俗易懂的学习教程帮助大家了解关于移动端设计尺寸的相关知识,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

如何提高用户体验?优秀的用户体验需要遵守的十大准则

自己的网站做的很漂亮却依然没有排名,这是为什么呢?这个时候,你应该考虑你是否关注到用户体验?而如何提高用户体验又是你要考虑的问题了,本文将提供优秀的用户体验需要遵守的十大准则供大家了解,希望对大家有所帮助和启发
收藏 0 赞 0 分享

DoubleClick Ad Exchange Seller(adx) 为您的广告代码生成异步代码的方法

这篇文章主要介绍了DoubleClick Ad Exchange Seller(adx) 为您的广告代码生成异步代码的方法,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多