java-buildpack源碼分析之Release


release的入口是bin/release,一樣須要一個構建目錄實例化buildpack對象,並調用其release接口buildpack#release方法

 代碼的基本結構和compile很類似,探測各個組件是否支持,而後調用各個組件的release方法。release的入口是bin/releasejava

Ruby代碼  收藏代碼web

  1. def release  app

  2.   container = component_detection('container'@containerstrue).first  less

  3.   fail 'No container can run this application' unless container  ui

  4.   component_detection('JRE'@jrestrue).first.release  this

  5.   component_detection('framework'@frameworksfalse).each(&:release)  spa

  6.   command = container.release  .net

  7.   payload = {  debug

  8.   'addons' => [],  code

  9.   'config_vars' => {},  

  10.   'default_process_types' => { 'web' => command }  

  11.   }.to_yaml  

  12.   @logger .debug { "Release Payload:\n#{payload}" }  

  13.   payload  

  14. end  

 

JRE的release方法

JRE組件實例化的實際是OpenJdkJRE的實例,而OpenJdkJRE又繼承自OpenJDKLike,release方法就在OpenJDKLike類中

Ruby代碼  收藏代碼

  1. def release  

  2. @droplet.java_opts  

  3.   .add_system_property('java.io.tmpdir''$TMPDIR')  

  4.   .add_option('-XX:OnOutOfMemoryError', killjava)  

  5.   .concat memory  

  6. end  

 從這裏能夠看出release方法返回的是運行時參數。

JRE的有:JDK的臨時目錄,內存溢出後的執行的腳本,以及內存限制的參數

Tomcat的release方法

調用依然是個子項目的release方法

Ruby代碼  收藏代碼

  1. def release  

  2.   @sub_components.map(&:release)  

  3.   command  

  4. end  

 

TomcatInstance的release方法

什麼都沒作

Ruby代碼  收藏代碼

  1. def release  

  2. end  

 TomcatLifecycleSupport,TomcatLifecycleSupport的release方法也都沒作什麼

TomcatAccessLoggingSupport的release方法

Ruby代碼  收藏代碼

  1. def release  

  2.   @droplet.java_opts.add_system_property 'access.logging.enabled'@configuration[KEY_ENABLED] == 'enabled'  

  3. end  

 添加了運行時參數:

access.logging.enabled和access_logging enabled

總結

從源代碼來看,release方法是獲取個組件的運行時參數。

相關文章
相關標籤/搜索