亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

ホームページ バックエンド開発 Golang etcd の Raft 実裝を理解する: Raft ログの詳細

etcd の Raft 実裝を理解する: Raft ログの詳細

Nov 23, 2024 am 06:14 AM

導(dǎo)入

この記事では、Raft コンセンサス アルゴリズムのログから始めて、etcd の Raft の Raft ログ モジュールの設(shè)計と実裝を紹介し、分析します。目標(biāo)は、読者が etcd の Raft の実裝をより深く理解し、同様のシナリオを?qū)g裝するための可能なアプローチを提供することです。

ラフトログの概要

Raft コンセンサス アルゴリズムは、本質(zhì)的には 複製されたステート マシン であり、サーバー クラスター全體で同じ方法で一連のログを複製することを目的としています。これらのログにより、クラスター內(nèi)のサーバーが一貫した狀態(tài)に達することができます。

この文脈では、ログは Raft Log を指します。クラスター內(nèi)の各ノードには獨自の Raft ログがあり、一連のログ エントリで構(gòu)成されます。通常、ログ エントリには次の 3 つのフィールドが含まれます:

  • インデックス: ログ エントリのインデックス
  • 用語: ログエントリが作成されたときのリーダーの用語
  • データ: ログ エントリに含まれるデータ (特定のコマンドなど)。

Raft ログのインデックスは 1 で始まり、リーダー ノードのみが Raft ログを作成してフォロワー ノードに複製できることに注意することが重要です。

ログ エントリがクラスタ內(nèi)の大部分のノード (例: 2/3、3/5、4/7) に永続的に保存されている場合、そのエントリは コミット済みとみなされます。

ログ エントリがステート マシンに適用されると、それは 適用されたとみなされます。

Understanding etcd

etcd の Raft 実裝の概要

etcd raft は Go で書かれた Raft アルゴリズム ライブラリであり、etcd、Kubernetes、CockroachDB などのシステムで広く使用されています。

etcd raft の主な特徴は、Raft アルゴリズムのコア部分のみを?qū)g裝していることです。ユーザーは、Raft プロセスに関係するネットワーク送信、ディスク ストレージ、その他のコンポーネントを自分で実裝する必要があります (ただし、etcd はデフォルトの実裝を提供します)。

etcd raft ライブラリとの対話はいくぶん簡単です。どのデータを永続化する必要があるか、どのメッセージを他のノードに送信する必要があるかがわかります。あなたの責(zé)任は、ストレージおよびネットワーク送信プロセスを処理し、それに応じて通知することです。これらの操作の実裝方法の詳細には関係ありません。ユーザーが送信したデータを処理し、Raft アルゴリズムに基づいて次のステップを通知するだけです。

etcd raft のコードの実裝では、この対話モデルが Go の獨自のチャネル機能とシームレスに結(jié)合され、etcd raft ライブラリが真に特徴的なものになります。

Raft ログの実裝方法

ログとlog_unstable

etcd raft では、Raft ログの主な実裝は log.go および log_unstable.go ファイルにあり、主な構(gòu)造は raftLog で不安定です。不安定構(gòu)造も raftLog 內(nèi)のフィールドです。

  • raftLog は、Raft ログのメイン ロジックを擔(dān)當(dāng)します。ユーザーに提供されるストレージ インターフェイスを通じて、ノードのログ ストレージ狀態(tài)にアクセスできます。
  • unstable には、その名前が示すように、まだ永続化されていないログ エントリが含まれており、コミットされていないログを意味します。

etcd raft は、raftLog と不安定版を連攜させてアルゴリズム內(nèi)のログを管理します。

raftLogとunstableのコアフィールド

議論を簡単にするために、この記事では etcd raft でのスナップショットの処理については觸れず、ログ エントリの処理ロジックのみに焦點を當(dāng)てます。

type raftLog struct {
    storage Storage
    unstable unstable
    committed uint64
    applying uint64
    applied uint64
}

