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

  1. 打开cmd
  2. go version
  3. go run hello.go
  4.  
  5. package main
  6.  
  7. import "fmt"
  8.  
  9. func main() {
  10. fmt.Println("hello go")
  11. }

还要安装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的更多相关文章

  1. 第一篇:初始Golang

    Golang简介 编程语言已经非常多,偏性能敏感的编译型语言有 C.C++.Java.C#.Delphi和Objective-C 等,偏快速业务开发的动态解析型语言有PHP.Python.Perl.R ...

  2. golang 时间的比较,time.Time的初始值?

    参考: https://golangcode.com/checking-if-date-has-been-set/ https://stackoverflow.com/questions/209243 ...

  3. golang语言构造函数

    1.构造函数定义 构造函数 ,是一种特殊的方法.主要用来在创建对象时初始化对象, 即为对象成员变量赋初始值,总与new运算符一起使用在创建对象的语句中.特别的一个类可以有多个构造函数 ,可根据其参数个 ...

  4. golang 使用 iota

    iota是golang语言的常量计数器,只能在常量的表达式中使用. iota在const关键字出现时将被重置为0(const内部的第一行之前),const中每新增一行常量声明将使iota计数一次(io ...

  5. Golang 语法学习笔记

    Golang 语法学习笔记 包.变量和函数. 包 每个 Go 程序都是由包组成的. 程序运行的入口是包 main. 包名与导入路径的最后一个目录一致."math/rand" 包由 ...

  6. 从OOP的角度看Golang

    资料来源 https://github.com/luciotato/golang-notes/blob/master/OOP.md?hmsr=toutiao.io&utm_medium=tou ...

  7. Golang语法与代码格式速记【转】

    // Description: Golang语法与代码格式速记 // Author: cxy // Date: 2013-04-01 // Version: 0.3 // TODO 说明 // TOD ...

  8. 【GoLang】golang 最佳实践汇总

    最佳实践 1 包管理 1.1 使用包管理对Golang项目进行管理,如:godep/vendor等工具 1.2 main/init函数使用,init函数参考python 1.2.1 main-> ...

  9. GoLang之基础

    GoLang之基础 Go是一种并发的.带垃圾回收的.快速编译的语言. 经典的"hello world"入门: package main import "fmt" ...

随机推荐

  1. hive 分隔符替换

    Hive建表的时候虽然可以指定字段分隔符,不过用insert overwrite local directory这种方式导出文件时,字段的分割符会被默认置为\001,一般都需要将字段分隔符转换为其它字 ...

  2. shell excute mongo query command

    use shell command method one: #!/bin/bash ] then echo 'Please input cid' exit fi HOST= mongo ${HOST} ...

  3. 企业wiki之confluence安装部署(linux)及其破解

    系统环境(虚拟机) centos6.5   2G运行内存,30g硬盘,cpu最好也分配两个或多个,因为我在安装过程中发现很卡,cpu占用率几乎占满 需要用到的安装包和文件可以在这里找 链接:https ...

  4. MySQL在登陆时出现ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)错误

    错误显示:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES) 解决方案: 1.找到配 ...

  5. oracle数据字典-权限-角色-参数

    每个数据库都提供了各自的数据字典的方案,虽然形式不同,但是目的和作用是一样的,比如在mysql里数据字典是在information_schema 里表现的,sqlserver则是在sys这个系统sch ...

  6. openstack--1--基础环境搭建

    Openstack介绍 OpenStack是一个由NASA(美国国家航空航天局)和Rackspace合作研发并发起的,以Apache许可证授权的自由软件和开放源代码项目. Openstack包含三大项 ...

  7. Java面向对象 第1节 类和对象

    一.Java 对象和类 面向对象语言三大特性:封装.继承.多态: 对象:描述客观事物的一个实体: 类:类是封装对象的属性和方法的载体,反过来说具有相同属性和行为的一类实体被称为类:类行为:方法:属性: ...

  8. [转]一致性hash算法 - consistent hashing

    consistent hashing 算法早在 1997 年就在论文 Consistent hashing and random trees 中被提出,目前在 cache 系统中应用越来越广泛: 1  ...

  9. naturalWidth与naturalHeight

    naturalWidth与naturalHeight是HTML5的新属性, 可与通过这两个属性来直接获取图片的原始宽度和高度, 现在在火狐, 谷歌, IE11均已经实现 可以看看naturalWidt ...

  10. parcel (另一个打包工具)知识点

    ParcelJS 本身是 0 配置的,但 HTML.JS 和 CSS 分别是通过 posthtml.babel 和 postcss 处理的,所以我们得分别配 .posthtmlrc..babelrc ...