Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
O
Openfire
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
Openfire
Commits
9261370d
Unverified
Commit
9261370d
authored
Jun 10, 2016
by
Guus der Kinderen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
OF-1147: Don't retry plugin load indefinately.
When a plugin fails to load, don't try indefinately.
parent
d18b7a86
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
34 additions
and
8 deletions
+34
-8
PluginManager.java
...va/org/jivesoftware/openfire/container/PluginManager.java
+30
-6
PluginMonitor.java
...va/org/jivesoftware/openfire/container/PluginMonitor.java
+4
-2
No files found.
src/java/org/jivesoftware/openfire/container/PluginManager.java
View file @
9261370d
...
@@ -27,6 +27,7 @@ import org.dom4j.io.SAXReader;
...
@@ -27,6 +27,7 @@ import org.dom4j.io.SAXReader;
import
org.jivesoftware.admin.AdminConsole
;
import
org.jivesoftware.admin.AdminConsole
;
import
org.jivesoftware.database.DbConnectionManager
;
import
org.jivesoftware.database.DbConnectionManager
;
import
org.jivesoftware.openfire.XMPPServer
;
import
org.jivesoftware.openfire.XMPPServer
;
import
org.jivesoftware.util.JiveGlobals
;
import
org.jivesoftware.util.LocaleUtils
;
import
org.jivesoftware.util.LocaleUtils
;
import
org.jivesoftware.util.Version
;
import
org.jivesoftware.util.Version
;
import
org.slf4j.Logger
;
import
org.slf4j.Logger
;
...
@@ -55,7 +56,6 @@ import java.util.concurrent.CopyOnWriteArraySet;
...
@@ -55,7 +56,6 @@ import java.util.concurrent.CopyOnWriteArraySet;
*/
*/
public
class
PluginManager
public
class
PluginManager
{
{
private
static
final
Logger
Log
=
LoggerFactory
.
getLogger
(
PluginManager
.
class
);
private
static
final
Logger
Log
=
LoggerFactory
.
getLogger
(
PluginManager
.
class
);
private
final
Path
pluginDirectory
;
private
final
Path
pluginDirectory
;
...
@@ -67,6 +67,7 @@ public class PluginManager
...
@@ -67,6 +67,7 @@ public class PluginManager
private
final
Map
<
Plugin
,
String
>
childPluginMap
=
new
HashMap
<>();
private
final
Map
<
Plugin
,
String
>
childPluginMap
=
new
HashMap
<>();
private
final
Set
<
PluginListener
>
pluginListeners
=
new
CopyOnWriteArraySet
<>();
private
final
Set
<
PluginListener
>
pluginListeners
=
new
CopyOnWriteArraySet
<>();
private
final
Set
<
PluginManagerListener
>
pluginManagerListeners
=
new
CopyOnWriteArraySet
<>();
private
final
Set
<
PluginManagerListener
>
pluginManagerListeners
=
new
CopyOnWriteArraySet
<>();
private
final
Map
<
String
,
Integer
>
failureToLoadCount
=
new
HashMap
<>();
private
final
PluginMonitor
pluginMonitor
;
private
final
PluginMonitor
pluginMonitor
;
private
boolean
executed
=
false
;
private
boolean
executed
=
false
;
...
@@ -118,6 +119,7 @@ public class PluginManager
...
@@ -118,6 +119,7 @@ public class PluginManager
classloaders
.
clear
();
classloaders
.
clear
();
pluginDevelopment
.
clear
();
pluginDevelopment
.
clear
();
childPluginMap
.
clear
();
childPluginMap
.
clear
();
failureToLoadCount
.
clear
();
}
}
/**
/**
...
@@ -247,13 +249,19 @@ public class PluginManager
...
@@ -247,13 +249,19 @@ public class PluginManager
*
*
* @param pluginDir the plugin directory.
* @param pluginDir the plugin directory.
*/
*/
void
loadPlugin
(
Path
pluginDir
)
boolean
loadPlugin
(
Path
pluginDir
)
{
{
// Only load the admin plugin during setup mode.
// Only load the admin plugin during setup mode.
final
String
pluginName
=
pluginDir
.
getFileName
().
toString
();
final
String
pluginName
=
pluginDir
.
getFileName
().
toString
();
if
(
XMPPServer
.
getInstance
().
isSetupMode
()
&&
!(
pluginName
.
equals
(
"admin"
)
)
)
if
(
XMPPServer
.
getInstance
().
isSetupMode
()
&&
!(
pluginName
.
equals
(
"admin"
)
)
)
{
{
return
;
return
false
;
}
if
(
failureToLoadCount
.
containsKey
(
pluginName
)
&&
failureToLoadCount
.
get
(
pluginName
)
>
JiveGlobals
.
getIntProperty
(
"plugins.loading.retries"
,
5
)
)
{
Log
.
debug
(
"The unloaded file for plugin '{}' is silently ignored, as it has failed to load repeatedly."
,
pluginName
);
return
false
;
}
}
Log
.
debug
(
"Loading plugin '{}'..."
,
pluginName
);
Log
.
debug
(
"Loading plugin '{}'..."
,
pluginName
);
...
@@ -263,7 +271,8 @@ public class PluginManager
...
@@ -263,7 +271,8 @@ public class PluginManager
if
(
!
Files
.
exists
(
pluginConfig
)
)
if
(
!
Files
.
exists
(
pluginConfig
)
)
{
{
Log
.
warn
(
"Plugin '{}' could not be loaded: no plugin.xml file found."
,
pluginName
);
Log
.
warn
(
"Plugin '{}' could not be loaded: no plugin.xml file found."
,
pluginName
);
return
;
failureToLoadCount
.
put
(
pluginName
,
Integer
.
MAX_VALUE
);
// Don't retry - this cannot be recovered from.
return
false
;
}
}
final
SAXReader
saxReader
=
new
SAXReader
();
final
SAXReader
saxReader
=
new
SAXReader
();
...
@@ -279,7 +288,8 @@ public class PluginManager
...
@@ -279,7 +288,8 @@ public class PluginManager
if
(
requiredVersion
.
isNewerThan
(
currentVersion
)
)
if
(
requiredVersion
.
isNewerThan
(
currentVersion
)
)
{
{
Log
.
warn
(
"Ignoring plugin '{}': requires server version {}. Current server version is {}."
,
pluginName
,
requiredVersion
,
currentVersion
);
Log
.
warn
(
"Ignoring plugin '{}': requires server version {}. Current server version is {}."
,
pluginName
,
requiredVersion
,
currentVersion
);
return
;
failureToLoadCount
.
put
(
pluginName
,
Integer
.
MAX_VALUE
);
// Don't retry - this cannot be recovered from.
return
false
;
}
}
}
}
...
@@ -314,7 +324,12 @@ public class PluginManager
...
@@ -314,7 +324,12 @@ public class PluginManager
if
(
parentPlugin
==
null
)
if
(
parentPlugin
==
null
)
{
{
Log
.
info
(
"Unable to load plugin '{}': parent plugin '{}' has not been loaded."
,
pluginName
,
parentPluginNode
.
getTextTrim
()
);
Log
.
info
(
"Unable to load plugin '{}': parent plugin '{}' has not been loaded."
,
pluginName
,
parentPluginNode
.
getTextTrim
()
);
return
;
Integer
count
=
failureToLoadCount
.
get
(
pluginName
);
if
(
count
==
null
)
{
count
=
0
;
}
failureToLoadCount
.
put
(
pluginName
,
++
count
);
return
false
;
}
}
pluginLoader
=
classloaders
.
get
(
parentPlugin
);
pluginLoader
=
classloaders
.
get
(
parentPlugin
);
}
}
...
@@ -446,10 +461,17 @@ public class PluginManager
...
@@ -446,10 +461,17 @@ public class PluginManager
}
}
firePluginCreatedEvent
(
pluginName
,
plugin
);
firePluginCreatedEvent
(
pluginName
,
plugin
);
Log
.
info
(
"Successfully loaded plugin '{}'."
,
pluginName
);
Log
.
info
(
"Successfully loaded plugin '{}'."
,
pluginName
);
return
true
;
}
}
catch
(
Throwable
e
)
catch
(
Throwable
e
)
{
{
Log
.
error
(
"An exception occurred while loading plugin '{}':"
,
pluginName
,
e
);
Log
.
error
(
"An exception occurred while loading plugin '{}':"
,
pluginName
,
e
);
Integer
count
=
failureToLoadCount
.
get
(
pluginName
);
if
(
count
==
null
)
{
count
=
0
;
}
failureToLoadCount
.
put
(
pluginName
,
++
count
);
return
false
;
}
}
}
}
...
@@ -576,6 +598,8 @@ public class PluginManager
...
@@ -576,6 +598,8 @@ public class PluginManager
{
{
Log
.
debug
(
"Unloading plugin '{}'..."
,
pluginName
);
Log
.
debug
(
"Unloading plugin '{}'..."
,
pluginName
);
failureToLoadCount
.
remove
(
pluginName
);
Plugin
plugin
=
plugins
.
get
(
pluginName
);
Plugin
plugin
=
plugins
.
get
(
pluginName
);
if
(
plugin
!=
null
)
if
(
plugin
!=
null
)
{
{
...
...
src/java/org/jivesoftware/openfire/container/PluginMonitor.java
View file @
9261370d
...
@@ -265,10 +265,12 @@ public class PluginMonitor
...
@@ -265,10 +265,12 @@ public class PluginMonitor
final
String
pluginName
=
PluginMetadataHelper
.
getCanonicalName
(
path
);
final
String
pluginName
=
PluginMetadataHelper
.
getCanonicalName
(
path
);
if
(
pluginManager
.
getPlugin
(
pluginName
)
==
null
)
if
(
pluginManager
.
getPlugin
(
pluginName
)
==
null
)
{
{
pluginManager
.
loadPlugin
(
path
);
if
(
pluginManager
.
loadPlugin
(
path
)
)
{
loaded
++;
loaded
++;
}
}
}
}
}
return
loaded
;
return
loaded
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment