Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
S
spring-cloud-netflix
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
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
openSource
spring-cloud-netflix
Commits
b46dab30
Commit
b46dab30
authored
Jan 18, 2016
by
Dave Syer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Put @Bean EurekaServerConfig in nested class to avoid cycle
A new integration test ill be added in spring-cloud-samples/tests. Fixes gh-759
parent
c97f6951
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
26 additions
and
24 deletions
+26
-24
EurekaServerConfiguration.java
...loud/netflix/eureka/server/EurekaServerConfiguration.java
+26
-24
No files found.
spring-cloud-netflix-eureka-server/src/main/java/org/springframework/cloud/netflix/eureka/server/EurekaServerConfiguration.java
View file @
b46dab30
...
@@ -37,6 +37,7 @@ import org.springframework.boot.context.embedded.FilterRegistrationBean;
...
@@ -37,6 +37,7 @@ import org.springframework.boot.context.embedded.FilterRegistrationBean;
import
org.springframework.boot.context.properties.EnableConfigurationProperties
;
import
org.springframework.boot.context.properties.EnableConfigurationProperties
;
import
org.springframework.cloud.client.actuator.HasFeatures
;
import
org.springframework.cloud.client.actuator.HasFeatures
;
import
org.springframework.cloud.client.discovery.EnableDiscoveryClient
;
import
org.springframework.cloud.client.discovery.EnableDiscoveryClient
;
import
org.springframework.cloud.netflix.eureka.EurekaConstants
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.ClassPathScanningCandidateComponentProvider
;
import
org.springframework.context.annotation.ClassPathScanningCandidateComponentProvider
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.context.annotation.Configuration
;
...
@@ -72,9 +73,8 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
...
@@ -72,9 +73,8 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
/**
/**
* List of packages containing Jersey resources required by the Eureka server
* List of packages containing Jersey resources required by the Eureka server
*/
*/
private
static
String
[]
EUREKA_PACKAGES
=
new
String
[]
{
private
static
String
[]
EUREKA_PACKAGES
=
new
String
[]
{
"com.netflix.discovery"
,
"com.netflix.discovery"
,
"com.netflix.eureka"
};
"com.netflix.eureka"
};
@Autowired
@Autowired
private
ApplicationInfoManager
applicationInfoManager
;
private
ApplicationInfoManager
applicationInfoManager
;
...
@@ -105,13 +105,16 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
...
@@ -105,13 +105,16 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
return
HasFeatures
.
namedFeature
(
"Eureka Server"
,
EurekaServerConfiguration
.
class
);
return
HasFeatures
.
namedFeature
(
"Eureka Server"
,
EurekaServerConfiguration
.
class
);
}
}
@Configuration
protected
static
class
EurekaServerConfigBeanConfiguration
{
@Bean
@Bean
@ConditionalOnMissingBean
@ConditionalOnMissingBean
public
EurekaServerConfig
eurekaServerConfig
()
{
public
EurekaServerConfig
eurekaServerConfig
()
{
return
new
EurekaServerConfigBean
();
return
new
EurekaServerConfigBean
();
}
}
}
//TODO: is there a better way?
//
TODO: is there a better way?
@Bean
(
name
=
"spring.http.encoding.CONFIGURATION_PROPERTIES"
)
@Bean
(
name
=
"spring.http.encoding.CONFIGURATION_PROPERTIES"
)
public
HttpEncodingProperties
httpEncodingProperties
()
{
public
HttpEncodingProperties
httpEncodingProperties
()
{
HttpEncodingProperties
properties
=
new
HttpEncodingProperties
();
HttpEncodingProperties
properties
=
new
HttpEncodingProperties
();
...
@@ -122,48 +125,47 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
...
@@ -122,48 +125,47 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
@Bean
@Bean
@ConditionalOnProperty
(
prefix
=
"eureka.dashboard"
,
name
=
"enabled"
,
matchIfMissing
=
true
)
@ConditionalOnProperty
(
prefix
=
"eureka.dashboard"
,
name
=
"enabled"
,
matchIfMissing
=
true
)
public
EurekaController
eurekaController
()
{
public
EurekaController
eurekaController
()
{
return
new
EurekaController
(
applicationInfoManager
);
return
new
EurekaController
(
this
.
applicationInfoManager
);
}
}
@Bean
@Bean
public
ServerCodecs
serverCodecs
()
{
public
ServerCodecs
serverCodecs
()
{
return
new
DefaultServerCodecs
(
eurekaServerConfig
);
return
new
DefaultServerCodecs
(
this
.
eurekaServerConfig
);
}
}
@Bean
@Bean
public
PeerAwareInstanceRegistry
peerAwareInstanceRegistry
(
ServerCodecs
serverCodecs
)
{
public
PeerAwareInstanceRegistry
peerAwareInstanceRegistry
(
eurekaClient
.
getApplications
();
// force initialization
ServerCodecs
serverCodecs
)
{
return
new
InstanceRegistry
(
eurekaServerConfig
,
eurekaClientConfig
,
serverCodecs
,
this
.
eurekaClient
.
getApplications
();
// force initialization
eurekaClient
,
expectedNumberOfRenewsPerMin
,
defaultOpenForTrafficCount
);
return
new
InstanceRegistry
(
this
.
eurekaServerConfig
,
this
.
eurekaClientConfig
,
serverCodecs
,
this
.
eurekaClient
,
this
.
expectedNumberOfRenewsPerMin
,
this
.
defaultOpenForTrafficCount
);
}
}
@Bean
@Bean
public
PeerEurekaNodes
peerEurekaNodes
(
PeerAwareInstanceRegistry
registry
,
public
PeerEurekaNodes
peerEurekaNodes
(
PeerAwareInstanceRegistry
registry
,
ServerCodecs
serverCodecs
)
{
ServerCodecs
serverCodecs
)
{
return
new
PeerEurekaNodes
(
registry
,
eurekaServerConfig
,
eurekaClient
Config
,
return
new
PeerEurekaNodes
(
registry
,
this
.
eurekaServer
Config
,
serverCodecs
,
applicationInfoManager
);
this
.
eurekaClientConfig
,
serverCodecs
,
this
.
applicationInfoManager
);
}
}
@Bean
@Bean
public
EurekaServerContext
eurekaServerContext
(
ServerCodecs
serverCodecs
,
public
EurekaServerContext
eurekaServerContext
(
ServerCodecs
serverCodecs
,
PeerAwareInstanceRegistry
registry
,
PeerAwareInstanceRegistry
registry
,
PeerEurekaNodes
peerEurekaNodes
)
{
PeerEurekaNodes
peerEurekaNodes
)
{
return
new
DefaultEurekaServerContext
(
this
.
eurekaServerConfig
,
serverCodecs
,
return
new
DefaultEurekaServerContext
(
eurekaServerConfig
,
serverCodecs
,
registry
,
registry
,
peerEurekaNodes
,
this
.
applicationInfoManager
);
peerEurekaNodes
,
applicationInfoManager
);
}
}
@Bean
@Bean
public
EurekaServerBootstrap
eurekaServerBootstrap
(
PeerAwareInstanceRegistry
registry
,
public
EurekaServerBootstrap
eurekaServerBootstrap
(
PeerAwareInstanceRegistry
registry
,
EurekaServerContext
serverContext
)
{
EurekaServerContext
serverContext
)
{
return
new
EurekaServerBootstrap
(
applicationInfoManager
,
eurekaClientConfig
,
return
new
EurekaServerBootstrap
(
this
.
applicationInfoManager
,
eurekaServerConfig
,
registry
,
serverContext
);
this
.
eurekaClientConfig
,
this
.
eurekaServerConfig
,
registry
,
serverContext
);
}
}
/**
/**
* Register the Jersey filter
* Register the Jersey filter
*
* @param eurekaJerseyApp the jersey application
* @return
*/
*/
@Bean
@Bean
public
FilterRegistrationBean
jerseyFilterRegistration
(
public
FilterRegistrationBean
jerseyFilterRegistration
(
...
@@ -171,8 +173,8 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
...
@@ -171,8 +173,8 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
FilterRegistrationBean
bean
=
new
FilterRegistrationBean
();
FilterRegistrationBean
bean
=
new
FilterRegistrationBean
();
bean
.
setFilter
(
new
ServletContainer
(
eurekaJerseyApp
));
bean
.
setFilter
(
new
ServletContainer
(
eurekaJerseyApp
));
bean
.
setOrder
(
Ordered
.
LOWEST_PRECEDENCE
);
bean
.
setOrder
(
Ordered
.
LOWEST_PRECEDENCE
);
bean
.
setUrlPatterns
(
Collections
bean
.
setUrlPatterns
(
.
singletonList
(
EurekaServerConfigBean
.
DEFAULT_PREFIX
+
"/*"
));
Collections
.
singletonList
(
EurekaConstants
.
DEFAULT_PREFIX
+
"/*"
));
return
bean
;
return
bean
;
}
}
...
@@ -211,7 +213,7 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
...
@@ -211,7 +213,7 @@ public class EurekaServerConfiguration extends WebMvcConfigurerAdapter {
propsAndFeatures
.
put
(
propsAndFeatures
.
put
(
// Skip static content used by the webapp
// Skip static content used by the webapp
ServletContainer
.
PROPERTY_WEB_PAGE_CONTENT_REGEX
,
ServletContainer
.
PROPERTY_WEB_PAGE_CONTENT_REGEX
,
Eureka
ServerConfigBean
.
DEFAULT_PREFIX
+
"/(fonts|images|css|js)/.*"
);
Eureka
Constants
.
DEFAULT_PREFIX
+
"/(fonts|images|css|js)/.*"
);
DefaultResourceConfig
rc
=
new
DefaultResourceConfig
(
classes
);
DefaultResourceConfig
rc
=
new
DefaultResourceConfig
(
classes
);
rc
.
setPropertiesAndFeatures
(
propsAndFeatures
);
rc
.
setPropertiesAndFeatures
(
propsAndFeatures
);
...
...
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