結合開放的 API 和 Python/ target=_blank class=infotextkey>Python 編程語言的力量。
圍繞 API 創建封裝器的開源項目正變得越來越流行。這些項目使開發人員更容易與 API 交互并在他們的應用中使用它們。openshift-python-wrApper
項目是 openshift-restclient-python 的封裝器。最初是一個幫助我們的團隊使用 OpenShift API 的內部包,后來變成了一個開源項目(Apache 許可證 2.0)。
本文討論了什么是 API 封裝器,為什么它很有用,以及封裝器的一些例子。
為什么要使用 API 封裝器?
API 封裝器是位于應用和 API 之間的一層代碼。它通過將一些涉及發出請求和解析響應的復雜性抽象出來,以簡化 API 訪問過程。封裝器還可以提供 API 本身提供的功能之外的附加功能,例如緩存或錯誤處理。
使用 API 封裝器使代碼更加模塊化并且更易于維護。無需為每個 API 編寫自定義代碼,你可以使用封裝器來提供與 API 交互的一致接口。它可以節省時間,避免代碼重復,并減少出錯的機會。
使用 API 封裝器的另一個好處是它可以保護你的代碼免受 API 變化的影響。如果 API 更改了它的接口,你可以更新封裝器代碼而無需修改你的應用程序代碼。隨著時間的推移,這可以減少維護應用程序所需的工作。
安裝
該應用位于 PyPi 上,因此使用 pip 命令 安裝 openshift-python-wrapper
:
$ python3 -m pip install openshift-python-wrapper
Python 封裝器
OpenShift REST API 提供對 OpenShift 平臺的許多功能的編程訪問。封裝器提供了一個簡單直觀的界面,用于使用 openshift-restclient-python
庫與 API 進行交互。它標準化了如何使用集群資源,并提供了統一的資源 CRUD(創建、讀取、更新和刪除)流程。它還提供額外的功能,例如需要由用戶實現的特定于資源的功能。隨著時間的推移,封裝器使代碼更易于閱讀和維護。
簡化用法的一個示例是與容器交互。在容器內運行命令需要使用 Kube.NETes 流、處理錯誤等。封裝器處理這一切并提供 簡單直觀的功能。
>>> from ocp_resources.pod import Pod
>>> from ocp_utilities.infra import get_client
>>> client = get_client()
ocp_utilities.infra INFO Trying to get
client via new_client_from_config
>>> pod = Pod(client=client, name="Nginx-deployment-7fb96c846b-b48mv", namespace="default")
>>> pod.execute("ls")
ocp_resources Pod INFO Execute ls on
nginx-deployment-7fb96c846b-b48mv (ip-10-0-155-108.ec2.internal)
'binnbootndevnetcnhomenlibnlib64nmedianmntnoptnprocnrootnrunnsbinnsrvnsysntmpnusrnvarn'
開發人員或測試人員可以使用這個封裝器,我們的團隊在編寫代碼的同時牢記測試。使用 Python 的上下文管理器可以提供開箱即用的資源創建和刪除,并且可以使用繼承來擴展特定場景的功能。Pytest fixtures 可以使用代碼進行設置和拆卸,不留任何遺留物。甚至可以保存資源用于調試。可以輕松收集資源清單和日志。
這是上下文管理器的示例:
@pytest.fixture(scope="module")
def namespace():
admin_client = get_client()
with Namespace(client=admin_client, name="test-ns",) as ns:
ns.wait_for_status(status=Namespace.Status.ACTIVE, timeout=240)
yield ns
def test_ns(namespace):
print(namespace.name)
生成器遍歷資源,如下所示:
>>> from ocp_resources.node import Node
>>> from ocp_utilities.infra import get_client
>>> admin_client = get_client()
# This returns a generator
>>> for node in Node.get(dyn_client=admin_client):
print(node.name)
ip-10-0-128-213.ec2.internal
開源社區的開源代碼
套用一句流行的說法,“如果你熱愛你的代碼,就應該讓它自由。” openshift-python-wrapper
項目最初是作為 OpenShift 虛擬化 的實用模塊。隨著越來越多的項目從代碼中受益,我們決定將這些程序提取到一個單獨的倉庫中并將其開源。套用另一句俗語,“如果代碼不回到你這里,那就意味著它從未屬于你。” 一旦這種情況發生,它就真正成為了開源。