golang是 Google 公司开发的一种静态强类型、编译型、并发型、并具有垃圾回收功能的编程语言。
Go语言(或 Golang)起源于 2007 年,并在 2009 年正式对外发布。Go 是非常年轻的一门语言,它的主要目标是“兼具 Python 等动态语言的开发速度和 C/C++ 等编译型语言的性能与安全性”。
Golang:Go的三个作者分别是: Rob Pike(罗伯.派克),Ken Thompson(肯.汤普森)和Robert Griesemer(罗伯特.格利茨默)
Go(又称 Golang)是 Google 的 Robert Griesemer,Rob Pike 及 Ken Thompson 开发的一种静态强类型、编译型语言。Go 语言语法与 C 相近,但功能上有:内存安全,GC(垃圾回收),结构形态及 CSP-style 并发计算。
1、初学Go语言首先弄懂基础语法和概念:基本数据类型、Struct、Array、map、Slice、指针、接口、map、内置函数,常用工具包
等,还有接口和Slice的底层数据结构。这些不需要弄特别懂,能自己理解并自己描述我觉得就可以了,关键在实践和应用练习。
2、然后学文件操作、网络编程、锁、协程、对象序列化和反序列化,以及各种数据格式的封装等,这是进阶的内容。
学完上面两个阶段,就可以自己接触一些框架,然后搭建一个web服务器,来做一些测试和练习。Go各种框架都非常多了,github上
star数过万的就有很多,这里列举几个:beego、iris、gin、echo、revel等。对于学习一些使用方法还是很有帮助的。
3、在第三个阶段做的过程中,自然就接触到了数据库,io,操作系统,网络,存储优化、需要排很多雷。到这一步,已经能够模块化
诞生时间
Go 语言起源 2007 年,并于 2009 年正式对外发布。它从 2009 年 9 月 21 日开始作为谷歌公司 20% 兼职项目,即相关员工利用 20% 的空余时间来参与 Go 语言的研发工作。
其实可以看到,Go语言的历史不算很短。
谷歌的“20%时间”工作方式,允许工程师拿出20%的时间来研究自己喜欢的项目。语音服务Google Now、谷歌新闻Google News、谷歌地图Google Map上的交通信息等,全都是20%时间的产物。
Go语言最开始也是20%时间的产物
Golang最大的特色可以说是协程(goroutine)了, 协程让本来很复杂的异步编程变得简单, 让程序员不再需要面对回调地狱。
要理解协程的实现, 首先需要了解go中的三个非常重要的概念, 它们分别是G, M和P,没有看过golang源代码的可能会对它们感到陌生, 这三项是协程最主要的组成部分, 它们在golang的源代码中无处不在..
go语言前景:
1.在云计算、微服务、基础后端软件上具有强大优势
2.得到诸多大厂的"青睐",很多部门由java转golang,新公司甚至直接使用golang
3.优秀开源项目不断涌现,以docker和k8s为代表
go语言优势:
1.兼顾C语言级别的编译、运行效率,容易部署,PHP级别的开发效率
2.强大的标准库,内置高效的垃圾回收机制
3.简单的并发编程,goroutine和channel极易上手
4.静态类型语言,拥有强大的编译检查、严格的编码规范
5.背景强大,由三位骨灰级大师创造,google公司运营维护
Ken Thompson(肯·汤普逊):1983年图灵奖、1998年美国国家技术奖得主,他与Dennis Ritchie是Unix系统的原创者。Thompson也发明了C语言、B语言,同时也是C语言的主要发明人。
Rob Pike(罗布·派克): 加拿大人,曾是贝尔实验室的Unix团队和Plan 9操作计划的成员。他与Thompson公事多年,并共创出广泛使用的UTF-8字元编码。(ps:Go语言的图标-gopher 囊地鼠,是Rob Pike老婆制作的)
Robert Griesemer:曾协助制作Java的HotSpot编译器,和Chrom浏览器的JavaScript引擎V8.
goroutine, 天然支持并发。网络编程很合适,在云计算方面用的较多, 如docker
工作职责:
1、负责数据库架构设计及中长期规划;
2、负责数据库的监控,备份,性能优化及故障处理等 ;
3、数据库分库分表方案的设计、实施及数据迁移;
4、负责根据项目需求设计并制定数据库解决方案;
5、负责SQL review,慢SQL优化等工作;
6、负责高可用及容灾落地实施工作;
7、制定并不断完善数据库的运维规范、开发规范及安全规范。
任职资格:
1、计算机相关专业本科及以上,三年以上Oracle 、Mysql 、DB2运维管理经验,精通RAC,DATAGUARD,OGG,具备ES,MongoDB、Redis使用经验优先考虑; 2、熟悉MySQL数据库体系结构和工作原理,熟悉常见存储引擎的原理、特点以及主从复制原理和实践,熟悉目前常用的开源中间件解决方案,有分表分库相关项目经验;
3、具备较强的数据库设计、SQL优化能力,并能根据业务需求,提供高可用、高性能、可扩展、稳定可靠的数据库解决方案;
4、有一定的脚本语言编程(python,golang等)等自动化开发能力优先;
5、良好的沟通、协调能力,能在一定的压力下有效开展工作,有阿里云数据库工作经验优。
少则及几千块钱多则几万块钱。自己可以在网上通过一些视频来学习,有很多都是免费的,也有一些付费的讲解视频。