dotnet restore "%WORKSPACE%\PreventFraudAPI.Server"
dotnet build "%WORKSPACE%\PreventFraudAPI.Server"
dotnet publish "%WORKSPACE%\PreventFraudAPI.Server\PreventFraudAPI.sln" -o "E:\Publish-web\PreventFraudAPI-test\PreventFraudAPI.Server"
dotnet restore :還原。主要是尋找當(dāng)前目錄下的項(xiàng)目文件(project.json),利用NuGet庫(kù)還原整個(gè)項(xiàng)目的依賴庫(kù),并且遍歷每個(gè)目錄,生成項(xiàng)目文件,繼續(xù)還原該項(xiàng)目文件中的依賴項(xiàng)。
dotnet build :編譯應(yīng)用程序。該命令將項(xiàng)目及其依賴項(xiàng)生成為一組二進(jìn)制文件。二進(jìn)制文件包括擴(kuò)展名為 .dll 的中間語言 (IL) 文件中的項(xiàng)目代碼。
dotnet publish:發(fā)布項(xiàng)目,使可跨平臺(tái)運(yùn)行程序。Windows環(huán)境build完之后,可發(fā)布到Linux環(huán)境下運(yùn)行。
dotnet run:運(yùn)行應(yīng)用程序。
Build構(gòu)建完后,再新建“Exceute Windows batch command”,從gitlab中拉取項(xiàng)目文件配置項(xiàng)。gitlbab中進(jìn)行集中存放。將集中配置項(xiàng)文件copy到項(xiàng)目構(gòu)建后的目錄中。
配置文件操作完后,需將Jenkins平臺(tái)下已構(gòu)建完后的項(xiàng)目文件打包、同步到.NET Core服務(wù)器端的CentOS7 Server上。Windows和Linux不同平臺(tái)文件操作,這里選擇Python實(shí)現(xiàn),主要作了服務(wù)器端dotnet應(yīng)用服務(wù)操作、應(yīng)用程序備份、代碼同步等。
這里使用python下的paramiko模塊實(shí)現(xiàn)。paramiko模塊屬于第三方庫(kù),實(shí)現(xiàn)了SSHv2協(xié)議,可以在Python代碼中直接使用SSH協(xié)議對(duì)遠(yuǎn)程服務(wù)器執(zhí)行操作,而無需通過ssh命令對(duì)遠(yuǎn)程服務(wù)器進(jìn)行操作,使用前需要使用如下命令先進(jìn)行安裝:
創(chuàng)新互聯(lián)專注于企業(yè)網(wǎng)絡(luò)營(yíng)銷推廣、網(wǎng)站重做改版、石龍網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、HTML5建站、電子商務(wù)商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為石龍等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
pip install paramiko
paramiko包含兩個(gè)核心組件:SSHClient和SFTPClient。
SSHClient:類似于Linux的ssh命令,是對(duì)SSH會(huì)話的封裝,該類封裝了傳輸(Transport),通道(Channel)及SFTPClient建立的方法(open_sftp),常用于執(zhí)行遠(yuǎn)程命令。
SFTPClient:類似與Linux的sftp命令,是對(duì)SFTP客戶端的封裝,用以實(shí)現(xiàn)遠(yuǎn)程文件操作,如文件上傳、下載、修改文件權(quán)限等操作。
這里根據(jù)實(shí)際需求,使用了SSHClient這個(gè)組件。
Python代碼細(xì)節(jié)如下:
import sys
import paramiko
class SSHconnection(object):
def __init__(self, host, port, username, password):
self._host = host
self._port = port
self._username = username
self._password = password
self._transport = None
self._client = None
self._connect()
#建立connect連接
def _connect(self):
transport = paramiko.Transport((self._host, self._port))
transport.connect(username=self._username, password=self._password)
self._transport = transport
def exec_command(self, command, step):
if self._client is None:
self._client = paramiko.SSHClient()
self._client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
self._client._transport = self._transport
stdin, stdout, stderr = self._client.exec_command(command)
data = stdout.read()
print('%s 執(zhí)行結(jié)果: ' % step)
print(data.decode('utf-8'))
# #輸出結(jié)果
# if len(data) > 0:
# print('執(zhí)行結(jié)果:')
# print(data.decode('utf-8'))
err = stderr.read()
#輸出錯(cuò)誤結(jié)果
if len(err) > 0:
print('%s 執(zhí)行的錯(cuò)誤輸出:' % step)
print(err.decode('utf-8'))
#關(guān)閉close連接
def close(self):
if self._transport:
self._transport.close()
if self._client:
self._client.close()
if __name__=="__main__":
host = "10.10.10.75"
port = 65089
username = "root"
password = "password"
cmd_stop = "systemctl stop supervisor"
cmd_backup = "cp -r /usr/soft/package/HiCore.PreventFraudAPI.Web/ /usr/soft/backup/HiCore.PreventFraudAPI.Web-`date +%Y-%m-%d-%H:%M`"
cmd_rsync = "rsync -vzrtopg --no-super --numeric-ids --progress --port=873 --password-file=/opt/scripts/passwd.sh rsync_user@10.10.10.69::PreventFraudAPI-test /usr/soft/package/HiCore.PreventFraudAPI.Web/"
cmd_start = "systemctl start supervisor"
conn = SSHconnection(host, port, username, password)
print('開始停supervisor服務(wù)...')
conn.exec_command(cmd_stop, 'supervisor_stop_service')
print('開始備份本地PreventFraudAPI程序...')
conn.exec_command(cmd_backup, 'backup_app')
print('開始同步PreventFraudAPI程序...')
conn.exec_command(cmd_rsync, 'rsync_app')
print('開始啟supervisor服務(wù)...')
conn.exec_command(cmd_start, 'supervisor_start_service')
print('PreventFraudAPI程序發(fā)布完成,請(qǐng)驗(yàn)證!')
同理,Job-B操作跟Job-A一樣。主要是Job-C有差異,Job配置中有帶參數(shù)。
4) 新建Job-C
列出Job中主要設(shè)置項(xiàng)。
選擇“This project is parameterized”,添加參數(shù)選擇“Choice Parameter”,配置如下:
根據(jù)選擇的參數(shù)觸發(fā)遠(yuǎn)程Job構(gòu)建。如選擇選項(xiàng)"Web"觸發(fā)遠(yuǎn)程Job-A構(gòu)建,選擇選項(xiàng)"File"觸發(fā)遠(yuǎn)程Job-B構(gòu)建。
構(gòu)建build:
build構(gòu)建步驟選擇新建“Exceute Windows batch command”,如下圖:
import jenkins
jenkins_server_url = 'http://jenkins.hicore.local/'
user = 'yuhuanghui'
api_token= '11f6714b10b086b9165ed507dd2f5e161a'
#實(shí)例化jenkins對(duì)象,連接遠(yuǎn)程的jenkins server
server = jenkins.Jenkins(jenkins_server_url,username=user,password=api_token)
print(server)
#構(gòu)建job
server.build_job('PreventFraudAPI-test')
#查看某個(gè)job的構(gòu)建信息
job_info=server.get_job_info('PreventFraudAPI-test')
print(job_info)
這里就不更換python版本了,其他Job用到的python都是Python3,所以用另一種API方式JenkinsApi 。
2) JenkinsApi
使用JenkinsApi方式需要導(dǎo)入from jenkinsapi.jenkins import Jenkins、from jenkinsapi.build import Build模塊。
上面Job-C中的python腳本:
import os,sys
from jenkinsapi.jenkins import Jenkins
from jenkinsapi.build import Build
def get_server_instance():
jenkins_url = 'http://10.10.10.69:8080/'
server = Jenkins(jenkins_url, username='xiaoming', password='password')
return server
server = get_server_instance()
#版本
print('Jenkins版本:',server.version)
#所有的job列表
#print('Jobs:', server.keys())
print('查看Jobs列表:',server.get_jobs_list())
#判斷job是否存在,存在返回true,不存在返回false。
Web_Job = server.has_job('PreventFraud-test')
File_Job = server.has_job('PreventFraudFile-test')
env = os.getenv("ENV")
print('選擇發(fā)布構(gòu)建的應(yīng)用是:', env)
if env == 'Web':
print('開始Build構(gòu)建PreventFraud-Web項(xiàng)目!')
if Web_Job == True:
#獲取job名稱
job = server.get_job('PreventFraud-test')
print('要Build構(gòu)建的job是:', job)
#構(gòu)建,無參數(shù)的構(gòu)建
#params = {'Branch': 'oriin/master', 'host': '192.168.1.1'}
res = server.build_job('PreventFraud-test')
print('開始觸發(fā)遠(yuǎn)程Job的構(gòu)建,請(qǐng)查看遠(yuǎn)程Job:%s' % job)
print(res)
#print(job.__dict__['_data']['builds'])
url = job.__dict__['_data']['lastBuild']['url']
number = job.__dict__['_data']['lastBuild']['number']
obj = Build(url, number, job)
print('此次構(gòu)建的Job名稱:%s,Job的URL是:%s, 是第 %d 次構(gòu)建。' % (job, url, number))
print('構(gòu)建的結(jié)果:', obj.get_status())
else:
print('要構(gòu)建的Job不存在,請(qǐng)檢查!')
elif env == 'File':
print('開始Build構(gòu)建PreventFraud-File項(xiàng)目!')
if File_Job == True:
#獲取job名稱
job = server.get_job('PreventFraudFile-test')
print('要遠(yuǎn)程觸發(fā)Build構(gòu)建的job是:', job)
#構(gòu)建,無參數(shù)的構(gòu)建
#params = {'Branch': 'oriin/master', 'host': '192.168.1.1'}
res = server.build_job('PreventFraudFile-test')
print('開始觸發(fā)遠(yuǎn)程Job的構(gòu)建,請(qǐng)查看遠(yuǎn)程Job:%s' % job)
print(res)
#print(job.__dict__['_data']['builds'])
url = job.__dict__['_data']['lastBuild']['url']
number = job.__dict__['_data']['lastBuild']['number']
obj = Build(url, number, job)
print('此次構(gòu)建的Job名稱:%s,Job的URL是:%s, 是第 %d 次構(gòu)建。' % (job, url, number))
print('構(gòu)建的結(jié)果:', obj.get_status())
else:
print('要構(gòu)建的Job不存在,請(qǐng)檢查!')
else:
print('請(qǐng)選擇正確ENV環(huán)境項(xiàng)目!')