Spring Boot Admin的使用
前面的文章我們講了Spring Boot的Actuator。但是Spring Boot Actuator只是提供了一個個的接口,需要我們自行集成到監控程序中。今天我們將會講解一個優秀的監控工具Spring Boot Admin。它採用圖形化的界面,讓我們的Spring Boot管理更加簡單。
先上圖給大家看一下Spring Boot Admin的界面:
從界面上面我們可以看到Spring Boot Admin提供了眾多強大的監控功能。那麼開始我們的學習吧。
配置Admin Server
既然是管理程序,肯定有一個server,配置server很簡單,我們添加這個依賴即可:
<code><dependency>/<code>
<code><groupid>de.codecentric/<groupid>/<code>
<code><artifactid>spring-boot-admin-starter-server/<artifactid>/<code>
<code><version>2.2.2/<version>/<code>
<code>
<code>同時我們需要在main程序中添加@EnableAdminServer來啟動admin server。/<code>
<code>@EnableAdminServer/<code>
<code>@SpringBootApplication/<code>
<code>publicclassSpringBootAdminServerApplication{/<code>
<code>publicstaticvoidmain(String[]args){/<code>
<code>SpringApplication.run(SpringBootAdminServerApplication.class,args);/<code>
<code>}/<code>
<code>}/<code>
配置admin client
有了server,我們接下來配置需要監控的client應用程序,在本文中,我們自己監控自己,添加client依賴如下:
<code><dependency>/<code>
<code><groupid>de.codecentric/<groupid>/<code>
<code><artifactid>spring-boot-admin-starter-client/<artifactid>/<code>
<code><version>2.2.2/<version>/<code>
<code>
我們需要為client指定要註冊到的admin server:
spring.boot.admin.client.url=http://localhost:8080
因為Spring Boot Admin依賴於 Spring Boot Actuator, 從Spring Boot2 之後,我們需要主動開啟暴露的主鍵,如下:
management.endpoints.web.exposure.include=*
management.endpoint.health.show-details=always
配置安全主鍵
通常來說,我們需要一個登陸界面,以防止未經授權的人訪問。spring boot admin提供了一個UI供我們使用,同時我們添加Spring Security依賴:
<code><dependency>/<code>
<code><groupid>de.codecentric/<groupid>/<code>
<code><artifactid>spring-boot-admin-server-ui-login/<artifactid>/<code>
<code><version>1.5.7/<version>/<code>
<code>
<code><dependency>/<code>
<code><groupid>org.springframework.boot/<groupid>/<code>
<code><artifactid>spring-boot-starter-security/<artifactid>/<code>
<code>
添加了Spring Security,我們需要自定義一些配置:
<code>@Configuration/<code>
<code>publicclassWebSecurityConfigextendsWebSecurityConfigurerAdapter{/<code>
<code>privatefinalAdminServerPropertiesadminServer;/<code>
<code>publicWebSecurityConfig(AdminServerPropertiesadminServer){/<code>
<code>this.adminServer=adminServer;/<code>
<code>}/<code>
<code>@Override/<code>
<code>protectedvoidconfigure(HttpSecurityhttp)throwsException{/<code>
<code>SavedRequestAwareAuthenticationSuccessHandlersuccessHandler=/<code>
<code>newSavedRequestAwareAuthenticationSuccessHandler();/<code>
<code>successHandler.setTargetUrlParameter("redirectTo");/<code>
<code>successHandler.setDefaultTargetUrl(this.adminServer.getContextPath()+"/");/<code>
<code>http/<code>
<code>.authorizeRequests()/<code>
<code>.antMatchers(this.adminServer.getContextPath()+"/assets/**").permitAll()/<code>
<code>.antMatchers(this.adminServer.getContextPath()+"/login").permitAll()/<code>
<code>.anyRequest().authenticated()/<code>
<code>.and()/<code>
<code>.formLogin()/<code>
<code>.loginPage(this.adminServer.getContextPath()+"/login")/<code>
<code>.successHandler(successHandler)/<code>
<code>.and()/<code>
<code>.logout()/<code>
<code>.logoutUrl(this.adminServer.getContextPath()+"/logout")/<code>
<code>.and()/<code>
<code>.httpBasic()/<code>
<code>.and()/<code>
<code>.csrf()/<code>
<code>.csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse())/<code>
<code>.ignoringRequestMatchers(/<code>
<code>newAntPathRequestMatcher(this.adminServer.getContextPath()+/<code>
<code>"/instances",HttpMethod.POST.toString()),/<code>
<code>newAntPathRequestMatcher(this.adminServer.getContextPath()+/<code>
<code>"/instances/*",HttpMethod.DELETE.toString()),/<code>
<code>newAntPathRequestMatcher(this.adminServer.getContextPath()+"/actuator/**"))/<code>
<code>.and()/<code>
<code>.rememberMe()/<code>
<code>.key(UUID.randomUUID().toString())/<code>
<code>.tokenValiditySeconds(1209600);/<code>
<code>}/<code>
<code>}/<code>
接下來,我們在配置文件中指定服務器的用戶名和密碼:
spring.boot.admin.client.username=admin
spring.boot.admin.client.password=admin
作為一個客戶端,連接服務器的時候,我們也需要提供相應的認證信息如下:
spring.boot.admin.client.instance.metadata.user.name=admin
spring.boot.admin.client.instance.metadata.user.password=admin
spring.boot.admin.client.username=admin
spring.boot.admin.client.password=admin
好了,登錄頁面和權限認證也完成了。
Hazelcast集群
Spring Boot Admin 支持Hazelcast的集群,我們先添加依賴如下:
<code><dependency>/<code>
<code><groupid>com.hazelcast/<groupid>/<code>
<code><artifactid>hazelcast/<artifactid>/<code>
<code><version>3.12.2/<version>/<code>
<code>
<code>然後添加Hazelcast的配置:/<code>
<code>@Configuration/<code>
<code>publicclassHazelcastConfig{/<code>
<code>@Bean/<code>
<code>publicConfighazelcast(){/<code>
<code>MapConfigeventStoreMap=newMapConfig("spring-boot-admin-event-store")/<code>
<code>.setInMemoryFormat(InMemoryFormat.OBJECT)/<code>
<code>.setBackupCount(1)/<code>
<code>.setEvictionPolicy(EvictionPolicy.NONE)/<code>
<code>.setMergePolicyConfig(newMergePolicyConfig(PutIfAbsentMapMergePolicy.class.getName(),100));/<code>
<code>MapConfigsentNotificationsMap=newMapConfig("spring-boot-admin-application-store")/<code>
<code>.setInMemoryFormat(InMemoryFormat.OBJECT)/<code>
<code>.setBackupCount(1)/<code>
<code>.setEvictionPolicy(EvictionPolicy.LRU)/<code>
<code>.setMergePolicyConfig(newMergePolicyConfig(PutIfAbsentMapMergePolicy.class.getName(),100));/<code>
<code>Configconfig=newConfig();/<code>
<code>config.addMapConfig(eventStoreMap);/<code>
<code>config.addMapConfig(sentNotificationsMap);/<code>
<code>config.setProperty("hazelcast.jmx","true");/<code>
<code>config.getNetworkConfig()/<code>
<code>.getJoin()/<code>
<code>.getMulticastConfig()/<code>
<code>.setEnabled(false);/<code>
<code>TcpIpConfigtcpIpConfig=config.getNetworkConfig()/<code>
<code>.getJoin()/<code>
<code>.getTcpIpConfig();/<code>
<code>tcpIpConfig.setEnabled(true);/<code>
<code>tcpIpConfig.setMembers(Collections.singletonList("127.0.0.1"));/<code>
<code>returnconfig;/<code>
<code>}/<code>
<code>}/<code>
看完覺得不錯可以關注一下,後續還會持續更新幹貨文章!!
閱讀更多 Java高級架構師 的文章
關鍵字: client spring getContextPath