raftLog のコアフィールド:

  • storage: ユーザーによって実裝されたストレージ インターフェイス。すでに永続化されているログ エントリを取得するために使用されます。
  • unstable: 非永続的なログを保存します。たとえば、リーダーがクライアントからリクエストを受信すると、その用語を含むログ エントリを作成し、それを不安定なログに追加します。
  • committed: Raft 論文では commitIndex として知られており、最後にコミットされた既知のログ エントリのインデックスを表します。
  • applying: 現(xiàn)在適用されているログ エントリの最高のインデックス。
  • applied: Raft 論文では lastApplied として知られており、ステート マシンに適用されたログ エントリの最高のインデックスです。
type unstable struct {
    entries []pb.Entry
    offset uint64
    offsetInProgress uint64
}

不安定なコアフィールド:

  • entries: スライスとしてメモリに保存された、永続化されていないログ エントリ。
  • offset: エントリ內(nèi)のログ エントリを Raft ログにマッピングするために使用されます。ここで、entrys[i] = Raft Log[i offset]。
  • offsetInProgress: 現(xiàn)在永続化されているエントリを示します。進行中のエントリは、entries[:offsetInProgress-offset] で表されます。

raftLog のコア フィールドは単純であり、Raft 論文の実裝に簡単に関連付けることができます。ただし、不安定なフィールドはより抽象的に見えるかもしれません。次の例は、これらの概念を明確にすることを目的としています。

Raft ログにすでに 5 つのログ エントリが保存されていると仮定します。現(xiàn)在、不安定版に 3 つのログ エントリが保存されており、これらの 3 つのログ エントリは現(xiàn)在永続化されています。狀況は以下のとおりです。

Understanding etcd

offset=6 は、unstable.entries の位置 0、1、および 2 のログ エントリが、実際の Raft ログの位置 6 (0 6)、7 (1 6)、および 8 (2 6) に対応することを示します。 offsetInProgress=9 の場合、位置 0、1、および 2 の 3 つのログ エントリを含む不安定な.entries[:9-6] がすべて永続化されていることがわかります。

不安定版で offset と offsetInProgress が使用される理由は、不安定版ではすべての Raft ログ エントリが保存されないためです。

いつ対話するか

ここでは Raft ログ処理ロジックのみに焦點を當(dāng)てているため、ここでの「対話するタイミング」とは、ユーザーが保持する必要があるログ エントリを etcd raft が渡すタイミングを指します。

ユーザー側(cè)

etcd raft は、主に Node インターフェースのメソッドを通じてユーザーと対話します。 Ready メソッドは、ユーザーが etcd raft からデータまたは命令を受信できるようにするチャネルを返します。

type raftLog struct {
    storage Storage
    unstable unstable
    committed uint64
    applying uint64
    applied uint64
}

このチャネルから受信した Ready 構(gòu)造體には、処理が必要なログ エントリ、他のノードに送信する必要があるメッセージ、ノードの現(xiàn)在の狀態(tài)などが含まれます。

Raft Log についての説明では、Entries フィールドと CommittedEntries フィールドのみに注目する必要があります。

  • エントリ: 永続化する必要があるログ エントリ。これらのエントリが永続化されると、ストレージ インターフェイスを使用して取得できます。
  • CommittedEntries: ステート マシンに適用する必要があるログ エントリ。
type unstable struct {
    entries []pb.Entry
    offset uint64
    offsetInProgress uint64
}

Ready を介して渡されたログ、メッセージ、その他のデータを処理した後、Node インターフェイスの Advance メソッドを呼び出して、etcd raft に指示が完了したことを通知し、次の Ready を受信して??処理できるようにします。

etcd raft は、ノードのパフォーマンスをある程度向上させることができる AsyncStorageWrites オプションを提供します。ただし、ここではこのオプションは考慮しません。

etcdいかだ側(cè)面

ユーザー側(cè)では、受信した Ready 構(gòu)造體のデータを処理することに重點が置かれます。 etcd raft 側(cè)では、いつ Ready 構(gòu)造體をユーザーに渡すか、そしてその後どのようなアクションを?qū)g行するかを決定することに重點が置かれています。

このプロセスに関係する主なメソッドを次の図にまとめました。これはメソッド呼び出しの一般的なシーケンスを示しています (これは呼び出しのおおよその順序を表しているだけであることに注意してください)。

