与OS X Mavericks的Apache2 mod_jk段错误

时间:2013-10-23 15:44:36

标签: macos apache apache2 mod-jk osx-mavericks

我昨天升级到了Mavericks,并且不得不为我的开发环境重新安装mod_jk。从源代码编译它有点痛苦。我在{X}上发现this page关于OS X上的mod_jk,但是还有一些额外的箍我不得不跳过。出于某种原因,apxs认为gcc生活在:

/Applications/Xcode.app/Contents/Developer/Toolchains/OSX10.9.xctoolchain/usr/bin/cc

但确切的文件夹不存在;我不得不对现有的XcodeDefault.xctoolchain目录进行符号链接:

sudo ln -s XcodeDefault.xctoolchain/ OSX10.9.xctoolchain

然后我尝试运行configure:

./configure CFLAGS='-arch x86_64' APXSLDFLAGS='-arch x86_64' --with-apxs=/usr/sbin/apxs

但是,配置失败,因为它找不到<stdio.h>,所以我将OS X 10.9工具链符号链接为:

sudo ln -s /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.9.sdk/usr/include/ /usr/include

然后我可以通过在apache-2.0子目录中运行sudo make install -f Makefile.apxs来编译和安装模块。但是,当我通过sudo apachectl start启动Apache时,会立即崩溃并发生段错误:

Thread 0 Crashed:: Dispatch queue: com.apple.main-thread
0   libsystem_kernel.dylib              0x00007fff875fb866 __pthread_kill + 10
1   libsystem_pthread.dylib             0x00007fff8b8a435c pthread_kill + 92
2   libsystem_c.dylib                   0x00007fff92480bba abort + 125
3   libsystem_c.dylib                   0x00007fff92480d31 abort_report_np + 181
4   libsystem_c.dylib                   0x00007fff924a48c5 __chk_fail + 48
5   libsystem_c.dylib                   0x00007fff924a48d5 __chk_fail_overlap + 16
6   libsystem_c.dylib                   0x00007fff924a4906 __chk_overlap + 49
7   libsystem_c.dylib                   0x00007fff924a4ad1 __strcpy_chk + 64
8   mod_jk.so                           0x0000000105a0c631 jk_map_get_int + 225
9   mod_jk.so                           0x0000000105a1f7f1 jk_get_worker_maintain_time + 33
10  mod_jk.so                           0x0000000105a17683 wc_open + 755
11  mod_jk.so                           0x0000000105a2f13f init_jk + 1151
12  mod_jk.so                           0x0000000105a28b7e jk_post_config + 1566
13  httpd                               0x000000010568b7d5 ap_run_post_config + 133
14  httpd                               0x00000001056947c7 main + 2567
15  libdyld.dylib                       0x00007fff9176e5fd start + 1

有人在小牛队中成功编译/运行mod_jk吗?有什么东西我缺少或做得不对吗?

3 个答案:

答案 0 :(得分:2)

前面提到的bug reported against Tomcat有一个拟议的补丁,可能很快就会应用。随意使用该bug中描述的任何补丁 - 它们都可以工作。

答案 1 :(得分:2)

从tomcat.apache.org/download-connectors.cgi

下载最新的Tomcat Connectors源代码

https://issues.apache.org/bugzilla/show_bug.cgi?id=55696 将./native/common/jk_maps.c中的以下方法更改为您在此处看到的内容:

int jk_map_get_int(jk_map_t *m, const char *name, int def)
 {
     const char *rc;
     int int_res;

    rc = jk_map_get_string(m, name, NULL);

    if(NULL == rc) {
        int_res = def;
    } else {
        size_t len = strlen(rc);
        int multit = 1;

        if (len) {
            char buf[100];
            char *lastchar;
             strncpy(buf, rc, 100);
            lastchar = buf + len - 1;
            if ('m' == *lastchar || 'M' == *lastchar) {
                *lastchar = '\0';
                multit = 1024 * 1024;
            }
            else if ('k' == *lastchar || 'K' == *lastchar) {
                *lastchar = '\0';
                multit = 1024;
            }
            int_res = multit * atoi(buf);
        }
        else
            int_res = def;
     }
    return int_res;
 }

安装命令行工具

xcode-select --install

创建缺少的符号链接

sudo ln -s /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain /Applications/Xcode.app/Contents/Developer/Toolchains/OSX10.9.xctoolchain

cd ./native

./ configure CFLAGS =' - arch x86_64'APXSLDFLAGS =' - arch x86_64' - with-apxs = / usr / sbin / apxs

chmod 755 scripts / build / instdso.sh

sudo make install

答案 2 :(得分:1)

替代方案 - 不是解决方案

我遇到了同样的事情,无法让 mod_jk 在Apache内部运行。

作为一种替代方法,只需让它在本地工作并继续前进,我改变了一些apache指令,改为使用 mod_proxy_ajp

LoadModule proxy_module libexec/apache2/mod_proxy.so
LoadModule proxy_ajp_module libexec/apache2/mod_proxy_ajp.so

ProxyPassMatch ^(/.*\.(jsp|json))$ ajp://localhost:8009/$1
ProxyPass /aircharge ajp://localhost:8009/aircharge
...

由于仍在使用AJP协议,因此可以使用相同的Tomcat连接器而无需修改。