โปรแกรม CI ทำ upload ไฟล์ระบบจาก gitlab ไปยังตัว server demo ด้วยภาษา Python

 

รูปภาพสัญลักษณ์ของ gitlab

 

สำหรับนักพัฒนาซอฟต์แวร์ คงจะเคยได้คำว่า GitLab หรือตัวเก็บซอร์สโค้ดที่เราได้พัฒนาขึ้นมาเก็บไว้บน Cloud เพื่อที่จะให้เพื่อนรวมงานสามารถพัฒนาต่อจากเราได้ เพื่อความสะดวก รวดเร็ว รวมไปถึงช่วยลดขั้นตอนการทำงานของทีม ตัวโปรแกรม upload ไฟล์ระบบจาก gitlab ไปยังตัว server demo ตัวนี้สามารถช่วยได้ในระดับนึ่ง ความรู้ที่ควรศึกษาก่อนนั้นจะเป็น python API เป็นส่วนใหญ่ และพวก ภาษา python พื้นฐาน เป็นต้น

อันดับแรกจะต้องมี user ของ gitlab และทำการขอ Personal Access Tokens จาก gitlab เพื่อทำการใช้ตัว API 

ขั้นตอนสามารถดูได้จากที่นี่ คลิก

เมื่อทำการขอ Personal Access Tokens เรียบร้อยแล้วให้ทำการสร้าง Project ใน pychram ขึ้นมา แล้วสร้างไฟล์ Python

จากนั้นทำการสร้างไฟล์ txt -ขึ้นมาใช้ชื่อว่า requirements.txt ให้พิมพ์คำสั่งตามนี้

requests==2.23.0
Flask==1.1.1
passlib==1.6.5
configparser==4.0.2

จากนั้นไปที่ terminal ของ pycharm พิมพ์คำสั่ง command ตามนี้เพื่อติดตั้ง library ของ python

pip install -r requirements.txt

เมื่อติตตั้งเสร็จแล้วทำการ import library เข้ามาใช้งานในไฟล์ Python ที่สร้างไว้ตอนแรก

from flask import Flask, render_template
from zipfile import ZipFile, BadZipfile

import requests, os, io, configparser, shutil

ให้ทำการสร้างไฟล์ config ขึ้นมาโดยสกุลไฟล์จะเป็น .conf จากนั้นพิมพ์คำสั่งตานนี้

[app_run]
host = < hostname >
port = < port >
debug = True

[gitlab]
git_url = < link gitlab >
private_token = < access token >
projectID_pathdemo = { < project ID >  : '< path demo >', < project ID >  : '< path demo >', < project ID >  : ['< path demo1 >', '< path demo2 >/']}

< hostname > คือ hostname ที่ติดตั้งโปรแกรม
< port > คือ port ที่ใช้
< link gitlab > คือ link gitlab ที่ใช้
< access token > คือ access token ที่ขอมาจาก gitlab
< project ID > คือ ID ของ project บน gitlab ที่ใช้
< path extension > คือ path ที่เก็บ extension บน server demo
< path demo > คือ path ของ server demo

ตัวอย่าง เช่น

[app_run]
host = 127.0.0.1
port = 5014
debug = True

[gitlab]
git_url = https://gitlab.com
private_token = Fg4ANg8jmwoH4vGHJfwi
projectID_pathdemo = { 254 : 'TEST_htmltopdf/', 38 : 'TEST_selenium/', 232 : ['TEST_htmltopdf/selenium_PHPBB/', 'TEST_selenium/selenium_PHPBB/']}

จากนั้นในไฟล์ python ให้ทำการ เพิ่มคำสั่งนี้เข้าไปเพื่อทำการเรียกใช้ไฟล์ config

config = configparser.ConfigParser()
config.read('tool_config.conf')

# ----app.run----
host = config['app_run']['host']
port = config['app_run']['port']
debug_run = config['app_run']['debug']

# ----gitlab----
git_url = config['gitlab']['git_url']
private_token = config['gitlab']['private_token']
id_pathdemo = config['gitlab']['projectID_pathdemo']

