distutils: 'Ông Tổ' Đóng Gói Python - Chuyện Của Kẻ Khai Phá
Python

distutils: 'Ông Tổ' Đóng Gói Python - Chuyện Của Kẻ Khai Phá

Author

Admin System

@root

Ngày xuất bản

23 Mar, 2026

Lượt xem

2 Lượt

"distutils"

distutils: 'Ông Tổ' Đóng Gói Python - Chuyện Của Kẻ Khai Phá

Chào các chiến thần Gen Z mê code! Anh Creyt đây, hôm nay chúng ta sẽ cùng “đào mộ” một khái niệm nghe có vẻ cũ kỹ nhưng lại là nền móng vững chắc cho cả một đế chế công nghệ: distutils. Nghe tên đã thấy mùi “distribute utilities” rồi đúng không? Chính xác là vậy!

1. distutils là gì và để làm gì? (Theo hướng Gen Z)

Thế này nhé, các em cứ hình dung các em code ra một cái app Python siêu đỉnh, một thư viện cực chất, muốn khoe với cả thế giới, muốn bạn bè cài phát ăn ngay mà không cần phải copy từng file một, rồi loay hoay setup môi trường. distutils chính là cái “hộp quà đóng gói” đầu tiên mà Python cung cấp cho chúng ta để biến những dòng code rời rạc thành một “sản phẩm” hoàn chỉnh, có thể phân phối và cài đặt dễ dàng.

Nó giống như việc các em làm một chiếc bánh pizza ngon tuyệt, nhưng để mang đi tặng bạn bè thì phải có cái hộp đựng chứ. distutils chính là cái hộp đó, kèm theo cả “hướng dẫn sử dụng” (hay còn gọi là quy trình cài đặt) để người nhận có thể thưởng thức chiếc bánh một cách trọn vẹn nhất.

Nói một cách “học thuật” hơn nhưng vẫn giữ chất Gen Z: distutils là một module chuẩn của Python, được thiết kế để giúp các nhà phát triển tạo ra source distributions (các gói mã nguồn) và binary distributions (các gói đã biên dịch, ít phổ biến hơn cho Python thuần túy) của các module Python. Mục tiêu chính là chuẩn hóa quy trình đóng gói và phân phối, giúp người dùng dễ dàng cài đặt các thư viện hoặc ứng dụng Python từ mã nguồn.

2. Code Ví Dụ Minh Họa Rõ Ràng

Để đóng gói một project Python bằng distutils (hoặc setuptools, vốn là bản nâng cấp của nó), chúng ta cần một file setup.py ở thư mục gốc của project. File này sẽ chứa tất cả thông tin về project của bạn.

Giả sử chúng ta có một project đơn giản với cấu trúc sau:

my_awesome_package/
├── my_awesome_package/
│   ├── __init__.py
│   ├── core.py
│   └── utils.py
├── scripts/
│   └── run_app.py
└── setup.py

Nội dung file my_awesome_package/core.py:

def say_hello(name="World"):
    return f"Hello, {name}! This is my awesome package."

Nội dung file scripts/run_app.py:

#!/usr/bin/env python3

from my_awesome_package.core import say_hello

if __name__ == "__main__":
    print(say_hello("Genz Dev"))

Nội dung file setup.py (sử dụng setuptools để tương thích tốt hơn, vì setuptools là bản mở rộng của distutils):

from setuptools import setup, find_packages

setup(
    name='my-awesome-package',
    version='0.1.0',
    author='Creyt The Great',
    author_email='creyt@example.com',
    description='A super cool package for Gen Z developers.',
    long_description=open('README.md').read(),
    long_description_content_type='text/markdown',
    url='https://github.com/creyt/my-awesome-package',
    packages=find_packages(), # Tự động tìm các gói trong thư mục hiện tại
    scripts=['scripts/run_app.py'], # Bao gồm các script có thể chạy trực tiếp
    classifiers=[
        'Programming Language :: Python :: 3',
        'License :: OSI Approved :: MIT License',
        'Operating System :: OS Independent',
    ],
    python_requires='>=3.7',
)

