漫谈Go语言后端开发

为什么使用Go语言做后端开发?

  • 简单高效:几乎所有主流的编程语言如Java、C++、PHP、Python、JavaScript等等都是可以用于服务端开发的,Go语言作为后起之秀,在语言层面具有语法简洁、执行效率高(底层语言)的特点;相比之下,Java和Python、PHP都显得低效,C++则太过麻烦,而Go则可以做到简单与高效兼顾;
  • 高并发:Go语言是主打并发、为并发而生的,其出发点即是瞄准大数据+云计算时代背景下的高并发、分布式应用场景;
  • 跨平台:可以在不同平台直接编译生成可执行程序,基础内存占用很少,小应用占用几M大型应用占用个几十M就能很好运行,这使得golang可以在树莓派之类的小设备上很好的运行,这一点表现比java要好的多;

容器化、分布式、微服务化是服务端发展的潮流,在这几个方向上:

  • 容器化:容器领域Go语言是绝对的霸主,大家所熟知的Docker和Kubernets(K8S)就是使用Go语言开发的;
  • 分布式:最好的例证就是以太坊,因为区块链即分布式账本;
  • 微服务:Go语言支持微服务的最好例证是今日头条,今日头条当前后端服务超过80%的流量是跑在 Go 构建的服务上。微服务数量超过100个,高峰 QPS 超过700万,日处理请求量超过3000亿,可能是业内最大规模的Go应用。

Go语言成功案例

  • 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可以通过独立的二进制分发,且对跨平台有良好支持。

Go后端开发前景

  • 2018年求职市场Go语言工程师需求增长率达到了800%,因此这个职业方向应该是现下最有“钱”途的职业方向了。
  • 以下数据来自拉勾网,可以看出Go语言后台开发的招聘量是充足的,特别在北上深等一线城市;
    漫谈Go语言后端开发_第1张图片
    漫谈Go语言后端开发_第2张图片
    漫谈Go语言后端开发_第3张图片
    漫谈Go语言后端开发_第4张图片
    漫谈Go语言后端开发_第5张图片
    漫谈Go语言后端开发_第6张图片
  • 以帝都为例,Go开发工程师的薪水,在随机样本中最低为10K,最高去到60,大面积落在20K-40K区间内;
    漫谈Go语言后端开发_第7张图片
    漫谈Go语言后端开发_第8张图片

Go后端开发学习难度如何?

  • 单就语法层面而言,Go语言的难度与Java相仿

兄弟连【Go全栈区块链】教学大纲
漫谈Go语言后端开发_第9张图片
漫谈Go语言后端开发_第10张图片

更多参考:
http://www.cnblogs.com/findumars/p/9230722.html
https://blog.csdn.net/aa1215018028/article/details/82753479
https://zhidao.baidu.com/question/584394281.html

FAQ

Go语言是什么?

  • 谷歌推出的底层语言,主打高并发特性;
  • 同时语法简洁、执行效率高;
  • 理论上什么都可以做,而事实上主要的应用场景是:服务器后台、区块链、云服务
  • 这些主要都是因为它的高并发和分布式特性;

区块链是什么?

  • 分布式账本;

区块链的应用场景是什么?

  • 数字货币(已经落地并且已经饱和了);
  • 农产品溯源、奢侈品溯源、知识产权保护;——这些都是因为区块中的信息无法篡改;
  • 房屋租赁、保险理赔——智能合约绑定账户并自动执行;
  • STO(证券通证)——企业资产证券化(通过代币体现)并流通(其实就是有监管的发币,有多少资产才能发多少代币,需要国家做公证);
  • 几乎所有的金融和契约场景——资产代币化、契约和交易记录无法篡改、契约(智能合约)的自动执行;

GoWeb跟区块链的区别是什么,或者关系是什么?

  • GoWeb、Go服务端开发、Go后端开发、Go全栈都是一个意思,就是做服务端应用开发;
  • 区块链是分布式的账本,每个节点都相当于一台服务器,每台服务器上都有数据库,它相当于一个大型的分布式存储系统;
  • 区块链跟分布式Web服务器没有本质区别;
  • 其实Java、Python、C++等语言都是既可以做Web又可以做区块链的;
  • 只不过【5G+大数据+云服务背景】下【分布式和高并发服务器开发】成为趋势,而Go语言恰恰主打的就是高并发(同时简单高效);
  • 所以Go语言是区块链的首选语言,也是分布式高并发Web开发的未来首选语言;

Go全栈目前行业里主流的就业方向是什么?

  • 首先,在Web领域,Java/php能做什么Go就能做什么,而且更加简单高效;
  • 在以下场景中,Go尤其凸显语言优势:
  • 对效率要求高的场景:比如推荐引擎,要迅速根据大数据分析形成用户画像,并生成推荐内容——所以今日头条的推荐引擎就是用Go来做的;
  • 复杂算法场景:比如大数据排序,以前用C/C++来做,现在可以使用Go来做;
  • 高并发场景:一个Go语言开发的服务端可执行程序能承受百万级并发,而Java要使用更多的服务器来做负载均衡,这就增加了成本;
  • 分布式场景:尤其是大规模分布式场景,或者计划要加入区块链的服务器节点;

兄弟连课程的优势在哪里?

  • 大纲贴合企业需求:分布式、微服务、数据结构算法设计模式;
  • 师资团队实力强:清华大神尹成+大赛获奖无数的豪华师资班底;
  • 实战性强:每个阶段都有大型实战项目;
  • 就业导向:每个阶段都贯彻笔试和面试题;
  • 追求卓越:产品质量永远放在第一位,对产品质量有成体系的制度保障,包括:教学测评、教师的薪酬晋升期权、留级和末位淘汰制度等;

Go能做的,Java和其他语言能做吗?

  • C++/Java/php/Python/Go都可以做Web开发和区块链开发;
  • Web来说,小公司用php,大公司用Java(Java对高并发+分布式+微服务+云服务这些都有成熟的支持),牛逼的大公司率先用Go,因为Go的天然后发优势(相比Java,开发和执行效率都更高,并发能力更强,不足是现有框架和解决方案较少,生态上无法和Java掰手腕);
  • 区块链来说,主要是Go和C++(因为必须要考虑执行效率的问题),也有少量使用Java的公司(现成的分布式服务器和数据库);

比如像PHP他的应用更多是网站 Java是企业级应用,GO是什么呢,针对这个应用GO的优势在哪里,为什么不用其他语言做呢?

  • php的优势是开发成本低,劣势是对【高并发+分布式+微服务+云服务】的支持无力;
  • Java和Go都对【高并发+分布式+微服务+云服务】有良好支持;
  • Java的优势是生态繁荣,框架和解决方案成熟而丰富,劣势是语言的开发效率和执行效率都落后,很多现有解决方案庞大臃肿积重难返;
  • Go的优势是并发能力强、简单高效,不足是成熟的框架和解决方案少,具有一定的研发风险;
  • C/C++复杂高效,它的应用领域主要是硬件、操作系统、游戏、以及后端服务中对效率要求较高的局部场景;

目前GO在国内发展了有多久了,之前应用的都有哪些项目,为什么现在火起来了?

  • 近两三年才发展起来,之前的项目见上文;
  • 火起来的原因:
  • 简单高效高并发的语言特性;
  • 大家对于谷歌的盲目崇拜;
  • 以太坊、Docker、今日头条的成功;
  • 一线公司的纷纷使用:BAT、360、B站、头条…

GO全栈区块链帝国②

加入兄弟连Go全栈区块链帝国,免费获取海量学习资源
漫谈Go语言后端开发_第11张图片

你可能感兴趣的:(Go语言Web开发框架)