|
| 1 | +# Golang介绍与环境安装 |
| 2 | + |
| 3 | +> 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. |
| 4 | +
|
| 5 | +Gin是用Golang开发的一个微框架,类似Martinier的API,重点是小巧、易用、性能好很多,也因为 [httprouter](https://github.com/julienschmidt/httprouter) 的性能提高了40倍。 |
| 6 | + |
| 7 | +## 准备环节 |
| 8 | + |
| 9 | +### 一、安装Golang |
| 10 | + |
| 11 | +首先,根据对应的操作系统选择安装包[下载](https://studygolang.com/dl), |
| 12 | + |
| 13 | +在这里我使用的是Centos 64位系统 |
| 14 | + |
| 15 | +``` sh |
| 16 | +wget https://studygolang.com/dl/golang/go1.9.2.linux-amd64.tar.gz |
| 17 | + |
| 18 | +tar -zxvf go1.9.2.linux-amd64.tar.gz |
| 19 | + |
| 20 | +mv go/ /usr/local/ |
| 21 | +``` |
| 22 | + |
| 23 | +配置 /etc/profile |
| 24 | + |
| 25 | +``` sh |
| 26 | +vi /etc/profile |
| 27 | +``` |
| 28 | +添加环境变量GOROOT和将GOBIN添加到PATH中 |
| 29 | + |
| 30 | +``` sh |
| 31 | +export GOROOT=/usr/local/go |
| 32 | +export PATH=$PATH:$GOROOT/bin |
| 33 | +``` |
| 34 | +添加环境变量GOPATH(这个可按实际情况设置目录位置) |
| 35 | +``` sh |
| 36 | +export GOPATH=/usr/local/go/path |
| 37 | +``` |
| 38 | +配置完毕后,执行命令令其生效 |
| 39 | +``` sh |
| 40 | +source /etc/profile |
| 41 | +``` |
| 42 | + |
| 43 | +在控制台输入`go version`,若输出版本号则**安装成功** |
| 44 | + |
| 45 | +那么大家会有些疑问,纠结`go`本身有什么东西,我们刚刚设置的环境变量是什么? |
| 46 | + |
| 47 | +1、 `go`本身有什么东西 |
| 48 | + |
| 49 | +首先,我们在解压的时候会得到一个名为`go`的文件夹,其中包括了所有`Go`语言相关的一些文件,在这下面又包含很多文件夹和文件,我们来简单说明其中主要文件夹的作为: |
| 50 | + |
| 51 | +- api:用于存放依照`Go`版本顺序的API增量列表文件。这里所说的API包含公开的变量、常量、函数等。这些API增量列表文件用于`Go`语言API检查 |
| 52 | +- bin:用于存放主要的标准命令文件(可执行文件),包含`go`、`godoc`、`gofmt` |
| 53 | +- blog:用于存放官方博客中的所有文章 |
| 54 | +- doc:用于存放标准库的HTML格式的程序文档。我们可以通过`godoc`命令启动一个Web程序展示这些文档 |
| 55 | +- lib:用于存放一些特殊的库文件 |
| 56 | +- misc:用于存放一些辅助类的说明和工具 |
| 57 | +- pkg:用于存放安装`Go`标准库后的所有归档文件(以`.a`结尾的文件)。注意,你会发现其中有名称为`linux_amd64`的文件夹,我们称为平台相关目录。这类文件夹的名称由对应的操作系统和计算架构的名称组合而成。通过`go install`命令,`Go`程序会被编译成平台相关的归档文件存放到其中 |
| 58 | +- src:用于存放`Go`自身、`Go`标准工具以及标准库的所有源码文件 |
| 59 | +- test:存放用来测试喝验证`Go`本身的所有相关文件 |
| 60 | + |
| 61 | +2、 刚刚设置的环境变量是什么 |
| 62 | +- GOROOT:`Go`的根目录 |
| 63 | +- GOPATH:用户工作区 |
| 64 | +- PATH下增加$GOROOT/bin:`Go`的`bin`下会存放可执行文件,我们把他加入PATH中就可以直接在命令行使用 |
| 65 | + |
| 66 | +3、 工作区是什么? |
| 67 | + |
| 68 | +这在`Go`中是一个非常重要的概念,在一般情况下,`Go`源码文件必须放在工作区中,也就是说,我们写的项目代码都必须放在我们所设定的工作区中,虽然对于命令源码文件来说,这不是必须的。但我们大多都是前一种情况。工作区其实就是一个对应特定工程的目录,它应包含3个子目录:`src`目录、`pkg`目录、`bin`目录 |
| 69 | + |
| 70 | +- src:用于以代码包的形式组织并保存Go源码文件 |
| 71 | +- pkg:用于存放通过`go install`命令安装后的代码包的归档文件(.a 结尾的文件) |
| 72 | +- bin:与pkg目录类似,在通过`go install`命令完成安装后,保存由Go命令源码文件生成的可执行文件 |
| 73 | + |
| 74 | +4、 什么是命令源码文件? |
| 75 | + |
| 76 | +如果一个源码文件被声明属于`main`代码包,且该文件代码中包含无参数声明喝结果声明的`main`函数,则它就是命令源码文件。命令源码文件可通过`go run`命令直接启动运行 |
| 77 | + |
| 78 | +### 二、安装Govendor |
| 79 | +> If using go1.5, ensure GO15VENDOREXPERIMENT=1 is set. |
| 80 | +
|
| 81 | +在命令行下执行安装 |
| 82 | +``` sh |
| 83 | +go get -u github.com/kardianos/govendor |
| 84 | +``` |
| 85 | +等待一会,安装成功后。 |
| 86 | + |
| 87 | +我们`cd /usr/local/go/path`(第三方依赖包,会默认安装在GOPATH的第一个目录下)目录, |
| 88 | + |
| 89 | +执行`ls`,可以在工作区中看到`bin`、`pkg`、`src`三个目录。这就是我们上面一小节所说**的工作区**了! |
| 90 | + |
| 91 | +那么,我们所安装的govendor去哪里了呢? |
| 92 | + |
| 93 | + |
| 94 | +答案就在工作区内,所生成的代码包大概是这样。我们所需要的是编译好的可执行文件,在`/usr/local/go/path/bin`中。 |
| 95 | +``` sh |
| 96 | +path/ |
| 97 | +├── bin |
| 98 | +│ └── govendor |
| 99 | +├── pkg |
| 100 | +│ └── linux_amd64 |
| 101 | +│ └── github.com |
| 102 | +│ └── kardianos |
| 103 | +│ └── govendor |
| 104 | +│ ├── ... |
| 105 | +└── src |
| 106 | + └── github.com |
| 107 | + └── kardianos |
| 108 | + └── govendor |
| 109 | + ├── ... |
| 110 | +``` |
| 111 | + |
| 112 | +大家还记得我们先前在环境变量`PATH`中设置了GOBIN, |
| 113 | + |
| 114 | +我们现在要做的就是把工作区中`bin`目录下的可执行文件`govendor`给移动过去,或者你可以将$GOPATH的BIN目录给加入环境变量中 |
| 115 | + |
| 116 | +那样就可以直接在命令行直接执行`govendor`了 |
| 117 | + |
| 118 | +``` sh |
| 119 | +mv /usr/local/go/path/bin/govendor /usr/local/go/bin/ |
| 120 | +``` |
| 121 | + |
| 122 | +移动成功后,在命令行执行`govendor -version`,若出现版本号,则成功 |
| 123 | + |
| 124 | +``` sh |
| 125 | +#govendor -version |
| 126 | +$ v1.0.9 |
| 127 | +``` |
| 128 | + |
| 129 | +在这里为什么单独挑出一节来讲`govendor`呢? |
| 130 | + |
| 131 | +大家可以想想,虽然我们在本地开发,利用`$GOPATH`达到安装第三方依赖包,然后去使用他,似乎也没有什么问题。 |
| 132 | + |
| 133 | +但是在实际的多人协作及部署中是有问题的 |
| 134 | +- 每一个新来的人都要`go get`很多次 |
| 135 | +- 拉下来的版本还可能不一样 |
| 136 | +- 线上部署更麻烦了 |
| 137 | + |
| 138 | +因此我们在这简单的使用`govendor`来解决这个问题,在这个项目完成的最后,你只需`govendor init`再`govendor add +external`就能美滋滋的把依赖包都放到项目的`vendor`目录中,就能把它一同传上你的版本库里了,是不是很方便呢。 |
| 139 | + |
| 140 | +当然了,目前官方推荐的包管理工具就有十几种,大家可以适当考察一下,这个不在本篇的范围内。 |
| 141 | + |
| 142 | +### 三、安装Gin |
| 143 | +在命令行下执行安装 |
| 144 | +``` sh |
| 145 | +go get -u github.com/gin-gonic/gin |
| 146 | +``` |
| 147 | + |
| 148 | +检查`/usr/local/go/path`中是否存在`gin`的代码包 |
| 149 | + |
| 150 | +### 四、测试Gin是否安装成功 |
| 151 | +编写一个`test.go`文件 |
| 152 | + |
| 153 | +``` go |
| 154 | +package main |
| 155 | + |
| 156 | +import "github.com/gin-gonic/gin" |
| 157 | + |
| 158 | +func main() { |
| 159 | + r := gin.Default() |
| 160 | + r.GET("/ping", func(c *gin.Context) { |
| 161 | + c.JSON(200, gin.H{ |
| 162 | + "message": "pong", |
| 163 | + }) |
| 164 | + }) |
| 165 | + r.Run() // listen and serve on 0.0.0.0:8080 |
| 166 | +} |
| 167 | +``` |
| 168 | + |
| 169 | +执行`test.go` |
| 170 | +``` sh |
| 171 | +go run test.go |
| 172 | +``` |
| 173 | + |
| 174 | +访问$HOST:8080/ping,若返回`{"message":"pong"}`则正确 |
| 175 | +``` sh |
| 176 | +curl 127.0.0.1:8080/ping |
| 177 | +``` |
| 178 | + |
| 179 | +至此,我们的环境安装都基本完成了:) |
| 180 | + |
| 181 | +## 参考 |
| 182 | +### 本系列示例代码 |
| 183 | +- [go-gin-example](https://github.com/EDDYCJY/go-gin-example) |
| 184 | + |
| 185 | +### 相关文档 |
| 186 | +- [Gin](https://github.com/gin-gonic/gin) |
| 187 | +- [Gin Web Framework](https://gin-gonic.github.io/gin/) |
| 188 | +- Go并发编程实战 |
| 189 | +- [govendor](https://github.com/kardianos/govendor) |
| 190 | + |
| 191 | + |
| 192 | + |
0 commit comments