初始Golang
Golang初识
字节跳动也就是我们常说的今日头条
1.今日头条基于Go语言构建千亿级微服务的实践
今日头条当前后端服务超过80%的流量是跑在Go构建的服务上
微服务数量超过100个
高峰QPS超过700万
日处理请求量超过3000亿
是业内最大规模的Go应用
2.Go构建微服务的历程
在2015年之前,头条的主要编程语言是Python以及部分C++
随着业务和流量的快速增长,服务端的压力越来越大,随之而来的问题频出
Python的解释型语言特性以及落后的多进程服务模型受到了巨大的挑战
此外,当时的服务端是一个典型的单体架构,耦合严重
部分独立功能也急需从单体架构中拆出来
3.为什么选择Go语言?
Go语言相对其他语言具有几点天然的优势:
语法简单,上手快
编译型语言,运行速度快
性能高,编译快,开发效率也不低
天生支持并发,充分利用多核,协程模型是非常优秀的服务端模型,同时也适合网络调用
静态编译,部署方便,编译包小,没有依赖
4.什么是Go?
Go语言是Google于2009年推出的一门新的系统编程语言。
Go的另外一个名字叫Golang,简称云计算时代的C语言。
Go是一门并发支持、垃圾回收的编译型系统编程语言,旨在创造一门具有在静态编译语言的高性能和动态语言的高效开发之间拥有良好平衡点的一门编程语言。
Go语言介于C和Python之间,运行速度快,开发效率高。
5.Go的主要特点有哪些?
可直接编译成机器码,不依赖其他库
类型安全和内存安全
以非常直观的极低代价的方案实现高并发
高效的垃圾回收机制
快速编译(同时解决C语言中头文件太多的问题)
为多核计算机提供性能提升的方案
UTF-8编码支持
跨平台编译
内嵌C支持
特点:静态类型语言,但是有动态语言的感觉
1.静态编译
2.垃圾回收
3.简洁的符号和语法
4.平坦的类型系统
5.基于CSP的并行模型
6.高效简单的工具链
7.丰富的标准库
6.Go存在的价值是什么?用来做什么?
Go在谷歌,以软件工程为目的的语言设计
服务器编程
分布式系统
网络编程
内存数据库
云平台
Go是记事本编码吗?
包括vim IDEA Sublime Text Eclipse等众多知名IDE均已支持
vscode idea liteide goland
7.国内知名互联网公司在使用Go语言的有哪些?
百度 BFE项目手百消息通讯系统
阿里 CDN
腾讯 腾讯游戏蓝鲸平台
京东 云消息推送系统、云存储、京东商场
小米 运维监控系统、小米互娱、小米商城、小米视频、小米生态链
360 日志搜索系统Poseidon
美图、滴滴等等
字节跳动 今日头条基于Go语言构建千亿级微服务的实践
8.Go语言写的开源软件有哪些?
Docker 容器
Kubernetes Google Borg的开源实现
Etcd 类似zookeeper的高可用key-value存储
9.什么时候用Go?
做一些页面,逻辑变化大用Python
高性能大规模,分布式集群管理用Go
10.Golang软件下载的地址在哪?
官方下载地址https://golang.org/dl
国内下载地址https://dl.gocn.io
https://golangtc.com/download
我们下载这个go1.9.2.windows-amd64.msi
打开cmd go version go run hello.go package main import "fmt" func main() { fmt.Println("hello go") }
还要安装Git
11.Go语言开发工具的ide
liteide
https://liteide.org/cn/
https://sourceforge.net/projects/liteide/files
12.Go语言帮助文档
go语言官网https://golang.org
go中文社区https://studygolang.com
go中文在线文档https://studygolang.com/pkgdoc
初始Golang的更多相关文章
- 第一篇:初始Golang
Golang简介 编程语言已经非常多,偏性能敏感的编译型语言有 C.C++.Java.C#.Delphi和Objective-C 等,偏快速业务开发的动态解析型语言有PHP.Python.Perl.R ...
- golang 时间的比较,time.Time的初始值?
参考: https://golangcode.com/checking-if-date-has-been-set/ https://stackoverflow.com/questions/209243 ...
- golang语言构造函数
1.构造函数定义 构造函数 ,是一种特殊的方法.主要用来在创建对象时初始化对象, 即为对象成员变量赋初始值,总与new运算符一起使用在创建对象的语句中.特别的一个类可以有多个构造函数 ,可根据其参数个 ...
- golang 使用 iota
iota是golang语言的常量计数器,只能在常量的表达式中使用. iota在const关键字出现时将被重置为0(const内部的第一行之前),const中每新增一行常量声明将使iota计数一次(io ...
- Golang 语法学习笔记
Golang 语法学习笔记 包.变量和函数. 包 每个 Go 程序都是由包组成的. 程序运行的入口是包 main. 包名与导入路径的最后一个目录一致."math/rand" 包由 ...
- 从OOP的角度看Golang
资料来源 https://github.com/luciotato/golang-notes/blob/master/OOP.md?hmsr=toutiao.io&utm_medium=tou ...
- Golang语法与代码格式速记【转】
// Description: Golang语法与代码格式速记 // Author: cxy // Date: 2013-04-01 // Version: 0.3 // TODO 说明 // TOD ...
- 【GoLang】golang 最佳实践汇总
最佳实践 1 包管理 1.1 使用包管理对Golang项目进行管理,如:godep/vendor等工具 1.2 main/init函数使用,init函数参考python 1.2.1 main-> ...
- GoLang之基础
GoLang之基础 Go是一种并发的.带垃圾回收的.快速编译的语言. 经典的"hello world"入门: package main import "fmt" ...
随机推荐
- YAML Class ID Reference
Classes Ordered by ID Number ID Class 1 GameObject 2 Component 3 LevelGameManager 4 Transform 5 Time ...
- ML(附录1)——梯度下降
梯度下降是迭代法的一种,可以用于求解最小二乘问题(线性和非线性都可以).在求解机器学习算法的模型参数,即无约束优化问题时,梯度下降(Gradient Descent)是最常采用的方法之一,另一种常用的 ...
- webpack 的 入口(Entry)、输出(Output)
入口(Entry) 入口定义了我们的应用代码开始执行的那个文件,webpack从这个文件开始打包.你能定义一个入口点(常见于单页应用 - Single-Page Application), 或者多个入 ...
- CF 316G3 Good Substrings——广义后缀自动机
题目:http://codeforces.com/contest/316/problem/G3 对询问串和模式串一起建一个后缀自动机,做出在每个串上的 right 集合大小之后枚举自动机上的每个点看看 ...
- 螺旋矩阵 II
给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7, 6, ...
- HTMLParser 笔记
# 关于html.parse.HTMLParser的使用 from html.parser import HTMLParser class MyHtmlParser(HTMLParser): # 使用 ...
- websocket连接的后台反向代理问题
今天要介绍的问题,是一个相对来说比较经典的问题,问题表面看不是很复杂的问题,但是反映出的背后通信逻辑,其实还是比较有意义的. websocket协议是当前绝大部分浏览器都支持的长连接协议,是HTTP协 ...
- ByteType字符串中判断是否英文
ByteType('123你好吗',1)=mbSingleByte//单字节ByteType('123你好吗',4)=mbLeadByte//双字节字符的第一个字符ByteType('123你好吗', ...
- 【巷子】---middleware---redux-promise-middleware---【react】
一.Middleware的由来 单一的state是存储在store中,当要对state进行更新的时候,首先要发起一个action(通过dispatch函数),action的作用就是相当于一个消息通知, ...
- Windows Azure Virtual Machine (36) 扩展Azure ARM VM的磁盘大小
<Windows Azure Platform 系列文章目录> 在默认情况下,Azure ARM VM的操作系统磁盘(OS Disk),容量为: (1)Windows VM OS Disk ...