Understanding etcd

プロセス全體がループであることがわかります。ここでは、これらのメソッドの一般的な機能の概要を説明し、その後の書き込みフロー分析では、これらのメソッドが raftLog と不安定なコア フィールドでどのように動作するかを詳しく説明します。

  • HasReady: 名前が示すように、ユーザーに渡す必要がある Ready 構(gòu)造體があるかどうかをチェックします。たとえば、現(xiàn)在永続化処理中ではない、永続化されていないログ エントリが不安定版にある場合、HasReady は true を返します。
  • readyWithoutAccept: HasReady が true を返した後に呼び出されるこのメソッドは、永続化する必要があるログ エントリやコミット済みとしてマークされたログ エントリを含む、ユーザーに返される Ready 構(gòu)造體を作成します。
  • acceptReady: etcd raft が、readyWithoutAccept によって作成された Ready 構(gòu)造體をユーザーに渡した後に呼び出されます。 Ready で返されたログ エントリを永続化および適用中としてマークし、ユーザーが Node.Advance を呼び出したときに呼び出される「コールバック」を作成して、ログ エントリを永続化および適用済みとしてマークします。
  • Advance: ユーザーが Node.Advance を呼び出した後、acceptReady で作成された「コールバック」を?qū)g行します。

コミット済みと適用済みを定義する方法

ここで考慮すべき重要な點が 2 つあります:

1.永続化 ≠ コミット済み

最初に定義したように、ログ エントリは、Raft クラスタ內(nèi)の大部分のノードによって永続化されている場合にのみコミットされたとみなされます。したがって、etcd raft によって返されたエントリを Ready を通じて永続化しても、これらのエントリはまだコミット済みとしてマークできません。

ただし、Advance メソッドを呼び出して永続化ステップが完了したことを etcd raft に通知すると、etcd raft はクラスター內(nèi)の他のノード全體の永続化ステータスを評価し、一部のログ エントリをコミット済みとしてマークします。これらのエントリは、Ready 構(gòu)造體の CommittedEntries フィールドを通じて提供されるため、ステート マシンに適用できます。

したがって、etcd raft を使用する場合、エントリをコミット済みとしてマークするタイミングは內(nèi)部で管理され、ユーザーは永続性の前提條件を満たすだけで済みます。

內(nèi)部的には、コミットメントは raftLog.commitTo メソッドを呼び出すことによって達成されます。これにより、Raft ペーパーの commitIndex に対応する raftLog.committed が更新されます。

2.コミット済み ≠ 適用済み

etcd raft 內(nèi)で raftLog.commitTo メソッドが呼び出された後、raft.committed インデックスまでのログ エントリがコミットされたとみなされます。ただし、インデックスが lastApplied

エントリを適用済みとしてマークするタイミングも etcd raft の內(nèi)部で処理されます。ユーザーは、コミットされたエントリを Ready からステート マシンに適用するだけで済みます。

もう 1 つの微妙な點は、Raft ではリーダーのみがエントリをコミットできるが、すべてのノードがエントリを適用できることです。

書き込みリクエストの処理フロー

ここでは、書き込みリクエストを処理する etcd raft のフローを分析することで、これまでに説明したすべての概念を結(jié)び付けます。

初期狀態(tài)

より一般的なシナリオについて説明するために、すでに 3 つのログ エントリがコミットされ適用されている Raft ログから始めます。

Understanding etcd

この図では、は raftLog フィールドとストレージに保存されたログ エントリを表し、は不安定なフィールドとエントリに保存された永続化されていないログ エントリを表します。

3 つのログ エントリをコミットして適用したため、コミットと適用の両方が 3 に設(shè)定されます。適用フィールドには、前のアプリケーションからの最も高いログ エントリのインデックスが保持されます。この場合も 3 です。

この時點ではリクエストは開始されていないため、unstable.entries は空です。 Raft ログの次のログ インデックスは 4 で、オフセット 4 になります。現(xiàn)在永続化されているログがないため、offsetInProgress も 4 に設(shè)定されます。

リクエストを発行する

ここで、Raft ログに 2 つのログ エントリを追加するリクエストを開始します。

Understanding etcd

図に示すように、追加されたログ エントリはunstable.entriesに保存されます。この段階では、コアフィールドに記録されたインデックス値は変更されません。

準(zhǔn)備完了

HasReady メソッドを覚えていますか? HasReady は、保存されていないログ エントリがあるかどうかを確認(rèn)し、存在する場合は true を返します。

永続化されていないログ エントリの存在を判斷するロジックは、unstable.entries[offsetInProgress-offset:] の長さが 0 より大きいかどうかに基づいています。明らかに、この例では次のようになります。

type raftLog struct {
    storage Storage
    unstable unstable
    committed uint64
    applying uint64
    applied uint64
}

保持されていないログ エントリが 2 つあることを示しているため、HasReady は true を返します。

Understanding etcd

準(zhǔn)備完了なし受け入れ

readyWithoutAccept の目的は、ユーザーに返される Ready 構(gòu)造體を作成することです。 2 つの非永続ログ エントリがあるため、readyWithoutAccept は返された Ready の Entries フィールドにこれら 2 つのログ エントリを含めます。

Understanding etcd

受け入れ準(zhǔn)備完了

acceptReady は、Ready 構(gòu)造體がユーザーに渡された後に呼び出されます。

Understanding etcd

acceptReady は、永続化処理中のログ エントリのインデックスを 6 に更新します。これは、範(fàn)囲 [4, 6) 內(nèi)のログ エントリが永続化されているものとしてマークされることを意味します。

前進

ユーザーはエントリを Ready 狀態(tài)に保持した後、Node.Advance を呼び出して etcd raft に通知します。これで、etcd raft は acceptReady で作成された「コールバック」を?qū)g行できるようになります。

Understanding etcd

この「コールバック」は、unstable.entries にすでに保存されているログ エントリをクリアし、オフセットを Storage.LastIndex 1、つまり 6 に設(shè)定します。

ログエントリをコミットする

これら 2 つのログ エントリは Raft クラスター內(nèi)の大部分のノードによってすでに永続化されていると想定しているため、これら 2 つのログ エントリをコミット済みとしてマークできます。

Understanding etcd

準(zhǔn)備完了

ループを続けると、HasReady はコミットされているがまだ適用されていないログ エントリの存在を検出するため、true を返します。

Understanding etcd

準(zhǔn)備完了なし受け入れ

readyWithoutAccept は、コミットされたがステート マシンに適用されていないログ エントリ (4、5) を含む Ready を返します。

これらのエントリは、左開き、右閉じの間隔で 1、コミット 1 を適用する low、high := として計算されます。

Understanding etcd

受け入れ準(zhǔn)備完了

acceptReady は、Ready で返されたログ エントリ [4, 5] をステート マシンに適用されるものとしてマークします。

Understanding etcd

前進

ユーザーが Node.Advance を呼び出した後、etcd raft は「コールバック」を?qū)g行し、更新を 5 に適用します。これは、インデックス 5 以前のログ エントリがすべてステート マシンに適用されたことを示します。

Understanding etcd

最終狀態(tài)

これで書き込みリクエストの処理フローは完了です。最終狀態(tài)は次のようになり、初期狀態(tài)と比較できます。

Understanding etcd

まとめ

私たちは Raft Log の概要から始めて、その基本概念を理解し、続いて etcd raft 実裝について最初に見ていきました。次に、etcd raft 內(nèi)の Raft Log のコア モジュールをさらに詳しく調(diào)べ、重要な質(zhì)問について検討しました。最後に、書き込みリクエスト フローの完全な分析を通じてすべてを結(jié)び付けました。

このアプローチが etcd raft 実裝を明確に理解し、Raft ログに対する獨自の洞察を発展させるのに役立つことを願っています。

これでこの記事は終わりです。間違いや質(zhì)問がある場合は、プライベートメッセージを介してご連絡(luò)いただくか、コメントを殘してください。

ところで、raft-foiver は私が実裝した etcd raft の簡易バージョンであり、Raft のすべてのコア ロジックを保持し、Raft 論文のプロセスに従って最適化されています。このライブラリを紹介する別の記事は今後公開する予定です。ご興味がございましたら、お気軽にスター、フォーク、PR をしてください!

