-
Notifications
You must be signed in to change notification settings - Fork 768
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
启动时报错!!! #27
Comments
因为 --without-http_rewrite_module 了,所以set指令不生效 |
这是redis的unix socket On Mon, May 23, 2016 at 2:33 PM, niuhp [email protected] wrote:
黄振栋 |
现在就剩这个了,访问8030端口提示ngx_http_lua_ffi_semaphore_new未定义,, |
请问你的luajit用的是哪个版本的,LuaJIT-2.1可以在openresty软件包中获得 On Mon, May 23, 2016 at 2:54 PM, niuhp [email protected] wrote:
|
是2.1.0啊 |
没有遇到过你的错误,用openresty软件包中维护的LuaJIT看看呢? On Mon, May 23, 2016 at 3:28 PM, niuhp [email protected] wrote:
|
@niuhp 访问8030端口提示ngx_http_lua_ffi_semaphore_new未定义 |
你好,这个是ngx_lua比较新的版本中带有的 resty.semaphore模块,请确定ngx_lua版本包含该模块 On Sun, Jun 19, 2016 at 2:42 PM, noodles-v6 [email protected]
|
我用的openresty 最新版本, luajit2.1.0beta2, 也是同样的问题 |
请问是哪个问题? On Thu, Jul 28, 2016 at 11:03 AM, 郭华伟 [email protected] wrote:
|
lua entry thread aborted: runtime error: ../lib/lua-resty-core/lib/ngx/semaphore.lua:64: /usr/local/lib/libluajit-5.1.so.2: undefined symbol: ngx_http_lua_ffi_semaphore_new 反复测试了好几遍,始终如此 |
你好,这个问题是api的更新,曾经也出现过这样的问题中已经解决了, 但是出现这个问题的原因是我版本中的lua-resty-lib没有更新到最新版,仍然使用了ngx_http_lua_ffi_semaphore_new,而新版已经是ngx_http_lua_ffi_sema_new了,这点我很抱歉。之所以一直没有发现,原因是我开发时采用的是tengine+luajit+lua-resty-lib,我当时的ngx_lua版本和lua-resty-lib契合,所以没有报错;当我采用新版openresty时没有进行深入测试,非常抱歉,我正在修复和测试 但是你的问题在于,使用了非openresty维护的luajit版本,openresty维护的LuaJIT是2.1版本以上了,会有与ngx有关的更新,而你是从官方下载的LuaJIT,编译是不会通过的 checking for LuaJIT library in /home/huang/workspace/oss/LuaJIT-2.1.0-beta2/lib and /home/huang/workspace/oss/LuaJIT-2.1.0-beta2/include/luajit-2.1 (specified by the LUAJIT_LIB and LUAJIT_INC env, with -ldl) ... not found
checking for LuaJIT library in /home/huang/workspace/oss/LuaJIT-2.1.0-beta2/lib and /home/huang/workspace/oss/LuaJIT-2.1.0-beta2/include/luajit-2.1 (specified by the LUAJIT_LIB and LUAJIT_INC env) ... not found
./configure: error: ngx_http_lua_module requires the Lua or LuaJIT library and LUAJIT_LIB is defined as /home/huang/workspace/oss/LuaJIT-2.1.0-beta2/lib and LUAJIT_INC (path for lua.h) /home/huang/workspace/oss/LuaJIT-2.1.0-beta2/include/luajit-2.1, but we cannot find LuaJIT there.
|
经过测试,我换用 lua-resty-core的v0.1.6 tag可以正常使用,目前该项目的master分支是v0.1.7rc+了,我不知道如何指定tag作为git项目的sub module,所以我将所需lua-resty-core手动放到我的项目里,然后在README中指明。 非常感谢你的反馈,欢迎使用 |
经过对openresty各版本的比对,我发现api ngx_http_lua_ffi_sema_new的引入是从当前最新版本openresty-1.9.15.1开始的,所以没有发现,看来我的锅轻一点了 :) 解决这个问题的终极办法是,如果想用semaphore的话,每次使用lua-resty-core的时候,需要将lua-resty-core/lib/ngx 和 lua-resty-core/lib/resty 的版本与openresty保持一直,简单粗暴的方法就是,从/usr/local/oprensty/lualib中将ngx和resty目录 copy 到ABTestingGateway的lib/lua-resty-core目录下替换; 解决这个问题的终极办法是,如果想用semaphore的话,每次使用lua-resty-core的时候,需要将lua-resty-core/lib/ngx 和 lua-resty-core/lib/resty 的版本与openresty保持一直,简单粗暴的方法就是,从/usr/local/oprensty/lualib中将ngx和resty目录 copy 到ABTestingGateway的lib/lua-resty-core目录下替换; 我之所以没有将lua_package_path中的路径直接指定到openresty的路径下,原因是1、我们使用的tengine,所以lua-resty-core等lib需要从目录外指定;2、运维人员应该拥有自己指定lib路径的权力。 这样的话,我仍然将本repo中的lib-resty-core保持原状,然后在readme中说明吧。 |
运行时日志报错,index变量错误是什么原因呢: |
执行tengine-2.1.2/objs/nginx -p
pwd
-c conf/nginx.conf时报错nginx: [emerg] unknown directive "set" in /path/to/ABTestingGateway-master/utils/conf/default.conf:22
tengine信息如下
/root/soft/tengine-2.1.2/objs/nginx -V
Tengine version: Tengine/2.1.2 (nginx/1.6.2)
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-16) (GCC)
TLS SNI support enabled
configure arguments: --with-ld-opt=-Wl,-rpath,/usr/local/web/LuaJIT-2.0.1/lib --with-luajit-inc=/usr/local/web/LuaJIT-2.0.1/include/luajit-2.0 --with-luajit-lib=/usr/local/web/LuaJIT-2.0.1/lib --without-http_rewrite_module --add-module=../lua-nginx-module-0.10.4
loaded modules:
ngx_core_module (static)
ngx_errlog_module (static)
ngx_conf_module (static)
ngx_dso_module (static)
ngx_syslog_module (static)
ngx_events_module (static)
ngx_event_core_module (static)
ngx_epoll_module (static)
ngx_procs_module (static)
ngx_proc_core_module (static)
ngx_openssl_module (static)
ngx_http_module (static)
ngx_http_core_module (static)
ngx_http_log_module (static)
ngx_http_upstream_module (static)
ngx_http_static_module (static)
ngx_http_autoindex_module (static)
ngx_http_index_module (static)
ngx_http_auth_basic_module (static)
ngx_http_access_module (static)
ngx_http_limit_conn_module (static)
ngx_http_limit_req_module (static)
ngx_http_geo_module (static)
ngx_http_map_module (static)
ngx_http_split_clients_module (static)
ngx_http_referer_module (static)
ngx_http_ssl_module (static)
ngx_http_proxy_module (static)
ngx_http_fastcgi_module (static)
ngx_http_uwsgi_module (static)
ngx_http_scgi_module (static)
ngx_http_memcached_module (static)
ngx_http_empty_gif_module (static)
ngx_http_browser_module (static)
ngx_http_user_agent_module (static)
ngx_http_upstream_ip_hash_module (static)
ngx_http_upstream_consistent_hash_module (static)
ngx_http_upstream_check_module (static)
ngx_http_upstream_least_conn_module (static)
ngx_http_upstream_keepalive_module (static)
ngx_http_upstream_dynamic_module (static)
ngx_http_stub_status_module (static)
ngx_http_write_filter_module (static)
ngx_http_header_filter_module (static)
ngx_http_chunked_filter_module (static)
ngx_http_range_header_filter_module (static)
ngx_http_gzip_filter_module (static)
ngx_http_postpone_filter_module (static)
ngx_http_ssi_filter_module (static)
ngx_http_charset_filter_module (static)
ngx_http_userid_filter_module (static)
ngx_http_footer_filter_module (static)
ngx_http_trim_filter_module (static)
ngx_http_headers_filter_module (static)
ngx_http_upstream_session_sticky_module (static)
ngx_http_reqstat_module (static)
ngx_http_lua_module (static)
ngx_http_copy_filter_module (static)
ngx_http_range_body_filter_module (static)
ngx_http_not_modified_filter_module (static)
The text was updated successfully, but these errors were encountered: