[
https://issues.jboss.org/browse/AS7-2695?page=com.atlassian.jira.plugin.s...
]
Mladen Turk edited comment on AS7-2695 at 11/25/11 7:38 AM:
------------------------------------------------------------
There are few technical reasons why having
product/lib/${platform}-${arch}/native.so would create some issues.
1. Libraries with dependencies won't load because operating
system library loader will look for libraries only
on PATH,LD_LIBRARY_PATH,DYLD_LIBRARY_PATH which is
usually reflected in java.library.path
2. From distribution PoV it makes sense only if you
distribute the entire product as platform specific
Eg. similar to what Eclipse does.
3. Most contemporary linux distributions already provide
tomcat-native as installable package. Since it is
stored inside system library it will load without any
additional configuration (like Remy noted)
It is usually optimized at compile time to a given platform.
If we ship something this would have to be generic so it
can work on any linux.
Also linux distributions are much better in applying security
fixes then we are.
To solve #1 (dependency loading) jbossweb would have to go
trough list of dependencies and load them in reverse order
by using System.load and then call System.loadLibrary
Only libapr-1.so is a dependency, but on enterprise edition
we ship openssl as well as its own list of dependencies so the
can increase to about 10 libraries which have to be loaded in
correct order. Again APR/OpenSSL could either
be provided by us or used from os distribution, so we are
basically again at #3.
Same would have to be done for any other native component.
The logical solution is to setup LD_LIBRARY_PATH (java.library.path)
before loading JVM in which case the dependencies are handled
by operating system library loader. If you have to set it up, then
the actual location where the libraries are stored is irrelevant
since this is handled by the application bootstrap code.
Enterprise distribution also contains additional modules so if we
ship that the way you propose it would mean that we would have to
load the isapi_redirect.dll or mod jk from
C:\jboss\jboss-as7\whatever-product\lib\windows-i386\x.dll
Since this is certainly not appropriate we would have to have
multiple root directories which would request fix directory names.
Other solution is to split the way how we distribute native enterprise
packages. We would need to embed some binaries inside AS and some
in a separate package (which would mean some libraries would have to
be separate). Then there is a problem how to make .rpm out of that.
Bottom line.
It makes sense if you ship everything as a bundle (both java and native code)
usually as a platform specific distribution.
In theory this could be done by merging java distribution and
*all* native distributions into a single package, which means the
native package becomes product mandatory.
was (Author: mladen.turk):
There are few technical reasons why having
product/lib/${platform}-${arch}/native.so would create some issues.
1. Libraries with dependencies won't load because operating
system library loader will look for libraries only
on PATH,LD_LIBRARY_PATH,DYLD_LIBRARY_PATH which is
usually reflected in java.library.path
2. From distribution PoV it makes sense only if you
distribute the entire product as platform specific
Eg. similar to what Eclipse does.
3. Most contemporary linux distributions already provide
tomcat-native as installable package. Since it is
stored inside system library it will load without any
additional configuration (like Remy noted)
It is usually optimized at compile time to a given platform.
If we ship something this would have to be generic so it
can work on any linux.
Also linux distributions are much better in applying security
fixes then we are.
To solve #1 (dependency loading) jbossweb would have to go
trough list of dependencies and load them in reverse order
by using System.load and then call System.loadLibrary
Luckily only libapr-1.so is a dependency. Again APR could either
be provided by us or used from os distribution, so we are
basically again at #3.
Same would have to be done for any other native component.
The logical solution is to setup LD_LIBRARY_PATH (java.library.path)
before loading JVM in which case the dependencies are handled
by operating system library loader. If you have to set it up, then
the actual location where the libraries are stored is irrelevant
since this is handled by the application bootstrap code.
Enterprise distribution also contains additional modules so if we
ship that the way you propose it would mean that we would have to
load the isapi_redirect.dll or mod jk from
C:\jboss\jboss-as7\whatever-product\lib\windows-i386\x.dll
Since this is certainly not appropriate we would have to have
multiple root directories which would request fix directory names.
Other solution is to split the way how we distribute native enterprise
packages. We would need to embed some binaries inside AS and some
in a separate package (which would mean some libraries would have to
be separate). Then there is a problem how to make .rpm out of that.
Bottom line.
It makes sense if you ship everything as a bundle (both java and native code)
usually as a platform specific distribution.
In theory this could be done by merging java distribution and
*all* native distributions into a single package, which means the
native package becomes product mandatory.
Package APR native libraries correctly
--------------------------------------
Key: AS7-2695
URL:
https://issues.jboss.org/browse/AS7-2695
Project: Application Server 7
Issue Type: Task
Components: Web
Reporter: David Lloyd
Assignee: Remy Maucherat
Fix For: 7.1.0.CR1
The APR libraries for native jbossweb should be packaged in the "lib" directory
of the module under the platform specific name, e.g.
* {{lib/linux-i686/libxxxx.so}}
* {{lib/linux-x86_64/libxxxx.so}}
* {{lib/solaris-sparc/libxxxx.so}}
* {{lib/solaris-sparcv9/libxxxx.so}}
* {{lib/solaris-i686/libxxxx.so}}
* {{lib/solaris-x68_64/libxxxx.so}}
* {{lib/macosx-i686/libxxxx.sl}}
* {{lib/macosx-x86_64/libxxxx.sl}}
For the case where you need to vary the library based on the Solaris version, you have
two options:
* (best solution) rework the library to use weak symbols and/or libc probes and/or system
call error detection, to detect features which are present and absent and adjust at
runtime
* Introduce more than one library in each of the solaris-xxx directories with the version
suffix, e.g. libnative-2.8.so or similar and check for solaris at load time, and if
solaris, choose the library with the version encoded in the name
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators:
https://issues.jboss.org/secure/ContactAdministrators!default.jspa
For more information on JIRA, see:
http://www.atlassian.com/software/jira