前言:
經過一段時間的測試驗證,決定使用RPM來做Golang服務的部署方式. 我們組關于代碼的部署方式主要有這么幾種,Python直接使用virtualenv + py code的方式來上線,Lua 是直接打包,Golang 是先編譯生成二進制之后,聯合配置文件直接打包。 但由于我們開發的Golang的代碼很多是基礎組件,需要很多節點都去安裝部署。那么這時候自己編譯打包跟RPM的方式其實很是想象的,那還不如復用公司內部成熟的基于rpm的上線系統。
下面話不多說了,來一起看看詳細的介紹吧。
rpm打包的使用方法:
# 安裝RPM依賴yum install rpmdevtools#生成RPM目錄cd ~rpmdev-setuptree
下面是rpm的基本組織結構.
├── BUILD├── BUILDROOT├── RPMS├── SOURCES├── SPECS└── SRPMS
其實最干脆的rpm打包方式就是 直接編輯SPECS的配置文件,在%install的邏輯里把go代碼編譯成二進制,然后cp進去,這就完事了。由于時間關系我就不詳細描述rpm的高級用法了,有興趣的朋友可以自己看SPECS相關的配置。
#軟件包簡要介紹Summary: build transcoding#軟件包的名字Name: transcoding#軟件包的主版本號Version: 0.0.1#軟件包的次版本號Release: 5#源代碼包,默認將在上面提到的SOURCES目錄中尋找Source0: %{name}-%{version}.tar.gz#授權協議License: GPL#軟件分類Group: Development/Tools#軟件包的內容介紹%description視頻轉碼集群#表示預操作字段,后面的命令將在源碼代碼BUILD前執行%prep#BUILD字段,將通過直接調用源碼目錄中自動構建工具完成源碼編譯操作%build#file#安裝字段%install# 二進制執行文件mkdir -p ${RPM_BUILD_ROOT}/usr/bin/cp -f /devops/app/go/src/transcoding/engine_bin ${RPM_BUILD_ROOT}/usr/bin/transcoding_engine_bincp -f /devops/app/go/src/transcoding/rest_bin ${RPM_BUILD_ROOT}/usr/bin/transcoding_rest_bin# 配置文件mkdir -p ${RPM_BUILD_ROOT}/etc/transcodingcp -f /devops/app/go/src/transcoding/etc/online.config.ini ${RPM_BUILD_ROOT}/etc/transcoding/config.ini# 控制腳本mkdir -p ${RPM_BUILD_ROOT}/etc/init.d/cp -f /devops/app/go/src/transcoding/bin/init.sh ${RPM_BUILD_ROOT}/etc/init.d/transcoding.sh#調用源碼中安裝執行腳本#文件說明字段,聲明多余或者缺少都將可能出錯%files%defattr(-,root,root)/usr/bin/transcoding_engine_bin/usr/bin/transcoding_rest_bin/etc/init.d/transcoding.sh%dir/etc/transcoding
當編輯完SPECS文件后,然后開始運行 rpmbuild
生成rpm包.
rpmbuild -bb transcoding.spec
編譯完之后,我們在來看看rpm結構, 對的,多了一個rpm包…
├── BUILD├── BUILDROOT├── RPMS│ └── x86_64│ └── transcoding-0.0.1-5.x86_64.rpm├── SOURCES├── SPECS│ └── transcoding.spec└── SRPMS
剩下要做的就是把我們生成的rpm包,上傳到我們私有的yum repo源里面。剩下的流程你就可以走你的標準的上線流程了。
這里需要注意兩件事情:
1. rpm specs
版本號的更新,如果不更新會造成yum update
無效….
2. 如果配置文件含有db的賬號密碼,請不要添加到rpm中,就算是私有yum repo
,也不安全…
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答