參照

  • https://github.com/B1NARY-GR0UP/raft
  • https://github.com/etcd-io/raft

以上がetcd の Raft 実裝を理解する: Raft ログの詳細の詳細內(nèi)容です。詳細については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國語版

SublimeText3 中國語版

中國語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Golang Frontendまたはバックエンドです Golang Frontendまたはバックエンドです Jul 08, 2025 am 01:44 AM

Golangは主にバックエンド開発に使用されますが、フロントエンドフィールドで間接的な役割を果たすこともできます。その設(shè)計目標(biāo)は、高性能、同時処理、システムレベルのプログラミングに焦點を當(dāng)てており、APIサーバー、マイクロサービス、分散システム、データベース操作、CLIツールなどのバックエンドアプリケーションの構(gòu)築に適しています。 GolangはWebフロントエンドの主流言語ではありませんが、Gopherjsを介してJavaScriptにコンパイルしたり、Tinygoを介してWebAssemblyで実行したり、テンプレートエンジンを備えたHTMLページを生成してフロントエンド開発に參加できます。ただし、最新のフロントエンド開発は、JavaScript/TypeScriptとそのエコシステムに依存する必要があります。したがって、Golangは、コアとして高性能バックエンドを備えたテクノロジースタック選択により適しています。

GolangでGraphQL APIを構(gòu)築する方法 GolangでGraphQL APIを構(gòu)築する方法 Jul 08, 2025 am 01:03 AM

GOでGraphQlapiを構(gòu)築するには、GQLGenライブラリを使用して開発効率を向上させることをお勧めします。 1.最初に、スキーマに基づいた自動コード生成をサポートするGQLGENなどの適切なライブラリを選択します。 2。次に、graphqlschemaを定義し、投稿の種類やクエリメソッドの定義など、API構(gòu)造とクエリポータルを説明します。 3。次に、プロジェクトを初期化し、基本コードを生成して、リゾルバにビジネスロジックを?qū)g裝します。 4.最後に、graphqlhandlerをhttpserverに接続し、組み込みの遊び場を介してAPIをテストします。メモには、プロジェクトのメンテナンスを確保するためのフィールドネーミング仕様、エラー処理、パフォーマンスの最適化、セキュリティ設(shè)定が含まれます

GOのインストール方法 GOのインストール方法 Jul 09, 2025 am 02:37 AM

GOをインストールするための鍵は、正しいバージョンを選択し、環(huán)境変數(shù)を構(gòu)成し、インストールを検証することです。 1.公式Webサイトにアクセスして、対応するシステムのインストールパッケージをダウンロードします。 Windowsは.msiファイルを使用し、macosは.pkgファイルを使用し、Linuxは.tar.gzファイルを使用し、 /usr /localディレクトリに解凍します。 2.環(huán)境変數(shù)を構(gòu)成し、linux/macOSで?/.bashrcまたは?/.zshrcを編集してパスとgopathを追加し、Windowsがシステムプロパティに移動するパスを設(shè)定します。 3.政府コマンドを使用してインストールを確認(rèn)し、テストプログラムを?qū)g行してhello.goを?qū)g行して、編集と実行が正常であることを確認(rèn)します。プロセス全體のパス設(shè)定とループ

GO SYNC.WAITGROUPの例 GO SYNC.WAITGROUPの例 Jul 09, 2025 am 01:48 AM

sync.waitgroupは、ゴルチンのグループがタスクを完了するのを待つために使用されます。そのコアは、3つの方法で協(xié)力することです。追加、完了、待機です。 1.ADD(n)待機するゴルチンの數(shù)を設(shè)定します。 2.done()は各ゴルチンの端で呼び出され、カウントは1つ減少します。 3.wait()すべてのタスクが完了するまでメインコルーチンをブロックします。使用する場合は、注意してください。Goroutineの外部で追加する必要があります。重複を避け、Donが呼び出されていることを確認(rèn)してください。 Deferで使用することをお勧めします。これは、Webページの同時クロール、バッチデータ処理、その他のシナリオで一般的であり、並行性プロセスを効果的に制御できます。

