古典的なコンピューティングモデルであるデータフロープログラミングは、Webスケールのリアルタイムサービスの急増のおかげで、リバイバルを経験しています。その固有のシンプルさ、スケーラビリティ、およびリソース効率により、多くのエンジニアリングの課題に最適です。 Node.jsフレームワークであるStrawは、元々リアルタイムの財務データ処理用に設計されており、控えめなハードウェアで毎秒数千のメッセージを処理できるデータフロー実装を容易にします。
ストロー構造コードは相互接続ノードにコードを作成します。各ノードは入力を受信し、それを処理し、結果を出力します。このモジュラー設計により、複雑な問題が簡素化され、スケーラビリティと回復力が向上します。この記事では、Twitterの消防符のマイニングでのアプリケーションをツイートデータのアプリケーションを詳述することにより、Strawの機能を示しています。 このプロセスでは、ノードを設定して、生データを摂取し、分析を実行し、リアルタイムの視覚化のためにWebSocketsを介してExpressサーバーとクライアントに結果を配布します。
ストローとヘイスタックの紹介
ストローは、それぞれが入力とゼロ以上の出力を備えたノードのトポロジを定義します。 ノードは、ユーザー定義の関数を使用して受信メッセージを処理し、接続されたノードの出力メッセージを生成します。 サンプルアプリケーションであるHayStackには、消防ホースからの生データ消費のためのノード、分析のためのデータルーティング、および分析ノード自体が含まれます。データは、WebSocketsを介してExpressサーバーとクライアントに中継されます。 フォローするには、Haystackをローカルにインストールします。 RedisとBowerは前提条件です。 バウアーインストール:。 Haystackのクローニングとセットアップ:
npm install -g bower
git clone https://github.com/simonswain/haystack cd haystack npm install bower install
Twitter Firehoseにアクセスするには、Twitterアプリを作成して取得したAPI資格情報が必要です(許可のみを読む)。 [APIキー]タブから、
、、およびconsumer_key
を取得します。 資格情報を使用して、HayStackのサンプル構成ファイル(consumer_secret
)を更新します
access_token_key
2つの別々の端子を使用してhaystackを実行します。1つはStrawトポロジ(access_token_secret
。config.js
exports.twitter = { consumer_key: '{your consumer key}', consumer_secret: '{your consumer secret}', access_token_key: '{your access token key}', access_token_secret: '{your access token secret}' };
node run
node server.js
わらのトポロジー(run.js)http://localhost:3000
わらのトポロジーを定義します。 ノードとその接続はオブジェクトで指定されています。 たとえば、
ノードはディレクトリにあります。
(入力なし)メッセージを導入します。選択的なメッセージルーティングの複数の出力を示します。run.js
var topo = new straw.topology({ 'consume-firehose': { 'node': __dirname + '/nodes/consume-firehose.js', 'output': 'raw-tweets', 'twitter': config.twitter }, 'route-tweets': { 'node': __dirname + '/nodes/route-tweets.js', 'input': 'raw-tweets', 'outputs': { 'geo': 'client-geo', 'lang': 'lang', 'text': 'text' } }, // ... more nodes });例ノードの例(Consume-firehose.jsおよびroute-tweets.js)
nodes
consume-firehose
route-tweets
:
:
git clone https://github.com/simonswain/haystack cd haystack npm install bower install
キャッチラングノード(言語集約用)
catch-langs
言語カウントを集約し、圧倒的なクライアントを避けるために定期的に合計を放出します。 setInterval
を使用して、排出を制御し、言語数の増加を制御し、変更が発生したときに合計を放出します。
Express Server(server.js)およびクライアント側の視覚化(haystack.js)
expressとsocket.io(またはsockjs)を使用して、a server.js
を使用してストローからのWebインターフェイスとストリーミングデータを提供します。 クライアントサイド(straw.tap
)は、このデータを受信して視覚化します
public/js/haystack.js
Haystackは、リアルタイムデータストリームのデータフロー処理を例示しています。 Strawの固有の並列性とモジュール性は、複雑なタスクを簡素化します。 ノードと視覚化を追加してヘイスタックを拡張します。
データフロープログラミングに関するよくある質問(FAQ)以上がストローによるデータフロープログラミングの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScriptは、Webサイト、モバイルアプリケーション、デスクトップアプリケーション、サーバー側のプログラミングで広く使用されています。 1)Webサイト開発では、JavaScriptはHTMLおよびCSSと一緒にDOMを運用して、JQueryやReactなどのフレームワークをサポートします。 2)ReactNativeおよびIonicを通じて、JavaScriptはクロスプラットフォームモバイルアプリケーションを開発するために使用されます。 3)電子フレームワークにより、JavaScriptはデスクトップアプリケーションを構築できます。 4)node.jsを使用すると、JavaScriptがサーバー側で実行され、高い並行リクエストをサポートします。

Pythonはデータサイエンスと自動化により適していますが、JavaScriptはフロントエンドとフルスタックの開発により適しています。 1. Pythonは、データ処理とモデリングのためにNumpyやPandasなどのライブラリを使用して、データサイエンスと機械学習でうまく機能します。 2。Pythonは、自動化とスクリプトにおいて簡潔で効率的です。 3. JavaScriptはフロントエンド開発に不可欠であり、動的なWebページと単一ページアプリケーションの構築に使用されます。 4. JavaScriptは、node.jsを通じてバックエンド開発において役割を果たし、フルスタック開発をサポートします。

CとCは、主に通訳者とJITコンパイラを実装するために使用されるJavaScriptエンジンで重要な役割を果たします。 1)cは、JavaScriptソースコードを解析し、抽象的な構文ツリーを生成するために使用されます。 2)Cは、Bytecodeの生成と実行を担当します。 3)Cは、JITコンパイラを実装し、実行時にホットスポットコードを最適化およびコンパイルし、JavaScriptの実行効率を大幅に改善します。

現実世界でのJavaScriptのアプリケーションには、フロントエンドとバックエンドの開発が含まれます。 1)DOM操作とイベント処理を含むTODOリストアプリケーションを構築して、フロントエンドアプリケーションを表示します。 2)node.jsを介してRestfulapiを構築し、バックエンドアプリケーションをデモンストレーションします。

Web開発におけるJavaScriptの主な用途には、クライアントの相互作用、フォーム検証、非同期通信が含まれます。 1)DOM操作による動的なコンテンツの更新とユーザーインタラクション。 2)ユーザーエクスペリエンスを改善するためにデータを提出する前に、クライアントの検証が実行されます。 3)サーバーとのリフレッシュレス通信は、AJAXテクノロジーを通じて達成されます。

JavaScriptエンジンが内部的にどのように機能するかを理解することは、開発者にとってより効率的なコードの作成とパフォーマンスのボトルネックと最適化戦略の理解に役立つためです。 1)エンジンのワークフローには、3つの段階が含まれます。解析、コンパイル、実行。 2)実行プロセス中、エンジンはインラインキャッシュや非表示クラスなどの動的最適化を実行します。 3)ベストプラクティスには、グローバル変数の避け、ループの最適化、constとletsの使用、閉鎖の過度の使用の回避が含まれます。

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

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

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター
