Makefile简介
就像dockerfile之于docker,makefile之于make.....
make命令执行时,需要一个makefile文件,以告诉make命令需要怎么样的去编译和链接程序。
你在命令行敲一个make,会自动去寻找目录下的makefile文件并执行。
可能你在C程序中见到的比较多,但是其实其他语言也是可以用到。
makefile内部是你根据makefile语法规则,自己编写的一条条shell命令等。
target
可以是一个object file(目标文件),也可以是一个执行文件,还可以是一个标签(label)。对于标签这种特性,在后续的“伪目标”章节中会有叙述。
prerequisites
生成该target所依赖的文件和/或target,没有就不需要写
command
该target要执行的命令(任意的shell命令)
下面我们看一个在 golang 中的应用例子
这里执行的任务就是本地编译,把得到的二进制可执行文件用upx压缩之后通过rsync传到服务器,
然后重启服务器的supervisor使程序重启,最后删除本地生成的可执行文件。
这一系列的任务,在makefile编写完成之后,只需要执行一句
make test
就可以完成一系列任务,非常方便。
这里需要注意的几个地方:
.PHONY
.PHONY: build clean tool lint help
其作用是声明 build / clean / tool / lint / help 为伪目标,声明为伪目标会怎么样呢?
声明为伪目标后:在执行对应的命令时,make 就不会去检查是否存在 build / clean / tool / lint / help 其对应的文件,而是每次都会运行标签对应的命令
若不声明:恰好存在对应的文件,则 make 将会认为 xx 文件已存在,没有重新构建的必要了
@
如果你执行 make 会发现,makefile中的每条命令都被打印到shell标准输出中,为什么?
因为make默认就是这么设置的,默认先打印每条命令再执行,这叫 echo
在命令前加@作用就是不让你这条命令打印到标准输出。