Skip to content

Commit aa1f377

Browse files
committed
初始化 golang gin 文章系列
1 parent 08c3c17 commit aa1f377

16 files changed

+5429
-0
lines changed

.gitignore

+2
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
.idea/
2+
.DS_Store

README.md

+6
Original file line numberDiff line numberDiff line change
@@ -1 +1,7 @@
11
# blog
2+
3+
## Golang
4+
5+
### Gin
6+
7+
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,192 @@
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

Comments
 (0)