Gin is a HTTP web framework written in Go (Golang). It features a Martini-like API with much better performance -- up to 40 times faster. If you need smashing performance, get yourself some Gin.
Gin是用Golang开发的一个微框架,相似Martinier的API,重点是小巧、易用、性能好不少,也由于 httprouter 的性能提升了40倍。linux
首先,根据对应的操做系统选择安装包下载,git
在这里我使用的是Centos 64位系统github
wget https://studygolang.com/dl/golang/go1.9.2.linux-amd64.tar.gz tar -zxvf go1.9.2.linux-amd64.tar.gz mv go/ /usr/local/
配置 /etc/profilegolang
vi /etc/profile
添加环境变量GOROOT和将GOBIN添加到PATH中web
export GOROOT=/usr/local/go export PATH=$PATH:$GOROOT/bin
添加环境变量GOPATH(这个可按实际状况设置目录位置)编程
export GOPATH=/usr/local/go/path
配置完毕后,执行命令令其生效segmentfault
source /etc/profile
在控制台输入go version
,若输出版本号则安装成功api
那么你们会有些疑问,纠结go
自己有什么东西,咱们刚刚设置的环境变量是什么?缓存
一、 go
自己有什么东西架构
首先,咱们在解压的时候会获得一个名为go
的文件夹,其中包括了全部Go
语言相关的一些文件,在这下面又包含不少文件夹和文件,咱们来简单说明其中主要文件夹的做为:
Go
版本顺序的API增量列表文件。这里所说的API包含公开的变量、常量、函数等。这些API增量列表文件用于Go
语言API检查go
、godoc
、gofmt
godoc
命令启动一个Web程序展现这些文档Go
标准库后的全部归档文件(以.a
结尾的文件)。注意,你会发现其中有名称为linux_amd64
的文件夹,咱们称为平台相关目录。这类文件夹的名称由对应的操做系统和计算架构的名称组合而成。经过go install
命令,Go
程序会被编译成平台相关的归档文件存放到其中Go
自身、Go
标准工具以及标准库的全部源码文件Go
自己的全部相关文件二、 刚刚设置的环境变量是什么
Go
的根目录Go
的bin
下会存放可执行文件,咱们把他加入PATH中就能够直接在命令行使用三、 工做区是什么?
这在Go
中是一个很是重要的概念,在通常状况下,Go
源码文件必须放在工做区中,也就是说,咱们写的项目代码都必须放在咱们所设定的工做区中,虽然对于命令源码文件来讲,这不是必须的。但咱们大多都是前一种状况。工做区其实就是一个对应特定工程的目录,它应包含3个子目录:src
目录、pkg
目录、bin
目录
go install
命令安装后的代码包的归档文件(.a 结尾的文件)go install
命令完成安装后,保存由Go命令源码文件生成的可执行文件四、 什么是命令源码文件?
若是一个源码文件被声明属于main
代码包,且该文件代码中包含无参数声明和结果声明的main
函数,则它就是命令源码文件。命令源码文件可经过go run
命令直接启动运行
If using go1.5, ensure GO15VENDOREXPERIMENT=1 is set.
在命令行下执行安装
go get -u github.com/kardianos/govendor
等待一会,安装成功后。
咱们cd /usr/local/go/path
(第三方依赖包,会默认安装在GOPATH的第一个目录下)目录,
执行ls
,能够在工做区中看到bin
、pkg
、src
三个目录。这就是咱们上面一小节所说的工做区了!
那么,咱们所安装的govendor去哪里了呢?
答案就在工做区内,所生成的代码包大概是这样。咱们所须要的是编译好的可执行文件,在/usr/local/go/path/bin
中。
path/ ├── bin │ └── govendor ├── pkg │ └── linux_amd64 │ └── github.com │ └── kardianos │ └── govendor │ ├── ... └── src └── github.com └── kardianos └── govendor ├── ...
你们还记得咱们先前在环境变量PATH
中设置了GOBIN,
咱们如今要作的就是把工做区中bin
目录下的可执行文件govendor
给移动过去,或者你能够将$GOPATH的BIN目录给加入环境变量中
那样就能够直接在命令行直接执行govendor
了
mv /usr/local/go/path/bin/govendor /usr/local/go/bin/
移动成功后,在命令行执行govendor -version
,若出现版本号,则成功
#govendor -version $ v1.0.9
在这里为何单独挑出一节来说govendor
呢?
你们能够想一想,虽然咱们在本地开发,利用$GOPATH
达到安装第三方依赖包,而后去使用他,彷佛也没有什么问题。
可是在实际的多人协做及部署中是有问题的
go get
不少次所以咱们在这简单的使用govendor
来解决这个问题,在这个项目完成的最后,你只需govendor init
再govendor add +external
就能美滋滋的把依赖包都放到项目的vendor
目录中,就能把它一同传上你的版本库里了,是否是很方便呢。
固然了,目前官方推荐的包管理工具就有十几种,你们能够适当考察一下,这个不在本篇的范围内。
在命令行下执行安装
go get -u github.com/gin-gonic/gin
检查/usr/local/go/path
中是否存在gin
的代码包
编写一个test.go
文件
package main import "github.com/gin-gonic/gin" func main() { r := gin.Default() r.GET("/ping", func(c *gin.Context) { c.JSON(200, gin.H{ "message": "pong", }) }) r.Run() // listen and serve on 0.0.0.0:8080 }
执行test.go
go run test.go
访问$HOST:8080/ping,若返回{"message":"pong"}
则正确
curl 127.0.0.1:8080/ping
至此,咱们的环境安装都基本完成了:)
具体gin
的介绍从连载二开始,会讲解Demo所涉及的知识点!