埋め込みパッケージチュートリアルに移動します 埋め込みパッケージチュートリアルに移動します Jul 09, 2025 am 02:46 AM

Goの埋め込みパッケージを使用すると、靜的リソースをバイナリに簡単に埋め込み、Webサービスに適しており、HTML、CSS、寫真、その他のファイルをパッケージ化できます。 1。追加する埋め込みリソースを宣言します// go:embed comment hello.txtを埋め込むなど、変數(shù)の前に埋め込みます。 2。static/*などのディレクトリ全體に埋め込み、embed.fsを介してマルチファイルパッケージを?qū)g現(xiàn)できます。 3.効率を改善するために、ビルドタグまたは環(huán)境変數(shù)を介してディスクロードモードを切り替えることをお勧めします。 4.パスの精度、ファイルサイズの制限、埋め込みリソースの読み取り専用特性に注意してください。埋め込みの合理的な使用は、展開を簡素化し、プロジェクト構(gòu)造を最適化することができます。

オーディオ/ビデオ処理に移動します オーディオ/ビデオ処理に移動します Jul 20, 2025 am 04:14 AM

オーディオとビデオ処理の中核は、基本的なプロセスと最適化方法を理解することにあります。 1.基本的なプロセスには、取得、エンコード、送信、デコード、再生が含まれ、各リンクには技術(shù)的な困難があります。 2。オーディオおよびビデオの異常、遅延、音のノイズ、ぼやけた畫像などの一般的な問題は、同期調(diào)整、コーディング最適化、ノイズ減少モジュール、パラメーター調(diào)整などを通じて解決できます。 3. FFMPEG、OPENCV、WeBRTC、GSTREAMER、およびその他のツールを使用して機能を達成することをお勧めします。 4.パフォーマンス管理の観點から、ハードウェアの加速、解像度フレームレートの合理的な設(shè)定、並行性の制御、およびメモリの漏れの問題に注意を払う必要があります。これらの重要なポイントを習(xí)得すると、開発効率とユーザーエクスペリエンスの向上に役立ちます。

GOでWebサーバーを構(gòu)築する方法 GOでWebサーバーを構(gòu)築する方法 Jul 15, 2025 am 03:05 AM

GOで書かれたWebサーバーを構(gòu)築することは難しくありません。コアは、Net/HTTPパッケージを使用して基本サービスを?qū)g裝することにあります。 1. Net/HTTPを使用して最もシンプルなサーバーを起動します。処理機能を登録し、數(shù)行のコードを介してポートをリッスンします。 2。ルーティング管理:Servemuxを使用して、構(gòu)造化された管理を容易にするために複數(shù)のインターフェイスパスを整理します。 3。共通の実踐:機能モジュールによるグループルーティング、およびサードパーティライブラリを使用して複雑なマッチングをサポートします。 4.靜的ファイルサービス:http.fileserverを介してHTML、CSS、JSファイルを提供します。 5。パフォーマンスとセキュリティ:HTTPSを有効にし、リクエスト本體のサイズを制限し、セキュリティとパフォーマンスを改善するためのタイムアウトを設(shè)定します。これらの重要なポイントを習(xí)得した後、機能を拡大する方が簡単になります。

デフォルトのケースで選択します デフォルトのケースで選択します Jul 14, 2025 am 02:54 AM

Select Plusのデフォルトの目的は、他のブランチがプログラムブロッキングを避ける準(zhǔn)備ができていない場合にデフォルトの動作を?qū)g行できるようにすることです。 1.ブロックせずにチャネルからデータを受信すると、チャネルが空の場合、デフォルトのブランチに直接入力されます。 2。時間と組み合わせて。後またはティッカー、定期的にデータを送信してみてください。チャネルがいっぱいの場合、ブロックしてスキップしません。 3.デッドロックを防ぎ、チャネルが閉じられているかどうかが不確かなときにプログラムが詰まっていることを避けます。それを使用する場合、デフォルトのブランチはすぐに実行され、亂用することはできず、デフォルトとケースは相互に排他的であり、同時に実行されないことに注意してください。

See all articles