nginx学习- 开篇,搭建调试环境

今天开始nginx的学习,Mark一下。争取能在一个月入门个皮毛,对于nginx的打算,主要是学习其各种应用场景和配置,下好源码只是为了配合理解。

搭建调试环境

首先还是搭个调试环境,下好了nginx代码以后,查看目录。

localhost:nginx-master jjchen$ tree -L 1
.
├── Makefile
├── auto
├── conf
├── contrib
├── docs
├── misc
├── objs
└── src

直接编译

bash auto/configure

make

程序就编译好了,可执行程序生成在objs/nginx。

代码在src中,我们用ide将代码导入,我这里是xcode。此处直接导入代码,没有处理编译错误,不能直接debug运行了,我们直接用附加程序的方式来调试。注意先附加到进程,后启动程序。

进入objs目录,启动nginx程序,这里用了root权限,不然一些日志文件创建不了。

sudo ./nginx -c ../conf/ngin.conf 

开始跟踪代码。--- 发现了大问题,debug的堆栈信息好像不准,而且IDE内函数不能跳转。。
看来不能偷懒了,还是回到开头,修改配置,修改代码让IDE能直接Debug起来;整个过程花了我两个多小时。记录一下避免后人踩坑。

有几个步骤。

1.加入头文件路径,这个在makefile文件可以找到。

    -I src/core \
    -I src/event \
    -I src/event/modules \
    -I src/os/unix \
    -I objs \
    -I src/http \
    -I src/http/modules

2.1 直接删掉其他平台的代码,比如win,linux非macos部分。

2.2 删掉其他makefile文件中没有的.c、.cpp文件。这个还是写个程序来做吧,如下。

import java.io.*;
import java.nio.CharBuffer;
import java.util.*;

public class FilterCppsInMakefile {

    private static String srcRoot = "/Users/jjchen/cpro/nginx-test/src";
    private static String MakefilePath = "/Users/jjchen/cpro/nginx-master/objs/Makefile";
    private static Map<String,String> cppFiles = new HashMap<>();

    public static void GetCppFiles(String dirPath){
        File dir = new File(dirPath);
        if (!dir.isDirectory()){
            throw new RuntimeException("can not read path: "+dirPath);
        }

        File []srcs = dir.listFiles(new FileFilter() {
            @Override
            public boolean accept(File pathname) {
                if (pathname.isDirectory()){
                    GetCppFiles(pathname.getPath());
                    return false;
                }
                return pathname.getName().endsWith(".c")||pathname.getName().endsWith(".cpp");
            }
        });
        for (File src: srcs){
            cppFiles.put(src.getName().replace(".c","").replace(".cpp",""),src.getAbsolutePath());
        }
    }
    public static String read (String filePath)throws Exception{
        Reader reader = new BufferedReader(new FileReader(filePath));
        StringBuilder stringBuilder = new StringBuilder();

        String part = "";
        while((part =((BufferedReader) reader).readLine())!= null){
            stringBuilder.append(part);
        }
        return stringBuilder.toString();


    }
    public  static void deleteSrcFiles(List<String>fileList){
        for(String fileName : fileList) {

            for (int i=0; i<2;i++){
                File file = new File(fileName);
                if (!file.exists()) {
                    continue;
                } else {
                    if (file.isFile())
                        file.delete();
                }
                //同时删除头文件
                fileName = fileName.replace(".cpp",".h").replace(".c",".h");
            }

        }


    }

    public static void main(String[] args) {
        GetCppFiles(srcRoot);
        String content = "";
        try {
            content = read(MakefilePath);
        } catch (Exception e) {
            e.printStackTrace();
            return;
        }
        System.out.println(cppFiles.toString());
        List<String> delList= new ArrayList<>();
        Iterator<HashMap.Entry<String,String>> iterator = cppFiles.entrySet().iterator();
        while (iterator.hasNext()){
            HashMap.Entry<String,String> node = iterator.next();
            if(!content.contains(node.getKey())){
                delList.add(node.getValue());
            }
        }
        System.out.println(cppFiles.size());
        System.out.println(Arrays.toString(delList.toArray()));
        deleteSrcFiles(delList);




    }
}

  1. 导入正则的库,我本地的头文件 /usr/local/Cellar/pcre/8.41/include/,静态库libpre.a;

  2. 执行完make以后,将objs文件夹下的ngx_modules.c文件和两个头文件拷入代码。

做完这些就可以正常启动了。去掉空的文件夹只剩下如下的模块。

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,919评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,567评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,316评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,294评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,318评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,245评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,120评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,964评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,376评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,592评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,764评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,460评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,070评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,697评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,846评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,819评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,665评论 2 354