前言
想玩Jenkins很久了,最近剛好有衝動想玩,就來玩囉~
Setup
這邊採用docker來建制真方便~
$ docker run --name jenkins -d --restart always -p 8080:8080 -p 50000:50000 -v /data/jenkins:/var/jenkins_home jenkins/jenkins:lts
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
8220bc6c4a1e jenkins/jenkins:lts "/sbin/tini -- /usr/…" 16 seconds ago Up 12 seconds 0.0.0.0:8080->8080/tcp, 0.0.0.0:50000->50000/tcp jenkins
接著連上http://localhost:8080
data:image/s3,"s3://crabby-images/b1486/b1486494feb8e8c9e74a1db62384bb58006c1564" alt=""
這邊要輸入密碼,他很貼心的跟你說密碼在哪了,就去找吧~
$ docker exec -it jenkins cat /var/jenkins_home/secrets/initialAdminPassword
371ef4e7294145f99b4eebe097ec5052
輸入後,會進到安裝plugin的畫面
data:image/s3,"s3://crabby-images/0170f/0170feab2a95a8fb8579c0638a773891cda77473" alt=""
第一次玩,就乖乖按Install suggested plugins吧
data:image/s3,"s3://crabby-images/03ae4/03ae4f5304f0f713e270ff1491a0f96b6ef711e3" alt=""
安裝玩後,接著要創建admin帳號
data:image/s3,"s3://crabby-images/61851/61851fa37e864ed9037e1d92b0109beed4615158" alt=""
接著設定url,目前只是先玩玩看,就用default吧
data:image/s3,"s3://crabby-images/525ef/525ef748ed6563b0254f298ad15fbafe1985c4df" alt=""
準備開使用囉~
data:image/s3,"s3://crabby-images/d15ce/d15cecd9642442ad680a8b3d752109e6dfdb0a2e" alt=""
data:image/s3,"s3://crabby-images/0b20b/0b20bda6443efc249c85ed46b64aab84dccc981c" alt=""
Install plugin
因為等等會使用GitLab來當git server,所以先來安裝GitLab的plugin。
data:image/s3,"s3://crabby-images/2bf4b/2bf4b6e040d8d81017e4cf50360b55b1d7bc5151" alt=""
接著點選可用的,並在filter中輸入GitLab,再選擇需要的plugin,
接下來因為我們目前都沒有任何任務在執行中,所以點選直接安裝
,
但如果是已經有在使用的Jenkins點選下載並於重新啟動後安裝
比較安全。
data:image/s3,"s3://crabby-images/fa965/fa965f87278fd438c23f499e3c9d65534dc6222a" alt=""
勾選當安裝完成且沒有工作正在執行時,重啟Jenkins
data:image/s3,"s3://crabby-images/b2d40/b2d40d9a8f9bd516d77d91ea07684695d4c679bb" alt=""
data:image/s3,"s3://crabby-images/8c004/8c004983c72d25f59446376e51ce929f36e032bd" alt=""
Setup GitLab
點選至設定系統
data:image/s3,"s3://crabby-images/8bcc8/8bcc8c8ada9570dace195989d20219abee01cd1f" alt=""
輸入GitLab的名稱和URL
data:image/s3,"s3://crabby-images/ba952/ba952338c11620c3dfc8bf77764315f5db2df818" alt=""
接著按下Credentials旁的Add來新增Credential
在新增前要先去GitLab拿access token
data:image/s3,"s3://crabby-images/6d728/6d72810e5567fbc32507f28b1bf74074e0a08f66" alt=""
data:image/s3,"s3://crabby-images/8b177/8b17760ca5a0630928f43707c158ad528a095125" alt=""
接著把剛剛的access token輸入到API token且Kind選擇GitLab API Token
data:image/s3,"s3://crabby-images/40bdc/40bdcde5c822dec4fa43833d3c45b57faa46396a" alt=""
新增完就來測試一下(因為我的GitLab也是架在docker中Jenkins會連不到,所以用ngrok幫忙架到外面)
data:image/s3,"s3://crabby-images/3cf25/3cf2523f015bc0e62fed9593377935aea2ce2179" alt=""
測試完後就按儲存
新增專案
點選新增作業
data:image/s3,"s3://crabby-images/f7684/f76849c5402036a2092e6aa3bd39edb64394aa5c" alt=""
再輸入名稱以及選擇建置Free-Style軟體專案
data:image/s3,"s3://crabby-images/44e5c/44e5c2a6b3d36e4f15f8b5ee473fa8da140ef40d" alt=""
輸入描述和選擇GitLab Connection
data:image/s3,"s3://crabby-images/7ddd1/7ddd1b8101af4db2896b43e731f291cd6f6a21dd" alt=""
輸入指定的repository url和brunch
data:image/s3,"s3://crabby-images/3ff75/3ff75692d5f726ef219911f323b1ae0f6aee4fe2" alt=""
選擇Build when a change is pushed to GitLab. GitLab webhook URL: http://localhost:8080/project/Demo
觸發
data:image/s3,"s3://crabby-images/76c31/76c3190cfd4ea2855296a4f6d7ffdb275b18cf54" alt=""
設定完後按儲存
接著按下馬上建置
data:image/s3,"s3://crabby-images/f7b0e/f7b0ed13c37f8f3d3f737ddc49a0474b4ecbc5f9" alt=""
可以看到第一次建置失敗了
data:image/s3,"s3://crabby-images/a3fad/a3fad486cffbd12f2804d08139ade9b26889c267" alt=""
就來Debug吧
data:image/s3,"s3://crabby-images/1b2e4/1b2e40f537294679ed429724f9e0f2653d800b6a" alt=""
data:image/s3,"s3://crabby-images/c581a/c581aae3fc0d43e30b6ad7bc00f3dbaff3be7685" alt=""
Google了一下可能是跟clone的權限有關,
才想起,我的GitLab有限制用ssh連線,
就來把ssh key給補上吧
data:image/s3,"s3://crabby-images/2c8b5/2c8b5c20c525ec9d9fc4856a6926ba632d59051b" alt=""
data:image/s3,"s3://crabby-images/bdd55/bdd555afddcb6d9e6671c7182fae525f97f06689" alt=""
接著按下馬上建置,這次就看到成功囉
data:image/s3,"s3://crabby-images/7f0dd/7f0ddbd4af7d810e8fa6f65a4bd0401ffec4ff9f" alt=""
data:image/s3,"s3://crabby-images/c8706/c8706971e0bed32b81b5644fb43b63da465cbaff" alt=""
也可以幫他加入一些你想要的shell哦,
data:image/s3,"s3://crabby-images/4f498/4f498d1ef8ca34c6cdba54996f04431d57a60093" alt=""
data:image/s3,"s3://crabby-images/f8727/f8727fa57b039971fea952c25f4c2a5b48fb5b24" alt=""
接著來測試一下用gitlab push來觸發
首先到gitlab中設定jenkins ci
project name要跟上面建置的project一樣哦
data:image/s3,"s3://crabby-images/32604/32604ca0a6576781c5b6f35649a4a97453c32162" alt=""
data:image/s3,"s3://crabby-images/3521f/3521f9003df65056240551bae0bc095330f2b9c4" alt=""
接著push個commit,就可以看到jenkins被觸發囉
data:image/s3,"s3://crabby-images/5e070/5e070245d43acfd9a0b723c513253f7b8501fcfb" alt=""
就先到這拉~
之後再研究其他功能