Để đóng gói (tạo source distribution):

Di chuyển vào thư mục gốc của project (my_awesome_package) và chạy lệnh:

python setup.py sdist

Lệnh này sẽ tạo ra một file .tar.gz (hoặc .zip trên Windows) trong thư mục dist/. Đây chính là "hộp quà" chứa mã nguồn của bạn.

Để cài đặt gói này từ mã nguồn:

Sau khi tạo sdist, bạn có thể cài đặt nó vào môi trường Python của mình (hoặc của người khác) bằng cách:

pip install dist/my-awesome-package-0.1.0.tar.gz

Hoặc nếu bạn muốn cài đặt trực tiếp từ thư mục hiện tại (ở chế độ phát triển):

pip install -e .

Sau khi cài đặt, bạn có thể chạy script của mình từ bất cứ đâu:

run_app.py
# Output: Hello, Genz Dev! This is my awesome package.
Illustration

3. Mẹo (Best Practices) để ghi nhớ hoặc dùng thực tế

  • distutils = 'Ông Tổ': Hãy nhớ distutils là nền móng, là “ông tổ” của hệ sinh thái đóng gói Python. Nó đã đặt những viên gạch đầu tiên, sau đó setuptools đến và “nâng cấp” ngôi nhà lên nhiều tầng, thêm tiện nghi. Và giờ thì chúng ta có pip như một “shipper” chuyên nghiệp, lo việc giao nhận các gói hàng.
  • Đừng dùng trực tiếp cho project mới: Trừ khi bạn đang bảo trì một project Python siêu cổ, còn lại thì distutils đã “nghỉ hưu” rồi. Luôn luôn dùng setuptools (như ví dụ trên) hoặc các công cụ hiện đại hơn như Poetry, Flit cho các dự án mới. Chúng mang lại trải nghiệm tốt hơn, quản lý dependencies (các thư viện phụ thuộc) hiệu quả hơn.
  • Hiểu để debug: Mặc dù không dùng trực tiếp, việc hiểu distutils giúp bạn nắm vững cơ chế đóng gói của Python. Khi gặp lỗi với setuptools hoặc pip liên quan đến setup.py, kiến thức về distutils sẽ giúp bạn “hack” não và tìm ra nguyên nhân nhanh hơn.

4. Văn phong học thuật sâu của anh Creyt (Dạy dễ hiểu tuyệt đối)

Như anh đã nói, distutils ra đời trong một thời đại mà việc chia sẻ code Python còn khá thủ công. Nó giải quyết bài toán cốt lõi: làm sao để một developer có thể đóng gói mã nguồn của mình thành một định dạng chuẩn, để người khác có thể dễ dàng cài đặt và sử dụng mà không cần phải biết quá nhiều về cấu trúc nội bộ của project. Nó định nghĩa các tiêu chuẩn về cấu trúc thư mục, cách khai báo metadata (tên, phiên bản, tác giả, mô tả), và các lệnh để xây dựng (build) và phân phối (distribute) gói.

Tuy nhiên, sự phát triển của Python cùng với nhu cầu ngày càng phức tạp về quản lý dependencies, cấu hình linh hoạt hơn, và khả năng mở rộng đã khiến distutils bộc lộ những hạn chế. Đó là lý do setuptools ra đời, như một bản “fork” và mở rộng mạnh mẽ của distutils, thêm vào các tính năng như entry points (để tạo các lệnh CLI), dependency links, và khả năng tự động tìm kiếm gói (find_packages()). setuptools đã trở thành tiêu chuẩn de facto cho đóng gói Python trong nhiều năm, và nó vẫn sử dụng lại rất nhiều logic cốt lõi từ distutils.

5. Ví dụ thực tế các ứng dụng/website đã ứng dụng

Thực tế, không có một ứng dụng hay website nào “dùng distutils” theo kiểu người dùng cuối tương tác. distutils (và sau này là setuptools) là công cụ dành cho các nhà phát triển để tạo ra các thư viện và framework mà các ứng dụng/website đó sử dụng.

