聊聊、Nginx GDB与MAIN
上一篇文章主要介绍了 Nginx 在 Window 和 Linux 平台上的安装。本章节主要介绍 Nginx 源码学习方法和源码结构,以及 Nginx 启动时 main 方法的位置,参数信息。后面的章节主要是 Linux 平台,你要问为何是 Linux,而不是 Window。我只能说 Nginx 是基于 Linux 平台开发出来的,我也习惯了 Linux 平台开发。
上一篇文章我讲了安装,现在打开 MobaXterm ,连接上 Nginx 服务器。输入 whereis nginx 命令查看安装目录:
是的我的安装目录在 /usr/local/nginx。
现在我们进入这个目录,看看里面有哪些文件。
暂时先不管这些文件是做啥用的,像 fastcgi_temp,proxy_temp , scgi_temp ,uwsgi_temp 这些模块都是可配的,以后咱们再详细的讲解。
大家有没有看到 sbin 文件,对的,这里面就是我们启动 Nginx 的地方。
先进入看看有啥:
有两个文件,一个 nginx ,一个 nginx.old 。old 文件是之前为了平滑升级所备份的 nginx 文件。我们启动只需要nginx 就行了。
ok,我们启动 Nginx 。输入 ./nginx 就行了。
怎么知道启动成功没有呢?输入 ps -ef|grep nginx 。
我们看到了一个 nginx: master process 主线程,一个 nginx: worker process 工作线程,这个工作线程多少是可配的,跟服务器内核数量有关。ok,如果你看到这两个线程,说明Nginx已经启动。为了进一步验证,我们访问http://localhost 页面,默认 80 端口。输入 curl http://localhost。
已经访问到相关欢迎页面了,默认 html 文件里面 index.html 。 ok,到这里我们 Nginx 已经正常启动。
接下来,我们通过 gdb 调试工具找到 Nginx 启动时的 main 方法在哪。
还是在 sbin 目录下,我们输入 gdb nginx 命令。
gdb 调试工具是 Linux 自带的,对于调试代码非常的方便,具体 gdb 信息大家可以上网看看。 ok,接下来输入 b main。
好的,看到了一行信息,file src/core/nginx.c line 198。
也就是在 nginx.c 文件的 198 行,这个地方就是 main 方法开始地方。不同的 Nginx 版本这个 main 方法所在的行也有不一样,大家根据自己的信息来找就行了。
怎么找呢?
学习源码确实需要方法,不然会很乱,也很累。上一章讲安装,Nginx 网上下载的安装包我放在了 /usr/local/src/nginx包里面。我们去看看。
我下载的版本是1.10.2
左边的 nginx-1.10.2 包是解压后并且编译过的,将这个包拷贝到 Win 系统,放你自己计划的目录就行。我放在 G:\学习日记\nginx\nginx-1.10.2。
ok,我们来找 src/core/nginx.c line 198,进入 G:\学习日记\nginx\nginx-1.10.2,你们按照自己的来,找到nginx.c 的198行。
ok,我们找到了 main 方法,接下来的文章我将讲解 main 方法,到底 Nginx 启动的时候做了什么事情,关于 main 方法里面的代码,大家可以自己先看看。谢谢大家观看!
聊聊、Nginx GDB与MAIN的更多相关文章
- 聊聊、Nginx GDB与MAIN参数
接着上一篇,我们学习 Nginx 的 main 方法.用 gdb 工具调试 Nginx,首先 gdb nginx.如下: gdb 调试工具有很多的命令,上一篇为了找 main 方法用了 b 命令,也就 ...
- gdb 调试main
gdb 调试main带参数 gdb program start a b c//参数为a b c然后从main函数开始 r a b c//参数为a b c来运行程序
- 利用 gdb 探究main(int argc, char *argv[]){} 中的char *argv[]
在 Linux 系统中编写小程序 代码如下 编译并采用gdb调试 在调试之前设置三个参数 a bb ccc 输入 start 执行代码到 return 0; 从这里可以看到 argc = ...
- 聊聊 Nginx 的反向代理
背景 最近在优化服务基础设施这块,正好有时间写一下Nginx的体会.相信大家都听说过反向代理,一提到反向代理一定会想到Nginx.什么你没听过Nginx?那么你一定听说过Apache吧!Apache是 ...
- 从压测碰到的诡异断连问题聊聊Nginx的连接管理
本文主要分享一个在压测Nginx反向代理服务过程中碰到的连接异常断开问题,包括问题的定位与复现,最后由这个实际问题引申聊一下Nginx的连接管理. 本博客已迁移至CatBro's Blog,那是我自己 ...
- 聊聊、Nginx 初始化错误信息
这篇文章我们继续学习 main 方法,我们先来看看 ngx_debug_init() 这个方法. 从方法名我们也知道,debug初始化.我们先看看方法位置在哪.我们来断点在这个方法上面. Functi ...
- Nginx代码调试——gdb工具
参考网上的资料,写了一个configprint模块,其功能为打印输出location配置内容,并计数访问次数. 代码链接如下:https://github.com/PaulWeiHan/nginx_m ...
- 菜鸟nginx源码剖析 框架篇(一) 从main函数看nginx启动流程(转)
俗话说的好,牵牛要牵牛鼻子 驾车顶牛,处理复杂的东西,只要抓住重点,才能理清脉络,不至于深陷其中,不能自拔.对复杂的nginx而言,main函数就是“牛之鼻”,只要能理清main函数,就一定能理解其中 ...
- unknown log format "main" in /nginx/conf/nginx.conf
vi /nginx/conf/nginx.conf找到http{ }模块中的 log_format去掉注释,或是log_format写到了别处. 解决方法: 将log_format 写到http开头 ...
随机推荐
- PADS 9.5封装向导 多一个管脚
使用PADS 9.5封装向导(Decal Wizard)建立封装(Decals) 时遇到封装的中间多了一个管脚,如图红圈位置,通过一番搜寻,才知道这是热焊盘,不需要就在右边的红圈处去掉勾选热焊盘即可.
- hadoop的shell总结
ls命令(文件内容) 列出系统跟目录下的目录和文件 Hadoop fs -ls / 列出文件系统所有的目录和文件 Hadoop fs -ls -R / cat命令(列出文档内容) Hadoop fs ...
- LibreOJ #514. 「LibreOJ β Round #2」模拟只会猜题意
内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 题目描述 给定一个长度为 nnn 的序列 AAA . 定义 f(l,r)=∑i=lrAif(l,r ...
- Java 原型模式(克隆模式)
Java 的设计模式有 23 种,前段时间小编已经介绍了单例模式,由于我们在学习 Spring 的时候在 bean 标签的学习中碰到了今天要讲的原型模式,那么小编就已本文来介绍下原型模式. 原型模 ...
- Distinct Values(贪心)
问题 D: Distinct Values 时间限制: 1 Sec 内存限制: 128 MB提交: 13 解决: 5[提交] [状态] [讨论版] [命题人:admin] 题目描述 Chiaki ...
- ios基础学习
action中调用函数方法别忘了冒号1. 各个视图之间的关系要分辨清楚 2. MVC (Model-View-Controller). In this pattern, models keep tra ...
- Bootstrap历练实例:带表格的面板
带表格的面板 为了在面板中创建一个无边框的表格,我们可以在面板中使用 class .table.假设有个 <div> 包含 .panel-body,我们可以向表格的顶部添加额外的边框用来分 ...
- 01_1_jdom调用xml文件
01_1_jdom调用xml文件 1. 导入jdom.jar包 2. xml文件内容 test.xml <?xml version="1.0" encoding=" ...
- Swift开发中 JSON对象/JSON字符串/Data的互转
本文将介绍Swift开发中常用的转换(JSON对象/JSON字符串/Data之间的互相转换) #pragma mark - JSON(对象)----->JSON字符串 1.原生方法 //JSON ...
- javascript原生方法集锦
1.sort方法sort()方法使数组中的元素按照一定的顺序排列. 语法: arrayObject.sort(方法函数) 参数说明: 1.如果不指定<方法函数>,则按unicode码顺序排 ...