入門系列之在Ubuntu 16.04使用Buildbot建立持續集成系統

歡迎大家前往騰訊云+社區,獲取更多騰訊海量技術實踐干貨哦~

本文由angel_郁發表于云+社區專欄

介紹

Buildbot是一個基于Python的持續集成系統,用于自動化軟件構建,測試和發布過程。

在本教程中,我們將演示如何設置持續集成系統以自動測試對存儲庫的新更改。我們將使用一個簡單的Node.js應用程序來演示測試過程和必要的配置。為了將我們的測試環境與Buildbot主機隔離,我們將創建一個Docker鏡像作為Buildbot worker運行。然后,我們將配置Buildbot主服務器以觀察GitHub存儲庫的更改,每次檢測到新的更改時自動進行測試。

準備

要學習本教程,您需要:

  • 一個具有至少1 GB的RAM的Ubuntu16.04服務器,并包括一個可以使用sudo命令的非root 用戶。

另外,在開始本教程之前需要完成以下內容:

  • 如何在Ubuntu上安裝Buildbot

  • 安裝Nginx

  • 在Ubuntu上使用SSL來保護Nginx

  • 給Buildbot加上SSL,使用Nginx做反向代理

  • 搭建Docker環境

在GitHub中使用fork示例存儲庫

在我們開始配置Buildbot之前,我們將看一下我們將用于本教程的示例存儲庫。

在您的Web瀏覽器中,訪問我們將用于演示的GitHub上的hello hapi應用程序。這個應用程序是一個簡單的“hello world”程序,帶有一些單元和集成測試,用hapi編寫的一個Node.js Web框架。

由于此示例用于演示各種持續集成系統,您可能會注意到一些文件用于為其他系統定義管道。對于Buildbot,我們將在服務器上而不是在存儲庫中定義構建步驟。

稍后,我們將在我們的存儲庫中為Buildbot設置webhook,以便更改將自動觸發新測試。現在,我們需要創建自己的存儲庫分支。

單擊屏幕右上角的Fork按鈕:

imgGitHub fork 按鈕

如果您是GitHub組織的成員,可能會詢問您在哪里使用fork存儲庫:

img哪里使用fork存儲庫

選擇帳戶或組織后,存儲庫的副本將添加到您的帳戶中:

img存儲庫的副本將添加到您的帳戶

您將在Buildbot配置中使用fork的URL。現在我們有了一個存儲庫URL,我們可以開始配置Buildbot了。

為Buildbot設置Docker

我們將從設置Docker開始,以便Buildbot使用它來執行構建。首先,我們需要配置Docker和Buildbot之間的訪問。之后,我們需要創建一個Docker鏡像以用于我們的容器。

為Buildbot配置Docker訪問

我們需要允許Buildbot和Docker在幾個不同的級別進行通信。

首先,我們需要確保Buildbot進程可以訪問Docker守護程序。我們可以通過將做到這一點buildbot用戶的docker組:

$ sudo usermod -aG docker buildbot

下次重新啟動Buildbot主服務器時,這個新組將可用于Buildbot,我們稍后會這樣做。

我們還需要確保Buildbot知道如何與Docker通信。由于Buildbot是用Python編寫的,它利用docker-py Python包而不是直接發出Docker命令。

您可以輸入以下命令安裝docker-py

$ sudo -H pip install docker-py

最后,我們需要打開從容器到主機系統和外部世界的網絡訪問。我們可以通過在防火墻中允許docker0的接口例外來實現此目的。

通過輸入以下內容允許從docker0界面訪問流量:

$ sudo ufw allow in on docker0

Buildbot和Docker現在應該能夠有效地相互通信。

創建一個Docker鏡像以用作Buildbot Worker

接下來,我們將創建一個Docker容器,用作Buildbot worker來運行我們的測試。Buildbot可以動態啟動Docker容器以用作worker,但首先需要使用包含的一些Buildbot worker組件構建容器。

幸運的是,Buildbot項目提供了一個基本的Buildbot worker映像,該鏡像已經配置了所有特定于Buildbot的需求。我們只需要將此鏡像用作基礎并安裝我們項目所需的其他依賴項。

在我們的例子中,我們將使用的示例應用程序是Node.js應用程序,因此我們需要確保Node.js在鏡像上可用。

要定義我們的鏡像,請創建并打開Dockerfile在主目錄中調用的文件:

$ nano ~/Dockerfile

在這個文件中,我們使用了基于Buildbot worker的鏡像FROM buildbot/buildbot-worker:master。之后,我們可以切換到root用戶安裝Node.js,然后切換回buildbot用戶運行實際命令:

?/ Dockerfile

FROM buildbot/buildbot-worker:masterUSER root
RUN curl -sL https://deb.nodesource.com/setup_8.x | bash -
RUN apt-get install -y nodejs
USER buildbot

完成后保存并關閉文件。

一旦我們擁有了Dockerfile,我們就可以從中構建我們的鏡像。我們將調用鏡像npm-worker來明確我們安裝的額外依賴項:

$ docker build -t npm-worker - < ~/Dockerfile

Docker將根據我們在其中列出的命令開始構建您的鏡像Dockerfile。它將下拉基本鏡像及其依賴層,安裝Node.js,然后將生成的環境保存到一個名為npm-worker的鏡像中。

配置Buildbot主服務器

現在我們有了Docker鏡像,我們可以配置Buildbot主機來使用它。

因為我們正在定義一個全新的構建過程,并且因為到目前為止我們對主配置的定制很少,所以我們將從頭開始配置。為避免丟失當前信息,我們將原始文件移動到備份文件:

$ sudo mv /home/buildbot/master/master.cfg /home/buildbot/master/master.cfg.bak

顯示備份文件的配置,以便我們可以復制一些重要值以在新配置中使用:

$ sudo cat /home/buildbot/master/master.cfg.bak

我們要轉移到新配置的重要部分是用戶憑據和權限。在輸出中查找c['www']['authz']c['www']['auth']開頭的配置部分:

. . .
c['www']['authz'] = util.Authz(allowRules = [util.AnyEndpointMatcher(role="admins")],roleMatchers = [util.RolesFromUsername(roles=['admins'], usernames=['Sammy'])]
)
c['www']['auth'] = util.UserPasswordAuth({'Sammy': 'Password'})
. . .

將這些行復制并保存在某處,以便以后可以引用它們。我們將這些詳細信息添加到我們的新Buildbot主配置中,以保留我們的用戶和身份驗證設置。

現在,創建一個新master.cfg文件,我們可以在其中重新定義Buildbot實例的行為:

$ sudo nano /home/buildbot/master/master.cfg

我們將在此文件中定義新的Buildbot主配置。

設置基本項目配置

Buildbot配置文件實際上是一個Python模塊,它以犧牲一些復雜性為代價提供了極大的靈活性。

我們將從一些基本配置開始。將以下行粘貼到您的文件中:

/home/buildbot/master/master.cfg

# -*- python -*-
# ex: set filetype=python:
from buildbot.plugins import *c = BuildmasterConfig = {}# Basic config
c['buildbotNetUsageData'] = None
c['title'] = "Hello Hapi"
c['titleURL'] = "https://github.com/your_github_name/hello_hapi"
c['buildbotURL'] = "https://buildmaster_domain_name/"
c['protocols'] = {'pb': {'port': 9989}}

該文件的頂部包含一些注釋,許多文本編輯器能夠解釋這些注釋以正確應用語法高亮顯示。然后,我們從buildbot.plugins包中導入所有內容,以便我們可以使用工具來構建配置。

Buildbot配置全部由名為BuildmasterConfig的字典定義,因此我們將此變量設置為空字典以啟動。

我們創建一個名為c的速記變量,設置為同一個字,以減少整個文件中所需的輸入量。

下面的配置中需要注意的一些事項:

  • buildbotNetUsageData設置為None。如果要向開發人員報告使用情況數據,請將其更改為字符串"basic"

  • titletitleURL反映項目的名稱和GitHub的倉庫。使用指向您自己的fork的鏈接。

  • buildbotURL設置為Buildbot主服務器的SSL安全域名。記得從https://開始并以尾部斜杠/結束。

  • 與我們的上一個配置不同,該protocol定義并不會和本地主機綁定。我們需要通過Docker橋接網絡docker0允許來自Docker容器的連接。

配置Docker Worker

接下來,我們需要定義我們的Docker worker。Buildbot將根據需要使用Docker來配置工作人員。為此,它需要知道如何連接到Docker以及使用哪個映象。

將以下內容粘貼到文件的底部:

/home/buildbot/master/master.cfg

. . .# Workers
c['workers'] = []
c['workers'].append(worker.DockerLatentWorker("npm-docker-worker", None,docker_host='unix://var/run/docker.sock',image='npm-worker',masterFQDN='buildmaster_domain_name'))

c['workers'] =[]行演示了我們在完成配置時將使用的基本約定。我們將配置字典中的鍵設置為空列表。然后,我們將元素附加到列表以實現實際配置。這使我們可以在以后添加其他元素。

為了定義我們的worker,我們創建一個worker.DockerLatentWorker實例并將其追加到worker列表中。我們將此工作者命名為npm-docker-worker,以便稍后在配置中引用它。然后我們將docker_host設置為Docker的套接字位置,并提供我們創建的Docker鏡像的名稱(在我們的例子中為npm-worker)。我們將masterFQDN設置為Buildbot master的域名,以確保容器可以到達主服務器,而不管服務器的內部主機名設置如何。

配置調度程序

接下來,我們將定義一個調度程序。Buildbot使用調度程序根據從變更源或更改掛鉤收到的更改來決定何時以及如何運行構建(稍后我們將配置更改掛鉤)。

將以下配置粘貼到文件的底部:

/home/buildbot/master/master.cfg

. . .# Schedulers
c['schedulers'] = []
c['schedulers'].append(schedulers.SingleBranchScheduler(name="hello_hapi",change_filter=util.ChangeFilter(project='your_github_name/hello_hapi', branch='master'),treeStableTimer=3,builderNames=["npm"]))

我們使用相同的方法將配置附加到空列表中。在這種情況下,我們附加一個schedulers.SingleBranchScheduler實例。這允許我們在存儲庫中觀察單個分支,并簡化了配置。

我們將調度程序命名為“hello_hapi”以正確識別它。然后我們定義一個更改過濾器。來自不同來源的許多不同變更集可以交給調度程序。更改過濾器定義一組標準,用于確定此特定調度程序是否應處理相關更改。在我們的例子中,我們根據項目名稱進行過濾,這將由GitHub webhook和我們希望觀看的分支報告。

接下來,我們將treeStableTimer設置為3秒,該treeStableTimer確定等待其他更改的時間量。這有助于防止Buildbot為與密切相關的更改排隊許多小型構建。最后,我們定義當更改符合我們的條件時應該使用的構建器的名稱(我們將暫時定義此為構建器)。

為Node.js項目配置構建工廠

接下來,我們將配置一個用于處理Node.js項目的構建工廠。構建工廠負責定義構建或在我們的案例測試中應該采取的步驟。它通過定義util.BuildFactory實例然后添加應執行的順序步驟來完成此操作。

將以下內容粘貼到文件的底部:

/home/buildbot/master/master.cfg

. . .# Build Factories
npm_f = util.BuildFactory()
npm_f.addStep(steps.GitHub(repourl='git://github.com/your_github_name/hello_hapi.git', mode='full', method='clobber'))
npm_f.addStep(steps.ShellCommand(command=["npm", "install"]))
npm_f.addStep(steps.ShellCommand(command=["npm", "test"]))

首先,我們定義一個名為npm_f的構建工廠。我們添加的第一步是steps.GitHub實例。在這里,我們設置應該下拉到構建器中的存儲庫。我們設置mode“full”method“clobber”以在每次提取新代碼時完全清理我們的存儲庫。

我們添加的第二個和第三個步驟是steps.ShellCommand對象,它們定義在構建期間在存儲庫中運行的shell命令。在我們的例子中,我們需要運行npm install以收集項目的依賴項。之后,我們需要運行npm test以運行我們的測試套件。在大多數情況下,建議將命令定義為一個list (["npm","install"]),以防止shell對命令中的元素應用不需要的擴展。

配置構建器

一旦我們有一個添加了步驟的構建工廠,我們就可以設置一個構建器。構建器將我們已定義的許多元素綁定在一起,以確定構建的執行方式。

將以下配置粘貼到文件的底部:

/home/buildbot/master/master.cfg

. . .# Builders
c['builders'] = []
c['builders'].append(util.BuilderConfig(name="npm",workernames=["npm-docker-worker"],factory=npm_f))

我們將一個util.BuilderConfig對象附加到builders列表中。請記住,我們的構建工廠名為npm_f,我們的Docker工作者稱為npm-docker-worker,我們定義的調度程序將把任務傳遞給名為npm的worker。。我們的構建器定義了這些元素之間的關系,以便我們的調度程序的更改將導致構建工廠步驟在Docker worker中執行。

配置數據庫和Web界面

最后,我們可以配置數據庫和Web界面設置。與之前的許多項目不同,這兩個設置被定義為字典而不是列表。該db字典只指向/home/buildbot/master目錄中已有的state.sqlite文件。www詞典包含大量額外配置。

將以下內容粘貼到文件的底部。將您從原始Buildbot主配置中復制的身份驗證信息替換為以下身份驗證塊:

/home/buildbot/master/master.cfg

. . .# Database
c['db'] = { 'db_url': "sqlite:///state.sqlite",}# Web Interface
c['www'] = dict(port=8010, plugins=dict(waterfall_view={}, console_view={}))# Auth info copied from the original configuration
c['www']['authz'] = util.Authz(allowRules = [util.AnyEndpointMatcher(role="admins")],roleMatchers = [util.RolesFromUsername(roles=['admins'], usernames=['Sammy'])]
)
c['www']['auth'] = util.UserPasswordAuth({'Sammy': 'Password'})
# End of auth info copied from the original configuration# GitHub webhook receiver
c['www']['change_hook_dialects'] = {'github': {'secret': 'your_secret_value','strict': True,}
}

在定義數據庫設置之后,我們創建一個www字典,該字典首先定義要偵聽的端口以及要包含在Web UI中的一些視圖。接下來,我們添加從先前的Buildbot配置文件中提取的身份驗證要求。

最后,我們在www字典中定義了一個名為change_hook_dialects的字典。我們使用它來定義一個GitHub更改掛鉤,它將偵聽來自GitHub的webhook消息。為您的機密選擇一個安全密碼,GitHub將使用該密碼來驗證它將發送的消息。

完成后,保存并關閉文件。

重新啟動Buildbot Master以應用新配置

此時,我們已經完全重新配置了Buildbot主進程。我們需要重新啟動Buildbot主進程來實現更改。

在我們這樣做之前,檢查我們的文件是否有重要的語法錯誤。由于我們從頭開始重建配置,因此我們很可能會引入一些錯誤。

輸入以下命令檢查文件的語法:

$ sudo buildbot checkconfig /home/buildbot/master

該命令將報告它找到的任何問題。如果未找到任何錯誤,您將收到如下消息:

Config file is good!

如果報告了任何錯誤,請仔細閱讀錯誤消息,以便更好地了解錯誤。再次打開配置文件以嘗試解決任何問題。

如果不再出現任何錯誤,請輸入以下命令重新啟動Buildbot主服務:

$ sudo systemctl restart buildbot-master

輸入以下命令檢查操作是否成功:

$ sudo systemctl status buildbot-master
● buildbot-master.service - BuildBot master serviceLoaded: loaded (/etc/systemd/system/buildbot-master.service; enabled; vendor preset: enabled)Active: active (running) since Tue 2017-06-27 19:24:07 UTC; 2s agoMain PID: 8298 (buildbot)Tasks: 2Memory: 51.7MCPU: 1.782sCGroup: /system.slice/buildbot-master.service└─8298 /usr/bin/python /usr/local/bin/buildbot start --nodaemonJun 27 19:24:07 bb5 systemd[1]: Started BuildBot master service

如果服務能夠成功重新啟動,則會將其標記為活動狀態。

在示例存儲庫中創建GitHub Webhook

現在Buildbot配置了一個Web端點來接受GitHub webhook帖子,我們可以為我們的fork配置一個webhook。

在Web瀏覽器中,導航到示例項目存儲庫的fork:

https://github.com/your_github_user/hello_hapi

單擊“設置”選項卡以查看項目設置。在設置頁面的左側菜單中,單擊Webhooks(GitHub可能會提示您在此過程中重新輸入密碼以確認您的身份):

img項目設置

單擊右側的“ 添加webhook”按鈕以添加新的webhook。

下面的頁面將包含一個用于定義webhook的表單。在Payload URL字段中,添加項目的GitHub更改的URL。這是通過指定https://協議,然后是Buildbot master的域名,然后是/change_hook/github構建的。

將內容類型設置為application/x-www-form-urlencoded。在“密碼”字段中,輸入您在Buildbot主配置文件中選擇的秘密密碼。您可以選中“Just push”事件觸發器,勾選“Active”復選框:

img添加新的webhook

完成后,單擊“ 添加webhook”按鈕。

您將返回到項目的webhooks索引,在該索引中將顯示您的新webhook。如果刷新幾次,則應在webhook旁邊顯示綠色復選標記圖標,表示郵件已成功傳輸:

imgwebhooks索引

如果您看到紅色的X,請再次單擊webhook,然后向下滾動到Recent Deliveries部分。如果您單擊failed delivery,可以獲得有關出現問題的更多信息。

測試Webhook

現在我們已經有了webhook,我們可以測試以確保當我們對存儲庫進行更改時,Buildbot會被警告,觸發Docker中的構建,并且能夠成功執行測試套件。

在GitHub fork的主頁面中,單擊綠色“克隆或下載”按鈕左側的“ 創建新文件 ”按鈕:

img創建新文件

在隨后的屏幕上,創建dummy_file并填寫一些文本:

imgdummy_file

完成后,單擊頁面底部的“ 提交新文件”按鈕。

接下來,訪問您的Buildbot Web界面,如果您尚未通過身份驗證,請登錄。

根據您提交dummy_file到存儲庫后的時間長度,您可能會看到正在進行的構建,如下所示:

imgBuildbot 正在構建

如果構建已經完成,則它將位于“最近構建”部分中:

img構建完成

我們定義的構建器名稱“npm”用于標記構建。在該示例中,我們還可以從先前的主配置中看到較早的樣本構建器運行。

無論進度如何,單擊構建器名稱和內部版本號鏈接以訪問構建詳細信息頁面。此視圖包含有關所執行的構建的信息。我們添加到構建工廠的每個步驟都將顯示在其自己的部分中:

img構建詳細信息

如果單擊某個步驟,將顯示該命令的輸出。如果出現問題,這可以幫助調試:

img調試輸出

在上面的輸出中,我們可以驗證Buildbot是否在我們的測試套件中成功運行了三個測試。

如果構建未成功完成,您可能希望檢查的其他一些區域是構建詳細信息頁面上的其他選項卡以及/home/buildbot/master/twistd.log文件。

調整Buildbot服務

在我們完成之前,我們應該對我們的Buildbot服務進行一些調整。

目前,我們為不再使用的工作人員定義了buildbot-worker服務(我們的Docker工作程序在需要時自動啟動)。

我們應該停止并禁用old worker。

要停止正在運行的服務并禁止它在引導時啟動,請輸入:

$ sudo systemctl stop buildbot-worker
$ sudo systemctl disable buildbot-worker
Removed symlink /etc/systemd/system/buildbot-master.service.wants/buildbot-worker.service.

上面的輸出結果表明工作人員下次啟動時不會啟動。要驗證服務是否不再運行,請輸入:

$ sudo systemctl status buildbot-worker
● buildbot-worker.service - BuildBot worker serviceLoaded: loaded (/etc/systemd/system/buildbot-worker.service; disabled; vendor preset: enabled)Active: inactive (dead)Jun 27 21:12:48 bb6 systemd[1]: Started BuildBot worker service.
Jun 27 21:55:51 bb6 systemd[1]: Stopping BuildBot worker service...
Jun 27 21:55:51 bb6 systemd[1]: Stopped BuildBot worker service.

我們應該做的最后一件事是在Buildbot主服務和Docker守護進程之間建立一個soft依賴項。由于Buildbot主服務無法在沒有Docker的情況下配置new workers,因此我們應該定義此要求。

打開/ etc / systemd / system目錄中的buildbot-master.service文件以調整服務文件:

$ sudo nano /etc/systemd/system/buildbot-master.service

[Unit]部分中,將docker.service添加到network.target項之后的After指令中。添加另一個名為docker.serviceWants指令。Wants建立了一個軟依賴,而After指令建立了起始順序:

/etc/systemd/system/buildbot-master.service

[Unit]
Description=BuildBot master service
After=network.target docker.service
Wants=docker.service[Service]
User=buildbot
Group=buildbot
WorkingDirectory=/home/buildbot/master
ExecStart=/usr/local/bin/buildbot start --nodaemon[Install]
WantedBy=multi-user.target

完成后保存并關閉文件。

重新加載systemd守護程序和服務以立即應用配置:

$ sudo systemctl daemon-reload
$ sudo systemctl restart buildbot-master

現在應該在Docker可用之后啟動Buildbot主進程。

結論

在本教程中,我們將Buildbot配置為使用webhooks監聽對GitHub存儲庫的更改。收到更改后,Buildbot會根據自定義Docker鏡像啟動容器以測試新提交。Docker鏡像包含一個Buildbot工作器實例以及測試項目代碼所需的依賴項。這允許Buildbot在對存儲庫進行更改時根據需要動態啟動Buildbot worker。


參考文獻:《How To Set Up Continuous Integration with Buildbot on Ubuntu 16.04》

問答

騰訊云服務器?

相關閱讀

教你從0到1搭建小程序音視頻

教你快速搭建一場發布會直播方案

移形換影 - 短視頻色彩特效背后的故事

此文已由作者授權騰訊云+社區發布,原文鏈接:https://cloud.tencent.com/developer/article/1178239?fromSource=waitui

歡迎大家前往騰訊云+社區或關注云加社區微信公眾號(QcloudCommunity),第一時間獲取更多海量技術實踐干貨哦~

海量技術實踐經驗,盡在云加社區! https://cloud.tencent.com/developer?fromSource=waitui

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/538071.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/538071.shtml
英文地址,請注明出處:http://en.pswp.cn/news/538071.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

fedora mysql 初始化_Linux(fedora)下啟動MySQL,結果顯示:env: /etc/init.d/mysql:權限不夠。 我已經將權限切換到su了...

展開全部Linu下啟動MySQL結果顯示&#xff1a;env: /etc/init.d/mysql: 是腳e69da5e887aa62616964757a686964616f31333365646235本執行的問題解決辦法&#xff1a;依次執行下面的命令(執行失敗的話&#xff0c;檢查路徑是否正確)&#xff1a;cp /etc/init.d/mysql /etc/init.d/…

3.Android的新虛擬ART與原虛擬機DVM的區別

Android在4.2之前的虛擬機叫做 DVM 在4.2的時候多了一個虛擬機選擇&#xff0c;這是新的虛擬機 ART。Android Runingtime 那時ART還不夠成熟&#xff0c;需要測試&#xff0c;所以默認虛擬機是DVM。國內的ROM廠商直接把ART給割了。 Android5.0起&#xff0c;默認使用ART虛擬…

mysql binlog 統計_對MySQL binlog日志解析,統計每張表的DML次數

想要獲取每天數據庫每張表的DML的次數&#xff0c;統計熱度表&#xff0c;可以使用該腳本# coding:utf-8# 解析binlog&#xff0c;統計熱度表&#xff0c;表的DML個數import sysimport os# mysqlbinlog解析binlog日志def binlog_output():binlog_file sys.argv[1]file_num bi…

strapi 開源api 內容管理平臺試用

strapi 是一個開源的api && 內容管理平臺&#xff0c;功能操作起來還是比較方便簡單的。 安裝 使用docker && docker-compose 代碼clonegit clone https://github.com/strapi/strapi-docker && cd strapi-docker 啟動 docker-compose up -d 訪問 首次初…

1.android體系結構介紹

一、Android的介紹 android介紹見百度百科&#xff1a;Android的介紹&#xff0c;度娘把Android介紹的這么清楚&#xff0c;如果谷歌是Android的爹&#xff0c;那度娘就是娘了。 二、Android的架構圖 android系統主要分四層&#xff1a; 從上致下&#xff1a; 1、應用層 2、…

mysql seconds_behind_master_MySQL中的seconds_behind_master的理解

通過show slave status查看到的Seconds_Behind_Master&#xff0c;從字面上來看&#xff0c;他是slave落后master的秒數&#xff0c;一般情況下&#xff0c;也確實這樣&#xff0c;我們可以通過Seconds_Behind_Master數字查看slave是否落后于master&#xff0c;但是在一些環境中…

2.JVM和DVM之間的區別

1、JVM .java----->.class----->.jar 運行在內存的 棧 棧虛擬機 2、DVM .java----->.class------>.dex-----(加上其它資源文件)---->apk 運行在CPU的 寄存器 寄存器虛擬機 ---------------------------------------------------------- 3、DVM與JVM的區…

Node.js模塊以及模塊加載機制

2019獨角獸企業重金招聘Python工程師標準>>> Node.js中的模塊 在Node.js中&#xff0c;以模塊為單位劃分功能&#xff0c;通過一個完整的模塊加載機制使得開發人員可以將應用程序劃分為多個不同的部分。模塊的使用可以提高代碼重用率&#xff0c;提高應用程序的開發…

wordpress支持MySQL5.5_wordpress數據庫版本為5.5以上導出不能在5.5以下的版本導入的問題解決...