Ví dụ:

  • Django, Flask, NumPy, Pandas: Hầu hết các thư viện Python lớn mà các em đang dùng hàng ngày đều được đóng gói bằng setuptools (mà setuptools lại xây dựng trên nền distutils). Khi các em pip install django, pip đang tải về một gói đã được tạo ra từ setup.py của Django, và quá trình cài đặt đó gián tiếp tận dụng những nguyên lý mà distutils đã đặt ra.
  • PyPI (Python Package Index): Đây là kho chứa hàng triệu gói Python. Mỗi gói trên PyPI đều được tạo ra thông qua một quy trình đóng gói, ban đầu là distutils, sau đó là setuptools, và giờ là các công cụ hiện đại khác. distutils chính là một phần của lịch sử hình thành nên kho tàng khổng lồ này.

6. Thử nghiệm đã từng và hướng dẫn nên dùng cho case nào

Anh Creyt đã từng “sống” với distutils từ những ngày đầu Python còn “chân ướt chân ráo” chưa có pip hay setuptools mạnh mẽ như bây giờ. Hồi đó, distutils là công cụ duy nhất để anh có thể “xuất bản” những module nhỏ của mình cho bạn bè cùng dùng. Nó là một sự “giải phóng” thực sự, từ việc copy paste file thủ công sang một quy trình đóng gói có tổ chức.

Vậy, nên dùng distutils cho case nào?

  • KHÔNG NÊN DÙNG TRỰC TIẾP CHO DỰ ÁN MỚI: Anh nhấn mạnh lại lần nữa. Đối với bất kỳ dự án Python mới nào, hãy chọn setuptools (mà anh đã dùng trong ví dụ setup.py ở trên) hoặc các công cụ quản lý dự án/đóng gói hiện đại hơn như Poetry hay Flit. Chúng cung cấp nhiều tính năng hơn, quản lý dependencies tốt hơn, và tích hợp với các công cụ khác dễ dàng hơn.
  • NÊN TÌM HIỂU ĐỂ HIỂU RÕ NỀN TẢNG: Việc tìm hiểu distutils là cực kỳ quan trọng để các em có cái nhìn toàn diện về lịch sử và cách thức hoạt động của hệ sinh thái đóng gói Python. Nó giúp các em hiểu tại sao setuptools lại có những tính năng đó, và tại sao pip lại hoạt động như vậy.
  • BẢO TRÌ CÁC DỰ ÁN LEGACY: Nếu bạn là một “nhà khảo cổ học code” và phải làm việc với một dự án Python “cổ đại” mà vẫn dùng distutils thuần túy, thì việc hiểu nó là bắt buộc. Khi đó, các em sẽ phải đọc và hiểu các setup.py cũ và có thể phải nâng cấp chúng lên setuptools hoặc các công cụ mới hơn.

Tóm lại, distutils là một phần lịch sử quan trọng của Python, là “ông tổ” đã đặt nền móng cho việc đóng gói và phân phối các gói Python. Dù hiện tại nó ít khi được dùng trực tiếp, nhưng kiến thức về nó sẽ giúp các em trở thành những developer Python “thâm niên” hơn, hiểu rõ hơn về cách mọi thứ vận hành dưới lớp vỏ hào nhoáng của pip install.

Thuộc Series: Python

Bài giảng này được tự động xuất bản ngẫu nhiên từ thư viện kiến thức. Đừng quên đón xem các Từ khoá Hướng Dẫn tiếp theo nhé!

#tech #cyberpunk #laravel
Chỉnh sửa bài viết

Bình luận (0)

Vui lòng Đăng Nhập để Bình luận

Hỗ trợ Markdown cơ bản
Nguyễn Văn A
1 ngày trước

Tính năng này đỉnh quá ad ơi, chờ mãi mới thấy một blog Tiếng Việt có UI/UX xịn như vầy!