怎么配置golang项目module模块?
image.png
为什么要配置模块?
我们需要在app.go
文件中调用b.go
中的函数,甚至需要调用modules/
文件夹中所有.go文件的函数,这时候b.go
或者整个modules
文件夹都应该改作为模块进行编写,类似golang内置模块那样可以直接import
导入到a.go
中使用。
当然,app.go
本身也应该被视为模块,它可以作为main
主入口模块。
image使用命令行
go env GO111MODULE
检查你的golang配置是否已经打开模块开发模式,如果返回on
或auto
都可以继续。否则的话请执行go env -w GO111MODULE="on"
命令打开模块开发模式。
文件结构
如上图所示,每个模块都应该有一个文件夹放置单个或多个.go
文件。而调用模块app/
和被调用模块b/,modules/
之间并没有必然的层次关系。
每个模块下都应该有个go.mod
文件,你需要在命令行中用cd app
这样的命令进入到每个模块文件夹,然后执行go mod init app
或者go mod init b
,go mod init modules
来自动生成。
实现模块引用
用go mod init ...
只是把每个模块进行单独生成,如果我们要在app.go
中调用其他模块,那么就还要在app/
文件夹下的go.mod
中用replace
说明要调用的模块的位置,方法是直接添加代码,添加之后它看起来像下面这样(最后一行是新加的):
module app
go 1.15
replace abc.com/b => ../b
注意这里的abc.com只要和app.go中import的内容一致就行,可以是任意网址。
箭头后的是b/文件夹的实际目录,../
表示上一层,也就是说app/
文件夹和b/
文件夹是在同一层次的。如果b/
在app/
下面,那么就不是双点而是replace abc.com/b => ./b
。
被调用的函数
在b.go
和c.go
中的函数名称要大写才能被调用,func Hello()...
是可以的,func hello()...
就不行。
另外也要注意b.go
中第一行是package b
,而c.go
属于modules/
模块所以第一行是package modules
。
实战案例:创建web服务器
我们需要创建一个服务器程序app.go
,它能够提供网页文件服务,也能够对类似.../api/Ksave
这样的API接口请求作出回应。
因为API接口可能会有很多,所以我建了一个api/
文件夹,这样可以分别把每个接口写成一个.go
文件进行管理,而在app.go
就可以使用api.Ksave
来调用。
这个文件目录是怎样创造的?先创建app/
文件夹,然后下面创建app.go
文件和api/
文件夹,然后api/
文件夹下创建ksave.go
。两个go.mod
是使用命令生成的,先在终端用cd
命令进入对应的文件夹,然后go mod init app
和go mod init api
就会生成go.mod
了。
web
文件夹是用来放网页文件的,里面手工创建index.html
写入<h1>Hello!!</h1>
即可。
然后修改app/
下面的go.mod
,内容如下:
module app
go 1.15
replace ksite.10knet.com/api => ./api
接下来就是编码了。下面是app.go
的完整代码:
package main
import (
"fmt"
"log"
"net/http"
"os"
"path"
"strconv"
"ksite.10knet.com/api"
)
func main() {
//获取当前程序运行的目录
dir, _ := os.Getwd()
webDir := path.Join(dir, "../web")
//设置文件服务
http.Handle("/", http.FileServer(http.Dir(webDir)))
//设置API接口
http.HandleFunc("/api/Ksave", api.Ksave)
//启动服务
port := 80
fmt.Println("Server is running on port " + strconv.Itoa(port) + " ...")
log.Fatal(http.ListenAndServe(":"+strconv.Itoa(port), nil))
}
下面是ksave.go
的完整代码:
package api
import "net/http"
// Ksave 只是返回一个问候语.
func Ksave(w http.ResponseWriter, r *http.Request) {
w.Write([]byte("Hello Ksave!"))
return
}
最后,用cd
命令进入到app/
文件夹下,执行go run app.go
就可以把服务运行起来,打开首页http://localhost
和接口测试页http://localhost/api/Ksave
就可以看到问候了。
注意!每次运行前要用
Ctrl+C
快捷键关闭当前程序,否则可能导致失败,重启电脑才能解决。
我们也可以执行go build app.go
可以得到如上面文件列表中所示的app
程序,然后执行./app
就能运行起来。同样注意关闭。
欢迎批评指正,交流学习。
网友评论