myeclipse java.lang.OutOfMemoryError:PermGen spaceエラー
6584 ワード
ECLIPSEは最近よくエラーを報告して、ログを見て、以下のエラーメッセージがあります.
1、PermGen spaceのフルネームはPermanent Generation spaceで、メモリの永久保存領域OutOfMemoryError:PermGen spaceは表面的にメモリの利益であり、解決方法もメモリを大きくするに違いない.なぜメモリが得られるのか:この部分はClassとMetaの情報を格納するために使用され、ClassはLoadされたときにPermGen space領域に格納され、Instanceを格納しているHeap領域とは異なり、GC(Garbage Collection)はメインプログラムの実行期間中にPermGen spaceをクリーンアップしないので、あなたのアプリがCLASSをたくさんLOADすると、PermGen spaceエラーが発生する可能性が高い.このエラーは、WebサーバがJSPに対してpre compileを行う場合によく発生します.
2、修正方法run.batに、-Xms 256 m-Xmx 512 m-XX:MaxNewSize=256 m-XX:MaxPermSize=256 mを加える
プロジェクトでは多くのjarパケットが参照されているため、これらのjarパケットのclass情報はJBossのclass loaderによってPermGen space領域にロードされます.JVMのデフォルトでは、この部分の空間の大きさは4 Mしかありません.jarパケットが非常に多い場合、明らかに十分ではありません.
また、heapメモリが不足するとjavaが現れる.lang.OutOfMemoryError:Java heap spaceの場合、-Xmx 512 mで最大heapメモリを指定することで、このような問題を解決できます.
3、問題を解決する方法は、インストールディレクトリeclipseを修正することである.Iniファイル、一番後ろに2行追加
これで問題が解決した.
原文住所:http://scholers.iteye.com/blog/734210、オリジナルをたくさんご覧ください
ENTRY org.eclipse.ui 4 0 2010-08-10 09:56:43.763
!MESSAGE Unhandled event loop exception
!STACK 0
org.eclipse.swt.SWTException: Failed to execute runnable (java.lang.OutOfMemoryError: PermGen space)
at org.eclipse.swt.SWT.error(SWT.java:3884)
at org.eclipse.swt.SWT.error(SWT.java:3799)
at org.eclipse.swt.widgets.Synchronizer.runAsyncMessages(Synchronizer.java:137)
at org.eclipse.swt.widgets.Display.runAsyncMessages(Display.java:3855)
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3476)
at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2405)
at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2369)
at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2221)
at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:500)
at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:493)
at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:113)
at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:194)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:368)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:179)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:559)
at org.eclipse.equinox.launcher.Main.basicRun(Main.java:514)
at org.eclipse.equinox.launcher.Main.run(Main.java:1311)
Caused by: java.lang.OutOfMemoryError: PermGen space
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(Unknown Source)
at java.lang.ClassLoader.defineClass(Unknown Source)
at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.defineClass(DefaultClassLoader.java:183)
at org.eclipse.osgi.baseadaptor.loader.ClasspathManager.defineClass(ClasspathManager.java:576)
at org.eclipse.osgi.baseadaptor.loader.ClasspathManager.findClassImpl(ClasspathManager.java:546)
at org.eclipse.osgi.baseadaptor.loader.ClasspathManager.findLocalClassImpl(ClasspathManager.java:477)
at org.eclipse.osgi.baseadaptor.loader.ClasspathManager.findLocalClass_LockClassLoader(ClasspathManager.java:465)
at org.eclipse.osgi.baseadaptor.loader.ClasspathManager.findLocalClass(ClasspathManager.java:445)
at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.findLocalClass(DefaultClassLoader.java:211)
at org.eclipse.osgi.internal.loader.BundleLoader.findLocalClass(BundleLoader.java:376)
at org.eclipse.osgi.internal.loader.BundleLoader.findClassInternal(BundleLoader.java:452)
at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:405)
at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:393)
at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.loadClass(DefaultClassLoader.java:105)
at java.lang.ClassLoader.loadClass(Unknown Source)
at org.eclipse.ui.internal.navigator.NavigatorContentService.getExtension(NavigatorContentService.java:905)
at org.eclipse.ui.internal.navigator.NavigatorContentService.getExtension(NavigatorContentService.java:875)
at org.eclipse.ui.internal.navigator.NavigatorContentService.findRootContentExtensions(NavigatorContentService.java:511)
at org.eclipse.ui.internal.navigator.NavigatorContentService.findRootContentExtensions(NavigatorContentService.java:477)
at org.eclipse.ui.internal.navigator.NavigatorContentService.updateService(NavigatorContentService.java:380)
at org.eclipse.ui.internal.navigator.NavigatorContentServiceContentProvider.inputChanged(NavigatorContentServiceContentProvider.java:598)
at org.eclipse.jface.viewers.ContentViewer.setInput(ContentViewer.java:270)
at org.eclipse.jface.viewers.StructuredViewer.setInput(StructuredViewer.java:1634)
at org.eclipse.ui.navigator.CommonNavigator.createPartControl(CommonNavigator.java:191)
at org.eclipse.wst.server.ui.internal.cnf.ServersView2.createPartControl(ServersView2.java:66)
at org.eclipse.ui.internal.ViewReference.createPartHelper(ViewReference.java:367)
at org.eclipse.ui.internal.ViewReference.createPart(ViewReference.java:226)
at org.eclipse.ui.internal.WorkbenchPartReference.getPart(WorkbenchPartReference.java:595)
at org.eclipse.ui.internal.Perspective.showView(Perspective.java:2228)
at org.eclipse.ui.internal.WorkbenchPage.busyShowView(WorkbenchPage.java:1067)
at org.eclipse.ui.internal.WorkbenchPage$20.run(WorkbenchPage.java:3816)
1、PermGen spaceのフルネームはPermanent Generation spaceで、メモリの永久保存領域OutOfMemoryError:PermGen spaceは表面的にメモリの利益であり、解決方法もメモリを大きくするに違いない.なぜメモリが得られるのか:この部分はClassとMetaの情報を格納するために使用され、ClassはLoadされたときにPermGen space領域に格納され、Instanceを格納しているHeap領域とは異なり、GC(Garbage Collection)はメインプログラムの実行期間中にPermGen spaceをクリーンアップしないので、あなたのアプリがCLASSをたくさんLOADすると、PermGen spaceエラーが発生する可能性が高い.このエラーは、WebサーバがJSPに対してpre compileを行う場合によく発生します.
2、修正方法run.batに、-Xms 256 m-Xmx 512 m-XX:MaxNewSize=256 m-XX:MaxPermSize=256 mを加える
プロジェクトでは多くのjarパケットが参照されているため、これらのjarパケットのclass情報はJBossのclass loaderによってPermGen space領域にロードされます.JVMのデフォルトでは、この部分の空間の大きさは4 Mしかありません.jarパケットが非常に多い場合、明らかに十分ではありません.
また、heapメモリが不足するとjavaが現れる.lang.OutOfMemoryError:Java heap spaceの場合、-Xmx 512 mで最大heapメモリを指定することで、このような問題を解決できます.
3、問題を解決する方法は、インストールディレクトリeclipseを修正することである.Iniファイル、一番後ろに2行追加
-XX:PermSize=128M
-XX:MaxPermSize=128M
これで問題が解決した.
原文住所:http://scholers.iteye.com/blog/734210、オリジナルをたくさんご覧ください