이 문제에 대한 해결책은 무엇입니까?
Centos 6.8에 elasticsearch 5.4.1을 새로 설치하세요.
[2017-06-15T13:54:19,140][WARN ][o.e.b.Natives ] unable to load JNA n
ative support library, native methods will be disabled.
java.lang.UnsatisfiedLinkError: /tmp/jna--1985354563/jna5608110195315969032.tmp:
/tmp/jna--1985354563/jna5608110195315969032.tmp: failed to map segment from sha
red object: Operation not permitted
at java.lang.ClassLoader$NativeLibrary.load(Native Method) ~[?:1.8.0_131
]
at java.lang.ClassLoader.loadLibrary0(Unknown Source) ~[?:1.8.0_131]
at java.lang.ClassLoader.loadLibrary(Unknown Source) ~[?:1.8.0_131]
at java.lang.Runtime.load0(Unknown Source) ~[?:1.8.0_131]
at java.lang.System.load(Unknown Source) ~[?:1.8.0_131]
at com.sun.jna.Native.loadNativeDispatchLibraryFromClasspath(Native.java
:947) ~[jna-4.4.0.jar:4.4.0 (b0)]
at com.sun.jna.Native.loadNativeDispatchLibrary(Native.java:922) ~[jna-4
.4.0.jar:4.4.0 (b0)]
at com.sun.jna.Native.<clinit>(Native.java:190) ~[jna-4.4.0.jar:4.4.0 (b
0)]
at java.lang.Class.forName0(Native Method) ~[?:1.8.0_131]
at java.lang.Class.forName(Unknown Source) ~[?:1.8.0_131]
at org.elasticsearch.bootstrap.Natives.<clinit>(Natives.java:45) [elasti
csearch-5.4.1.jar:5.4.1]
at org.elasticsearch.bootstrap.Bootstrap.initializeNatives(Bootstrap.jav
a:105) [elasticsearch-5.4.1.jar:5.4.1]
답변1
이 문제를 해결했습니다.
/tmp는 noexec로 마운트됩니다.
exec를 통해 /tmp를 마운트하도록 /etc/fstab을 업데이트하여 문제가 해결되었습니다.
여기에서 부분적으로 논의됨 https://github.com/elastic/elasticsearch/issues/18406