2021-01-04 09:56:11 阅读(190)
Go语言是谷歌于2009年首次推出并于2012年正式发布的全新编程语言,可以降低代码的复杂性,而不会损失应用程序的性能。谷歌首席软件工程师罗布派克(RobPike)七牛之所以开发Go,是因为过去10年软件开发的难度令人沮丧。谷歌对谷歌寄予厚望,其设计是让软件充分发挥多核心处理器同步多工的优点,并能解决面向对象的程序设计问题。它具有垃圾回收等现代程序语言特征,帮助开发人员处理琐碎但重要的内存管理问题。Go的速度也很快,几乎与C或C相同 程序一样快,应用程序可以快速开发。最初评估Go语言最重要的原因是七牛没有找到合适的语言。从云计算领域的主要技术方案来看,C是最受欢迎的 还有Java。七牛知道亚马逊用的是Java。我个人在2007年金山实验中尝试Java进行服务端开发。Java的风格比较克制或者严谨,不符合我推崇的编程风格,分布式系统开发没有明显优势,所以我会关注Erlang(所以有ECUG社区)、Go等小众语言。在我评估了Go语言之后,我认为它是云计算领域最合适的开发语言。说到Java的流行,我们会想到SSH(Struts Spring Hibernate);说到Python,也会想到Djangon;说到Ruby,会想到RubyonRailss。;如果提到JavaScript,会想到NodeJS;如果提到PHP,是长江后浪推前浪死在沙滩上的一堆Web开发框架。这些编程语言社区的繁荣无一例外都与网络开发密切相关,最终沉淀了各种各样的网络开发框架。这些编程语言社区的繁荣无一例外都与网络开发密切相关,最终沉淀了各种各样的网络开发框架。可以说,我们目前面临的技术选择从未如此繁荣。繁荣的背后,衬托出一个PCWeb时代,大江东流不复返。就稳定性而言,云计算假设单机可以停机,整个集群应该在单机不可靠的情况下可靠(这种停机甚至不被用户感知)。七牛不担心单个过程的稳定性,即使Go程序每天挂一次,对七牛来说也是可以接受的。Go语言的入门门槛很低。在任何其它语言的背景下,学习Go语言只需要一个星期。**七牛面试从来不问你会不会Go语言。七牛关心开发人员的能力与七牛业务的匹配程度,如他的算法基础、他是否擅长网络编程、他是否适合创业(他对事物的责任感)等。Go语言最吸引人的特点是什么?并发Go最大的特点是自然支持语言层面的并发编程,开发者不需要像大多数其他编程语言那样实现或借助第三方类库实现并发编程。Go在语言层面支持的并发编程简化了逻辑,易于理解和启动。与大多数脚本或解释性的高级编程语言不同,Go编写的代码直接编译成机器代码。简洁的25个关键词就是表达你能想到的所有动作,没有也没有必要有任何多余的动作,想做什么就做什么。跨平台x86、AMD64(x86_64)、ARM;Linux、Windows、Darwin(OSX)、FreeBSD、Android(计划Go1.4)几乎全平台支持,真正做到源代码,到处编译,到处运行。Go语言有哪些常见的应用场景?作为Go语言的重度用户,目前除了不适合制造操作系统外,还可以在操作系统上做应用级的事情。更具体一点,比如适用于这样的使用场景:系统应用前使用C/C 现在可以用Go写系统应用,事半功倍,Go完美包容C源代码,可以混合编译无缝集成。网络应用包括Web、APIService等常见的服务端编程,以前使用PHP/Python/Ruby现在Java所做的一切都可以用Go更简单清晰地写出来。再比如也可以用来做一些Proxy(代理),比如网络穿透软件,你知道的。基于Go强大的系统编程和网络编程,分布式系统创建了各种跨网络分布式系统服务。Go社区有许多与分布式系统相关的开源产品。groupcache、influxdb等各种形式的存储和数据库应用。客户端应用包括带界面的桌面软件和后续可想象的移动端应用(如支持Android)。云服务(PaaS)比如基于Go的七牛云存储(分布式对象存储系统),比如基于Go的Docker(开源容器虚拟化产品)。Go能做的,包括但不限于上面列出的使用场景。例如Web开发。大多数编程语言上的Web开发框架都是根据MVC的处理过程开发Web应用程序:Model部分包装数据,Controler部分处理业务逻辑,View部分植入变量填充模板页面。大多数Web框架中MVC的三个部分都是在Server-side中处理的。例如,View部分的处理是在Server-side通过程序动态找到模板变量值后拼接组装成HTML页面输出到浏览器。Go开发Web应用程序不依赖任何Web开发框架,可以通过内置标准库轻松实现:例如,使用net/http标准库可以构建一个完整的Web骨架应用程序数行代码;另一个例子,数据结构可以通过关键字struct包装来表达MVC框架中需要使用的厚ORM(Object-RelationalMapping)能表达的部分。大道至简,可以说是Go的哲学。Go在View层也有相应的标准库支持,但更推荐的做法是目前流行的MVVM(Model-View-ViewModel):Server-Side只输出JSON,浏览器DOM作为View层,前端JavaScript作为Contoller部分;这样,不仅减少了Server-side的资源消耗,还减少了中间传输的网络流量,而且前端更灵活、更丰富,后端更轻、更高效,更有利于项目的分工与合作。七牛中Go语言开发了哪些服务?Go语言在七牛中开发了哪些服务?Go语言在七牛的代码量中占多大比例?七牛主要利用Go开发以下服务和工具:分布式存储系统(DistributedKey/ValueStorage)数据处理服务(DataProcessing)网络接口服务(RESTfulAPIService)新闻队列服务(MessageQueueService)日志处理系统(LogService)一般来说,Web网站(不包括前端JavaScript)CLI命令行和GUI图形界面工具等辅助工具,七牛七牛工程Go代码覆盖率超过90%。另外10%无法覆盖的原因是七牛为开发者自助使用的Web界面需要JavaScript编程来实现酷炫的前端,七牛为开发者准备了多达10种编程语言的SDK。另外10%无法覆盖的原因是七牛自助开发人员使用的Web界面需要JavaScript编程来实现酷炫的前端,七牛为开发人员准备了多达10种编程语言的SDK。让我们来看看Go在当前多核时代的行动。不得不说,Go最大的特点就是在语言层面自然支持并发。在Go程序中,您可以在函数调用前使用关键字Go,使函数func运行成独立的goroutine。goroutine可以理解为一个比线程更轻、更经济的轻量级协程。Go的并发模型是通过系统的线程多路派遣这些独立函数的执行,使用关键字Go执行调用的每个函数都可以作为单位协程运行。当⼀当一个协程被堵塞时,调度器会自动将其他协程安排到另一个线程中进行执行,从而实现程序的无等待并行运行。而且调度费用很小,单核CPU的调度规模不低于每秒100万次,让我们可以创建大量的谷歌,轻松编写并发程序,达到我们想要的目的。同时,Go还在语言层面引入了内置类型的channel,实现并发执行体goroutines之间的信息传递,通信通过channnels传递信息。Go遵循CSP(Communicatingsequentialprocesses)并发模型通过通信共享内存,而不是通过共享内存。Go的并发没有共享内存,更不用说内存锁了,所有这些都有利于编写更安全和简单的并行程序。
以上就是关于经验分享:七牛云存储使用Go语言架设网站的相关介绍,更多经验分享:七牛云存储使用Go语言架设网站相关内容可以咨询我们或者浏览页面上的推荐内容。我们将让你对经验分享:七牛云存储使用Go语言架设网站有更深的了解和认识。
推荐阅读
最新文章
猜你喜欢以下内容:
一 客户顾问-张三 一

