微信公众号:Nginx源码分析
关注可了解更多的Nginx
知识。任何问题或建议,请公众号留言;
关注公众号,有趣有内涵的文章第一时间送达!
回顾
前面我们介绍了nginx
的很多脚本,比如测试操作系统是否支持某个特性的auto/feature
脚本,测试类型变量长度的auto/types/sizeof
脚本等等。
有时候大家可能会问,nginx
为什么搞这么多脚本呢?
其实答案很简单:
①.
为了保证nginx
的可移植性。
②.
为编译nginx
源码做准备。
那么本文我们就分析一下和编译器相关的脚本。
写在前面
本文简单的分析一下和编译器相关的脚本。
这一部分内容对于分析nginx
自动化配置流程以及分析源码来说,几乎没有什么用处。但是为了保证本系列文章的连贯性和完整性,我还是尽最大的努力分析这部分内容。但是由于本人对编译相关的内容也不是很了解,如有错误,请联系我,我会第一时间修正。
auto/cc 脚本
该目录下的脚本用于设置编译器相关的参数。
不同的操作系统都有自己的特有的编译器,它们的设置可能有细微的差别。所以nginx
自动根据操作系统和编译器种类,设置符合该平台的参数。
设置编译器种类
nginx
使用CC
变量保存所用的编译器名称。在auto/options
中对该变量进行了赋值。
CC=${CC:-gcc}
所以CC
的默认值是gcc
。
我们可以在执行configre
脚本的时候通过指定--with-cc=*)
的方式来自由的设置所使用的编译器,默认情况下,我们都不会改变这个值。在linux
下该值为gcc
。
auto/cc/name 设置编译器名称
在auto/cc/conf
脚本中,会首先调用auto/cc/name
。这个脚本并不复杂,它的作用就是根据我们在configure
时选择的编译器,从而设置编译器的名称。
查找编译器
auto/cc/name
一开始就调用了一大段脚本,如下:
if [ "$NGX_PLATFORM" != win32 ]; then
ngx_feature="C compiler"
ngx_feature_name=
ngx_feature_run=yes
ngx_feature_incs=
ngx_feature_path=
ngx_feature_libs=
ngx_feature_test=
. auto/feature
if [ $ngx_found = no ]; then
echo
echo $0: error: C compiler $CC is not found
echo
exit 1
fi
fi
这段脚本看起来吓人,其实,它的功能非常简单。
我们前面介绍过auto/feature
的执行过程,所以上面的代码就是编译如下的自动测试程序:
#include <sys/types.h>
#include <unistd.h>
#include <sys/epoll.h>
int main() {
return 0;
}
这段代码其实啥功能都木有,所以它就是测试一下能不能找到我们选择的编译器。因为只要编译器能正常工作,那么上面的c
代码就可以编译成功。
判断编译器的名称
因为我们选择的编译器是gcc
,所以剩下的脚本执行的应该是如下的部分:
if [ "$CC" = cl ]; then
#
else
# 因为我们选择的是gcc
# 所以执行else部分
fi
观察一下else
部分的代码:
其实就是根据gcc -v
的内容判断具体的编译器名称。
下面的内容是在我的本机上面执行gcc -v
的输出内容:
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/usr/libexec/gcc/x86_64-redhat-linux/4.8.5/lto-wrapper
Target: x86_64-redhat-linux
Configured with: ../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=http://bugzilla.redhat.com/bugzilla --enable-bootstrap --enable-shared --enable-threads=posix --enable-checking=release --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-gnu-unique-object --enable-linker-build-id --with-linker-hash-style=gnu --enable-languages=c,c++,objc,obj-c++,java,fortran,ada,go,lto --enable-plugin --enable-initfini-array --disable-libgcj --with-isl=/builddir/build/BUILD/gcc-4.8.5-20150702/obj-x86_64-redhat-linux/isl-install --with-cloog=/builddir/build/BUILD/gcc-4.8.5-20150702/obj-x86_64-redhat-linux/cloog-install --enable-gnu-indirect-function --with-tune=generic --with-arch_32=x86-64 --build=x86_64-redhat-linux
Thread model: posix
gcc version 4.8.5 20150623 (Red Hat 4.8.5-28) (GCC)
所以对于我自己的电脑来说,会指向下面的代码:
NGX_CC_NAME=gcc
echo " + using GNU C compiler"
对于大多数linux
系统,应该都是执行上面的代码,会把NGX_CC_NAME
变量的值设置为gcc
。
即使你的电脑上不是这样的,那么也没关系,这部分内容并不影响我们后面的源码分析。
auto/cc/conf
初始化变量
该脚本的第一步是初始化一些变量,用于后面的编译选项,如ngx_include_opt
变量表示编译时引入头文件的选项等。
调用 auto/cc/name 脚本
上面已经分析过这个脚本。主要功能就是根据cc
变量设置NGX_CC_NAME
的值。
执行特定编译器测试脚本
根据在auto/cc/name
中获取到的NGX_CC_NAME
变量,执行特定的脚本,比如对于我的机器来说,由于选择的编译器是gcc
,所以执行 auto/cc/gcc
脚本。
编译器的feature测试
进行一些编译器的feature
性能测试。
比如测试编译器是否支持宏,是否支持inline
等。
auto/cc/gcc 脚本
该脚本完成gcc
编译器的特定初始化操作。
脚本的内容非常简单,利用了前面分析过的许多脚本,大家可以自己看一下。
总结
我们在本文中分析了nginx
中编译器相关的脚本,这部分内容对于我们分析源代码没有什么关系。只是为了保证内容上的连续性。如果又不懂的地方也没关系,let it go
。
后面的文章我们会接着分析nginx
的源码,敬请期待。顺便关注我的个公众号(Nginx源码分析
)。
喜欢本文的朋友们,欢迎长按下图关注订阅号Nginx源码分析,更多精彩内容第一时间送达