聊聊、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开头 ...
随机推荐
- bt5r3开启远程登录
sshd-generate /etc/init.d/ssh restart
- java控制远程ssh-expect4j(一)
github : https://github.com/wengyingjian/ssh-java-demo.git 程序写完后,ssh连接到远程服务器上需要做的步骤都是固定的,所以我们可以通过程序来 ...
- SQL Server Sleeping会话占用内存资源浅析?
在SQL Server中,会话的状态有运行(Running).睡眠(Sleeping).休眠(Dormant).Preconnect 等状态,有时候你会在数据库中看到很多会话处于睡眠(Sleepi ...
- 前端APP打包管理规范
1.包命名规范1)说明打包人:姓名拼音首字母小写 dev:开发环境 test:测试环境 pre:预发布环境 prod:正式环境 例如:版本号:1.2.3,说明:第一个数字大版本:变更框架.调整结构时变 ...
- thisnkphp添加二维码
Rcode二维码生成类QRcode.class.php实例演示 <?php //import('@.Org.QRcode');//thinkphp include_once('QRcode.cl ...
- 报bug
在打印输出seg的gt数据的时候,出现了gt数据突然很大突然很小的情况,一般这种都是访问了其他内存
- python之道08
1.有如下文件,a1.txt,里面的内容为: 某某是最好的学校, 全心全意为学生服务, 只为学生未来,不为牟利. 我说的都是真的.哈哈 分别完成以下的功能: a,将原文件全部读出来并打印. 答案 f ...
- 《队长说得队》【Alpha】Scrum meeting 1
项目 内容 这个作业属于哪个课程 >>2016级计算机科学与工程学院软件工程(西北师范大学) 这个作业的要求在哪里 >>实验十二 团队作业8:软件测试与ALPHA冲刺 团队名称 ...
- Python——序列封包与序列解包
一.序列封包与序列解包 把多个值赋给一个变量时,Python会自动的把多个值封装成元组,称为序列封包. 把一个序列(列表.元组.字符串等)直接赋给多个变量,此时会把序列中的各个元素依次赋值给每个变量, ...
- OC和C++的区别
C++语言特点: 1.在C语言的基础上进行扩充和完善,使C++兼容了C语言的面向过程特点,又成为了一种面向对象的程序设计语言: 2.可以使用抽象数据类型进行基于对象的编程: 3.可以使用多继承.多态进 ...