Jnotify在linux下的使用出现的问题解决

Jnotify程序代码:

import net.contentobjects.jnotify.JNotify;
import net.contentobjects.jnotify.JNotifyListener;

public class JnotifyForLinux {
	public static void main(String[] args)
	{
		String monitedPath = "/tmp";
		int mask = JNotify.FILE_CREATED | JNotify.FILE_DELETED | JNotify.FILE_MODIFIED | JNotify.FILE_RENAMED;
		System.out.println("------Start Watching DIR: /tmp");
		boolean watchSubtree = true;
		try{
			int watchID = JNotify.addWatch(monitedPath,mask,watchSubtree,new Listener());
			Thread.sleep(1000000);
			System.out.println("Timeout:Stop Watching!");
			boolean res = JNotify.removeWatch(watchID);
			if(!res)
			{
				System.out.println("Release Watching Error!");
			}
		}catch(Exception e){
				e.printStackTrace();
		}
	}
	public static class Listener implements JNotifyListener
	{
		public void fileRenamed(int wd,String rootPath,String oldName,String newName)
		{
			print("rename"+rootPath+":"+oldName+"--->"+newName);
		}
		public void fileModified(int wd,String rootPath,String name)
		{
			if(!name.endsWith("swp") && !name.endsWith("swp/") && !name.endsWith("swpx") && !name.endsWith("swpx/")){
				print("[modified]"+rootPath+":"+name);
			}
		}
		public void fileDeleted(int wd,String rootPath,String name)
		{
			if(!name.endsWith("swp") && !name.endsWith("swp/") && !name.endsWith("swpx")&& !name.endsWith("swpx/")){
				print("[deleted]"+rootPath+":"+name);
			}
		}
		public void fileCreated(int wd,String rootPath,String name)
		{
			if(!name.endsWith("swp") && !name.endsWith("swp/") && !name.endsWith("swpx")&& !name.endsWith("swpx/")){
				print("[created]"+rootPath+":"+name);
			}
		}
		void print(String msg)
		{
			System.err.println(msg);
		}
		
	}
}

在linux运行以上代码:

(1)编译时找不到jnotify-0.94.jar中的类,可以设置classpath路径,也可以使用下面的命令行参数,进行编译:
  javac -cp .:jnotify-0.94.jar JnotifyForLinux.java
  -cp 后面不要忘加当前目录.
(2)运行时,执行下面的命令:
  java -cp .:jnotify-0.94.jar JnotifyForLinux

出现错误:

 Exception in thread "main" java.lang.UnsatisfiedLinkError: no jnotify in java.library.path
  这是因为程序运行时在动态链接库的搜索路径中找不到libjnotify.so(前面的lib是前缀,后面的.so是后缀)

libjnotify.so放入java.library.path中,查看java.library.path用如下代码:

public class javalibpath {
	public static void main(String[] args){
		System.out.println(System.getProperty("java.library.path"));
	}
}
这个变量可能会有多个位置,随便将jnotify压缩包中附带的libjnotify.so文件加入到其中的任何一个路径中即可。

接着运行又出现问题:

java.lang.UnsatisfiedLinkError:/usr/bin/libjnotify.so:/usr/bin/libjnotify.so: wrong ELF class: ELFCLASS64 (Possible cause: architecture word width mismatch)

原因是引入的libjnotify.so是64位系统的,而本身工程布置的linux为32位机,libjnotify.so与linux内核不符,换成32位的。


再接着又出现问题:

 Exception in thread "main" java.lang.UnsatisfiedLinkError: /usr/bin/libjnotify.so: /lib64/libc.so.6: version `GLIBC_2.12' not found

这个问题在于系统的glibc库版本不是libjnotify.so编译时使用的版本,使用 rpm -qi glibc 查看系统的glibc库版本信息,在这里看到我的版本号是2.5,低于libjnotify.so编译时使用的版本2.12。


根据网友说明两种方法:

(1)重新编译libjnotify.so

我的处理方法是在本机重新编译libjnotify.so,如下:
  ·首先将源代码中的以下三个文件拷贝到某一目录下
  net_contentobjects_jnotify_linux_JNotify_linux.c 

  inotify-syscalls.h 

  net_contentobjects_jnotify_linux_JNotify_linux.h
  ·然后进行编译,如下
  -bash-3.1$ gcc -I /usr/java/jdk1.6.0_45/include/ -I /usr/java/jdk1.6.0_45/include/linux/ -fPIC -g -c net_contentobjects_jnotify_linux_JNotify_linux.c -o libjnotify.o
  -bash-3.1$ gcc -g -shared -W1 -o libjnotify.so libjnotify.o -lc
  -bash-3.1$ ls
  inotify-syscalls.h  libjnotify.so                                     net_contentobjects_jnotify_linux_JNotify_linux.h
  libjnotify.o        net_contentobjects_jnotify_linux_JNotify_linux.c
  这里要引入 jni 需要的库,而且版本要和操作系统相匹配。使用 uname -a 查看操作系统的版本,java -version 查看JDK版本。我这里操作系统和JDK都是64位版本。
  此时可以正常使用libjnotify.so了。
正确的执行过程如下:

[plain]  view plain copy
  1. -bash-3.1$ ls  
  2. jnotify-0.94.jar  JNotifyTest.java  libjnotify.so  
  3. -bash-3.1$ javac -cp .:jnotify-0.94.jar JNotifyTest.java   
  4. -bash-3.1$ java -cp .:jnotify-0.94.jar JNotifyTest  
  5. -bash-3.1$ export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:.  
  6. -bash-3.1$ java -cp .:jnotify-0.94.jar JNotifyTest  
  7. Monitoring /usr/local/study/jnotify3  
(2)更换libjnotify.so版本,我使用了0.93包里面的libjnotify.so测试通过。



参考:

http://blog.csdn.net/akon_vm/article/details/9329089

http://xiaobenbenxiong.iteye.com/blog/1706197

http://lichuanbao.iteye.com/blog/1532951

你可能感兴趣的:(java,linux,jnotify)