我是JWS的新手.
我有一个Web应用程序(几个Web服务),我想在Linux系统上使用tomcat 6.0.20进行部署.
如果我生成一个包含所有已使用库的.war文件并将其放在webapps目录中,那么一切都没问题,但我想让这些jar共享,而.war文件本身就太大了.
首先,我尝试了直观的方式 - 我创建了一个链接(WEB-INF/lib)到包含jar的目录,但奇怪的是它无法部署(如果目录不是链接,它会启动):
SEVERE: Error configuring application listener of class com.sun.xml.ws.transport.http.servlet.WSServletContextListener
java.lang.ClassNotFoundException: com.sun.xml.ws.transport.http.servlet.WSServletContextListener
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1387)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1233)
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3877)
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4429)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:526)
at org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:630)
at org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:556)
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:491)
at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1206)
at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:314)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
at org.apache.catalina.core.StandardHost.start(StandardHost.java:722)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
at org.apache.catalina.core.StandardService.start(StandardService.java:516)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
at org.apache.catalina.startup.Catalina.start(Catalina.java:583)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
Run Code Online (Sandbox Code Playgroud)
之后我创建了$ CATALINA_HOME/shared/lib目录,并将jar移动到那里(我已经删除了WEB-INF/lib)并且它仍然显示相同的错误 - 似乎tomcat没有在其他任何地方寻找jar比WEB-INF/lib目录.但另一方面 - 为什么创建符号链接有什么不同?
我的CATALINA_HOME和JRE_HOME变量似乎是正确的.
你知道任何好的库将posix和linux函数和结构(例如套接字或文件描述符)包装到C++类中吗?例如,我正在考虑一个基本的FileDescriptor类和一些继承类(unix套接字等),其方法包括write,read甚至一些系统调用(sendfile,splice) - 所有抛出异常而不是设置errno.或者一些共享内存类等.
我似乎无法找到类似的东西,现在我考虑自己编写它,因为我经常要为linux编写一个C++应用程序并使用C函数(痛苦的错误检查),或者每次都自己包装它们.
- -编辑 - -
那么QT和Boost都不会在系统上编译,我们正在使用 - 它是一个基于2.4.29安装在嵌入式计算机上的小型Linux内核.
是否有可能在linux中以某种方式读取另一个进程的输出(来自stdout和stderr)而不知道它?所以假设我有一个进程A在后台运行而进程B想要读取它的输出 - 这可能吗?我不能使用管道或屏幕程序.我尝试从/ proc/xxx/fd或/ pts/x控制台等读取,但到目前为止没有任何工作.
我想到了C++中一个小的调试内联函数:
void inline debug( int debug_level, ostream& out ) {
if ( debug_level <= verbosity ) {
out.flush();
}
else {
ostream tmp;
tmp << out;
}
}
Run Code Online (Sandbox Code Playgroud)
这是我想如何使用它的一个例子:
_debug( 7, cout << "Something something" << someint << endl );
Run Code Online (Sandbox Code Playgroud)
然而它不能按照我计划的方式工作 - 我希望它只在详细级别高于或等于调试级别传递给函数时打印消息,但它似乎每次打印而不管调试级别如何,因此数据保持不变在cout缓冲区.到目前为止,我认为这个功能不是我最近的最好的想法,但我仍然想知道是否有办法清除与cout,cerr等相关的缓冲区.是否有可能让这种功能正常工作?