您好,登錄后才能下訂單哦!
Cloud Foundry buildpack開發(fā)部署的實例分析,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
CF運行應用的基本過程是將用戶發(fā)布的應用程序包解壓開,然后將自己的所有buildpack拿來,按照指定順序與程序包進行匹配,直到找到第一個能夠運行這些代碼的buildpack,然后將buildpack也解開,與這些應用代碼打成一個包(即droplet),在按照指定的運行環(huán)境參數(shù)生成容器,將droplet扔進去,按照buildpack指定的啟動命令,啟動應用。在上面的過程中,buildpack實現(xiàn)了三步功能:
第一步,detect:檢查當前應用程序包是否能夠用本buildpack支持運行,比如,java buildpack發(fā)現(xiàn)WEB-INF路徑就認為自己能夠運行它。
第二步,compile:將應用程序包與buildpack包水乳交融一下,比如將java程序包放到tomcat的應用目錄下,然后替換某些參數(shù),比如將當前dea里的隨機端口賦予這個tomcat實例。
第三部,release:將droplet啟動,比如運行tomcat的startup.sh。
任何一個buildpack都有一個bin路徑,放著三個指定名字(detect、compile、release)的腳本(任何dea的os能執(zhí)行的腳本都可以),然后具體的實現(xiàn)邏輯就從這里觸發(fā)了。下面將以java buildpack為例,通過三個實際需求,介紹buildpack的開發(fā)和使用。
國際軟件都使用格林尼治時間作為系統(tǒng)中的默認時間,所以咱們寫出的日志或者使用程序代碼獲取的系統(tǒng)時間(其實都是dea的系統(tǒng)時間)都是+0000的,而我們需要+0800的,當然,可以從代碼里自行處理。但是我的用戶們不爽,他們說我這程序還要本地測視呢,太亂了,你得給我處理。
tomcat里的默認編碼應該都是utf8,可是,在某些場景下,比如tomcat上運行的rest服務,其報文中包含中文,是無法被正常接收的。CF的java buildpack里包含的就是默認的tomcat,所以為了解決這個問題,可以使用下面的命令進行設置,但是畢竟不大爽,還是直接改掉buildpack比較友好。
cf set-env appname CATALINA_OPTS "$CATALINA_OPTS -Dfile.encoding=UTF-8"
java buildpack是ruby寫的,所以如果不是原則性的上的變動,大可以通過將壓縮包打開,修改ruby代碼,然后再壓縮上的辦法。不過,winrar似乎有些莫名其妙的問題,如果是解壓開再壓縮會有問題,但是如果直接將修改后的同名文件拖動到winrar的窗口中進行替換,就可以工作。為了達到時區(qū)和編碼這兩個需求,需要做的文件修改如下:
在java-buildpack-offline-v#.#.#\lib\java_buildpack\component\java_opts.rb
中增加兩個方法:
# @return [JavaOpts] +self+-Duser.timezone def add_timezone(value) self << "-Duser.timezone=#{value}" self end # @return [JavaOpts] +self+-Dfile.encoding def add_fileencode(value) self << "-Dfile.encoding=#{value}" self end
在java-buildpack-offline-v#.#.#\lib\java_buildpack\jre\open_jdk_like.rb中,修改release方法,增加add_timezone和add_fileencode調用
@droplet.java_opts .add_system_property('java.io.tmpdir', '$TMPDIR') .add_option('-XX:OnOutOfMemoryError', killjava) .add_timezone('GMT+08') .add_fileencode('UTF-8') .concat memory
修改后,將這兩個文件替換到原來的離線buildpack包里,然后將其發(fā)布到CF中,查看當前buildpack情況:
cf buidlpacks
然后,創(chuàng)建新的buildpack,其中最后一個參數(shù)決定了cf查看buildpack符合應用的順序,需要根據(jù)實際情況調整。
cf create-buildpack java_buildpack_with_gmt0800_offline d:\somedir\java-buildpack-with-gmt0800-offline-v2.4.zip 1
如果是更新的話,使用cf update-buildpack
。
有些應用,尤其是做產(chǎn)品的公司做的,會對tomcat進行一定的剪裁,這樣的應用遷移到cf上時,非常痛苦。簡單的辦法就是,自己做個buildpack,提供的只是jre。
假定這個產(chǎn)品的標識是LiveBOS,在程序包的第一層路徑下就有一個LiveBOS文件夾:
在java-buildpack-with-livebos-offline-v#.#\lib\java_buildpack\container\里添加一個libe_bos.rb:
# Encoding: utf-8 # Cloud Foundry Java Buildpack # Copyright 2013 the original author or authors. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. require 'java_buildpack/container' require 'java_buildpack/container/dist_zip_like' require 'java_buildpack/util/dash_case' module JavaBuildpack module Container # Encapsulates the detect, compile, and release functionality for +LiveBOS+ style applications. class LiveBOS < JavaBuildpack::Container::DistZipLike # Creates an instance # # @param [Hash] context a collection of utilities used the component def initialize(context) super(context) end # (see JavaBuildpack::Component::BaseComponent#compile) def compile startup.chmod 0755 end # (see JavaBuildpack::Component::BaseComponent#release) def release @droplet.java_opts.add_system_property 'http.port', '$PORT' [ @droplet.java_home.as_env_var, @droplet.java_opts.as_env_var, qualify_path(catalina, @droplet.root), 'run' ].flatten.compact.join(' ') end protected # (see JavaBuildpack::Container::DistZipLike#id) def id LiveBOS.to_s.dash_case end # (see JavaBuildpack::Container::DistZipLike#supports?) def supports? livebos? && catalina.exist? end private def startup candidates = (root + 'bin/startup.sh').glob candidates.size == 1 ? candidates.first : nil end def catalina candidates = (root + 'bin/catalina.sh').glob candidates.size == 1 ? candidates.first : nil end def livebos? (root + 'LiveBos').exist? end end end end
在java-buildpack-with-livebos-offline-v2.4\config\components.yml的containers下面添加:
- "JavaBuildpack::Container::LiveBOS"
后面就是打包發(fā)布了。
有些應用只能使用特定版本的jre,如果這jre比較新還好辦,但是如果是舊的,比如1.6,那現(xiàn)在cf中能找到的buildpack就全不支持了。另外,也有可能應用要求使用oracle jre(cf中默認是open jre)。
開始之前,建議大家不要在windows上嘗試這個編譯過程,基本沒有成功的可能,隨便找個能上網(wǎng)能運行ruby的linux吧。
修改java-buildpack-offline-v2.4\config\components.yml,將不使用的jre注釋掉:
- "JavaBuildpack::Jre::OpenJdkJRE" # - "JavaBuildpack::Jre::OracleJRE"
修改java-buildpack-offline-v2.4\config\oracle_jre.yml,將下面這行里的內容更新為一個本地tomcat的地址:
repository_root: http://localhost:8080/myapp
在本地的myapp下放一個index.yml文件,其中放上類似下列內容的oracle jre下載地址,如果oracle網(wǎng)站上已經(jīng)找不到了,就也放在本地tomcat上吧。
--- 1.7.0_01: http://download.run.pivotal.io/openjdk/centos6/x86_64/openjdk-1.7.0_01.tar.gz ...... 1.8.0_M6: http://download.run.pivotal.io/openjdk/centos6/x86_64/openjdk-1.8.0_M6.tar.gz
然后,就可以編譯打包了。
bundle install bundle exec rake package OFFLINE=true ... Creating build/java-buildpack-offline-cfd6b17.zip
最后,當然還是發(fā)布到cf上。
看完上述內容,你們掌握 Cloud Foundry buildpack開發(fā)部署的實例分析的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。