เขียนคำสั่งสร้างโฟรเดอร์เพื่อมาเก็บไฟล์ที่ดาวน์โหลดมาจาก gitlab

app = Flask(__name__)

if os.path.isdir('tmp_project') == False:
    os.mkdir('tmp_project')
    print "Directory tmp_project created successfully"
if os.path.isdir('tmp_zip') == False:
    os.mkdir('tmp_zip')
    print "Directory tmp_project created successfully"

จากนั้นทำการสร้าง method zip_dir จะทำการ extract ไฟล์ตาม projectที่เลือก

def zip_dir(directory, zipname, path_demo_project):
   if os.path.exists(directory):
      outZipFile = ZipFile(zipname, 'w')

      # The root directory within the ZIP file.
      rootdir = os.path.basename(directory)
      for dirpath, dirnames, filenames in os.walk(directory):
         for filename in filenames:
            filepath = os.path.join(dirpath, filename)
            parentpath = os.path.relpath(filepath, directory)
            arcname = os.path.join(rootdir, parentpath)
            outZipFile.write(filepath, arcname)

   outZipFile.close()
   try:
      with ZipFile(zipname, 'r') as zipObj:
         if type(path_demo_project) == list and len(path_demo_project) >1:
            for path in path_demo_project:
               zipObj.extractall(path)
         elif type(path_demo_project) == list and len(path_demo_project) == 1:
            zipObj.extractall(path_demo_project[0])
         else:
            zipObj.extractall(path_demo_project)
      zipObj.close()

      directory = directory.split("/")
      del directory[-1]
      directory = "/".join(directory)

      remove_directory = shutil.rmtree(directory)
      remove_zipname = os.remove(zipname)
      if remove_zipname == None and remove_directory == None:
         print 'remove tmp_zip & tmp_project success'
      return 'extract success'

   except (IOError, BadZipfile) as e:
      return e

ส่วน method ตัวนี้จะทำ request เพื่อที่จะขอไฟล์ระบบจาก gitlab โดยใช้ link API ของ gitlab

def request_url(id_project, path_project):
   url = git_url + '/api/v4/projects/' + str(id_project) + '/repository/archive.zip?private_token=' + private_token
   re = requests.get(url)
   z = ZipFile(io.BytesIO(re.content))
   z.extractall('tmp_project')
   pathname = z.namelist()[0]
   pathname = 'tmp_project/' + pathname

   return zip_dir(pathname, 'tmp_zip/project.zip', path_project)

คำสั่งอันนี้จะคำสั่งที่ให้ทุกส่วนทำงานตามลำดับ

@app.route('/<int:post_id>')
def index(post_id):
   id_path_dict = eval(id_pathdemo)
   if post_id in id_path_dict.keys():
      path_project = id_path_dict[post_id]
      id_project = post_id
      return request_url(id_project, path_project)
   else:
      return 'No Project ID in id_path, Chack your tool_config.conf'

โค้ดรวม

หัวเรื่อง
Python CI demo Server รวมไฟล์จาก Gitlab ขึ้น Server
หมวดหมู่
Python for work, Python for work
ฮิต
31350
ผู้สร้างเอกสาร
ae
วันที่สร้างเอกสาร
2020-05-28 06:04:28

mindphp-upload-to-demo.zip

ประเภทไฟล์ zip

ขนาดไฟล์ 1.23 KB

ผู้อัพโหลดไฟล์ Administrator

วันที่อัพโหลด 2020-05-27 22:57:38


เมื่อทำทุกอย่างเสร็จแล้วทำการรันโปรแกรม จากนั้นไปใช้คำสั่ง command บน terminal

curl http://127.0.0.1:5014/<Project ID>

ตัวอย่างเช่น

curl http://127.0.0.1:5014/254

ผลจะได้ตามนี้

 

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
เซ็นเซอร์ตรวจจับเสียง เอาไปใช้ทำอะไรได้บ้าง ทำโปรเจ็ค IOT
โดย Anonymous ส 30 ธ.ค. 2023 4:28 am บอร์ด IOT - Internet of things
2
809
ส 30 ธ.ค. 2023 10:48 pm โดย mindphp View Topic เซ็นเซอร์ตรวจจับเสียง เอาไปใช้ทำอะไรได้บ้าง ทำโปรเจ็ค IOT
มีเว็บที่เปิดเป็น localhost ใช้งานได้อยู่ มีวิธีไหนบ้างครับ ที่จะทำให้คนเข้าถึงออนไลน์ได้
โดย Anonymous ส 30 ธ.ค. 2023 4:18 am บอร์ด Programming - PHP
1
389
ส 30 ธ.ค. 2023 10:47 pm โดย mindphp View Topic มีเว็บที่เปิดเป็น localhost ใช้งานได้อยู่ มีวิธีไหนบ้างครับ ที่จะทำให้คนเข้าถึงออนไลน์ได้
ในฐานะผู้ดูแลระบบ (System Administrator) ก่อนเข้าช่วงหยุดยาว เตรียมตัวแบบนี้เพื่อให้หยุดได้อย่างไร้กังวน
โดย mindphp พฤ 28 ธ.ค. 2023 12:20 pm บอร์ด Linux - Web Server
0
609
พฤ 28 ธ.ค. 2023 12:20 pm โดย mindphp View Topic ในฐานะผู้ดูแลระบบ (System Administrator) ก่อนเข้าช่วงหยุดยาว เตรียมตัวแบบนี้เพื่อให้หยุดได้อย่างไร้กังวน
แก้ปัญหา Google Chrome เข้าหน้าเว็บไม่ได้ขึ้น ERROR SSL Key แต่ใช้ browser ตัวอื่นเข้าได้หมด
โดย mindphp พฤ 28 ธ.ค. 2023 7:11 am บอร์ด ถาม - ตอบ คอมพิวเตอร์
0
362
พฤ 28 ธ.ค. 2023 7:11 am โดย mindphp View Topic แก้ปัญหา Google Chrome เข้าหน้าเว็บไม่ได้ขึ้น ERROR SSL Key แต่ใช้ browser ตัวอื่นเข้าได้หมด
ทำไมการย้ายโดเมนมักแนะนำให้ดำเนินการก่อนหมดอายุ 30 วัน มาดูรายละเอียดกัน Domain Tranfer มีกี่ขั้นตอน
โดย mindphp พฤ 28 ธ.ค. 2023 6:54 am บอร์ด Microsoft Office Knowledge & line & Etc
0
450
พฤ 28 ธ.ค. 2023 6:54 am โดย mindphp View Topic ทำไมการย้ายโดเมนมักแนะนำให้ดำเนินการก่อนหมดอายุ 30 วัน มาดูรายละเอียดกัน Domain Tranfer มีกี่ขั้นตอน
วิธีแชร์ภาพจาก Canva ไปที่ Facebook Page
โดย vibeday พฤ 28 ธ.ค. 2023 12:42 am บอร์ด Microsoft Office Knowledge & line & Etc
0
373
พฤ 28 ธ.ค. 2023 12:42 am โดย vibeday View Topic วิธีแชร์ภาพจาก Canva ไปที่ Facebook Page
โฆษณา LINE ทางเลือกใหม่ของแบรนด์ในยุคออนไลน์
โดย admeadme พ 27 ธ.ค. 2023 3:38 pm บอร์ด Share Knowledge
0
402
พ 27 ธ.ค. 2023 3:38 pm โดย admeadme View Topic โฆษณา LINE ทางเลือกใหม่ของแบรนด์ในยุคออนไลน์
คำสั่ง SQL วิธีแปลงค่าตัวเลข เช่น 1703618219 ซึ่งเป็นค่า Unix timestamp (จำนวนวินาทีนับตั้งแต่วันที่ 1 มกราคม ค.ศ. 1970)
โดย mindphp พ 27 ธ.ค. 2023 1:12 pm บอร์ด SQL Knowledge
0
1793
พ 27 ธ.ค. 2023 1:12 pm โดย mindphp View Topic คำสั่ง SQL วิธีแปลงค่าตัวเลข เช่น 1703618219 ซึ่งเป็นค่า Unix timestamp (จำนวนวินาทีนับตั้งแต่วันที่ 1 มกราคม ค.ศ. 1970)