自從wordpress4.2版本出現以后&#xff0c;已經可以支持utf8mb4數據編碼&#xff0c;那么如果您的php空間的數據庫版本是mysql5.1的&#xff0c;那么很多站長朋友從mysql5.5導出來再導入到5.1的數據中的時候&#xff0c;那么問題來了&#xff0c;就會報錯Unknown collation ‘u…

i++與++i的區別

代碼&#xff1a; int i1; int ai;//先賦值&#xff0c;然后再自增&#xff0c;它等價于 a i ; i i 1System.out.println("a"a);System.out.println("i"i);System.out.println("---------------");int j1; int bj;//先自增&#xff0c;后賦值…

獲取數據庫名稱dbName

2019獨角獸企業重金招聘Python工程師標準>>> Autowired DataSource ds; connection ds.getConnection(); tring dbName connection.getCatalog(); connection.close(); 轉載于:https://my.oschina.net/u/2351011/blog/1925838

mysql 5.7 密碼過期_mysql5.7 密碼過期了怎么辦

mysql5.7 密碼過期了怎么辦發布時間&#xff1a;2020-05-08 14:11:09來源&#xff1a;億速云閱讀&#xff1a;148作者&#xff1a;三月下文主要給大家帶來mysql5.7 密碼過期了怎么辦&#xff0c;希望這些文字能夠帶給大家實際用處&#xff0c;這也是我編輯mysql5.7 密碼過期了怎…

我的開源項目

Android App 循環訪問網站app app介紹&#xff1a;http://blog.csdn.net/zengmingen/article/details/78016167 開源地址&#xff1a;https://gitee.com/zengmg/VistWeb

初始化bean(二)—— 緩存部分

上一篇博客&#xff0c;講了下spring如何初始化bean的 當然&#xff0c;當時只討論了很簡單的一種情況&#xff1a;初次加載bean時候&#xff0c;并且只考慮了單例。 這篇博客會試著理清楚spring在加載bean的時候的一部分緩存。關于解決循環引用所使用的緩存&#xff0c;可以看…

chkconfig: 2345 20 80

#chkconfig: 2345 20 80 2345表示系統運行級別是2&#xff0c;3&#xff0c;4或者5時都啟動此服務&#xff0c;20&#xff0c;是啟動的優先級&#xff0c;80是關閉的優先級&#xff0c;如果啟動優先級配置的數太小時如0時&#xff0c;則有可能啟動不成功&#xff0c;因為此時可…

android 按鍵上浮動畫_android – 浮動動作按鈕動畫

從Zielony的回答中,我確切地說到了我想要的地方.下面是正確應用效果的代碼.scale_fab_in.xmlandroid:duration"500"android:fromXScale"0"android:fromYScale"0"android:pivotX"50%"android:pivotY"50%"android:toXScale&qu…

性能測試調優篇---未完待續

性能測試調優一&#xff1a;1.首先&#xff0c;看下選測交易的整個走向純系統內部交易&#xff1a;選測交易如果是系統內的交易&#xff0c;每一步請求都和系統交互幾次&#xff0c;訪問了幾個數據庫&#xff0c;訪問了數據庫的那幾張表&#xff1f;&#xff1f;該交易走了那幾…

mysql連接idea詳細教程_idea配置連接數據庫的超詳細步驟

學習時&#xff0c;使用IDEA的時候&#xff0c;需要連接Database&#xff0c;連接時遇到了一些小問題&#xff0c;下面記錄一下操作流程以及遇到的問題的解決方法。一、 連接操作簡介&#xff1a;介紹如何創建連接&#xff0c;具體連接某個數據庫的操作流程。1.1 創建連接打開i…

redis單節點安裝

1、下載 redis &#xff1a;https://redis.io/ redis 提供的是 源碼包&#xff0c;需要編譯。 2、Linux下安裝gcc 和 tcl tcl介紹 命令&#xff1a;yum install gcc tcl 3、將redis的源碼包&#xff0c;放到 /usr/local/src 下 tar -zxvf redis-4.0.6.tar.gz 4、安裝redi…

Shell編程—企業生產案例

Linux系統Shell編程—企業生產案例&#xff08;一&#xff09; 企業數據庫可以說是重點保護對象啊&#xff0c;沒有之一&#xff0c;數據在當今企業里就是生命線&#xff0c;因此今天就來說一說&#xff0c;如何通過shell腳本來檢查或監控MYSQL數據庫服務是否正常&#xff1f;&…