Rumah >pembangunan bahagian belakang >Tutorial Python >Cara menggunakan IO tak segerak dalam Python untuk pengaturcaraan konkurensi tinggi

Cara menggunakan IO tak segerak dalam Python untuk pengaturcaraan konkurensi tinggi

王林
王林asal
2023-10-27 10:28:411308semak imbas

Cara menggunakan IO tak segerak dalam Python untuk pengaturcaraan konkurensi tinggi

Cara menggunakan IO tak segerak dalam Python untuk pengaturcaraan serentak tinggi

Dalam era Internet hari ini, pemprosesan serentak tinggi adalah salah satu pertimbangan penting dalam banyak reka bentuk sistem. Dengan menggunakan pengaturcaraan IO tak segerak, kami boleh mengendalikan sejumlah besar permintaan serentak dan meningkatkan prestasi dan kelajuan tindak balas sistem dengan berkesan. Sebagai bahasa pengaturcaraan peringkat tinggi, Python juga menyediakan banyak perpustakaan IO tak segerak, seperti asyncio dan aiohttp, dsb., menjadikan pengaturcaraan tak segerak agak mudah.

Yang berikut akan memperkenalkan cara menggunakan IO tak segerak dalam Python untuk pengaturcaraan konkurensi tinggi, termasuk cara menggunakan perpustakaan asyncio untuk pengaturcaraan IO tak segerak dan cara menggabungkan perpustakaan aiohttp untuk mencapai permintaan rangkaian konkurensi tinggi. Kod contoh berikut adalah berdasarkan Python 3.7.

1. Konsep asas pengaturcaraan IO tak segerak

Pengaturcaraan IO tak segerak merujuk kepada melaksanakan berbilang operasi IO serentak dalam urutan tanpa menunggu selesai operasi IO sebelumnya. Berbanding dengan pengaturcaraan IO segerak tradisional, pengaturcaraan IO tak segerak boleh memberikan keupayaan konkurensi yang lebih tinggi dan overhed sistem yang lebih rendah.

Dalam pengaturcaraan IO tak segerak, operasi IO perlu diasingkan daripada tugas lain, dan operasi IO yang memakan masa diserahkan kepada sistem pengendalian untuk diproses, manakala utas utama boleh terus melaksanakan tugas lain, dengan itu meningkatkan keupayaan pemprosesan serentak daripada sistem.

2. Gunakan asyncio untuk pengaturcaraan IO tak segerak

Pustaka asyncio ialah sebahagian daripada pustaka standard Python dan boleh digunakan terus dalam Python 3.4 dan ke atas. Ia menyediakan rangka kerja pengaturcaraan tak segerak yang boleh melaksanakan operasi IO tak segerak dengan mudah.

Berikut ialah kod contoh ringkas yang menunjukkan cara menggunakan perpustakaan asyncio untuk pengaturcaraan IO tak segerak:

import asyncio

async def hello():
    print("Hello")
    await asyncio.sleep(1)  # 模拟耗时的IO操作
    print("World")

loop = asyncio.get_event_loop()
loop.run_until_complete(hello())
loop.close()

Dalam contoh ini, kami mentakrifkan fungsi tak segerak hello(), menggunakan kaedah await关键字来等待一个耗时的IO操作。asyncio.sleep(1)模拟了一个耗时1秒的IO操作。通过loop.run_until_complete(), kami menambah fungsi hello() ke dalam gelung acara dan tunggu sehingga pelaksanaannya selesai.

3. Gunakan aiohttp untuk permintaan rangkaian konkurensi tinggi

aiohttp ialah perpustakaan klien/pelayan HTTP tak segerak berdasarkan asyncio, yang boleh melaksanakan permintaan rangkaian konkurensi tinggi dengan mudah. Contoh berikut menunjukkan cara menggunakan perpustakaan aiohttp untuk melaksanakan permintaan rangkaian konkurensi tinggi:

import aiohttp
import asyncio

async def fetch(session, url):
    async with session.get(url) as response:
        return await response.text()

async def main():
    urls = [
        "http://www.example.com",
        "http://www.example.org",
        "http://www.example.net"
    ]
    async with aiohttp.ClientSession() as session:
        tasks = []
        for url in urls:
            task = asyncio.ensure_future(fetch(session, url))
            tasks.append(task)
        responses = await asyncio.gather(*tasks)
        for response in responses:
            print(response[:100])  # 打印每个URL的前100个字符

loop = asyncio.get_event_loop()
loop.run_until_complete(main())
loop.close()

Dalam contoh ini, kami mentakrifkan fetch() fungsi tak segerak untuk menghantar permintaan HTTP tak segerak ke URL yang ditentukan. Dalam fungsi main(), kami menggunakan kaedah asyncio.gather() untuk merangkum berbilang tugas tak segerak ke dalam coroutine dan menggunakan aiohttp.ClientSession() sebagai objek sesi HTTP untuk menghantar permintaan rangkaian serentak.

4. Ringkasan

Menggunakan IO tak segerak dalam Python untuk pengaturcaraan serentak tinggi boleh meningkatkan keupayaan serentak dan kelajuan tindak balas sistem. Dengan menggunakan perpustakaan seperti asyncio dan aiohttp, kami boleh melaksanakan pengaturcaraan IO tak segerak dan permintaan rangkaian konkurensi tinggi dengan mudah.

Perlu diingatkan bahawa pengaturcaraan IO tak segerak tidak sesuai untuk semua senario Jika operasi IO agak singkat atau terdapat banyak tugas pengkomputeran yang perlu dilakukan, prestasi mungkin berkurangan. Oleh itu, dalam aplikasi sebenar, anda perlu memilih sama ada untuk menggunakan pengaturcaraan IO tak segerak mengikut keperluan dan situasi tertentu.

Saya harap artikel ini dapat membantu anda memahami cara menggunakan IO tak segerak dalam Python untuk pengaturcaraan konkurensi tinggi, dan menyediakan beberapa contoh kod khusus untuk rujukan. Saya harap anda berjaya menggunakan IO tak segerak dalam aplikasi praktikal untuk meningkatkan prestasi sistem!

Atas ialah kandungan terperinci Cara menggunakan IO tak segerak dalam Python untuk pengaturcaraan konkurensi tinggi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn