• 日本語
    • English (英語)
Avinton JapanAvinton JapanAvinton JapanAvinton Japan
  • サービス
    • Avinton Data Platform
    • エッジAIカメラ
      • 自動車ナンバープレート自動認識システム
    • プライベートクラウド
    • AIサービス開発
    • AIカメラ/画像解析無料体験版
  • 最新情報
    • ニュースリリース&イベント情報
    • 技術ブログ&インタビュー
  • アカデミー
    • Avintonアカデミー
    • Academy on Campus
    • Academy with Platform
  • 採用情報
    • Avintonジャパン 採用ページ
    • 求人一覧
    • よくある質問
    • 新卒採用
  • 企業情報
    • 会社概要
    • 代表からご挨拶
    • SDGsへの貢献
  • お問い合わせ

インフラストラクチャー(サーバー、コンポーネント、RAID)

  • ルーティング
  • データベースの命名規則
  • 三目並べ – 2.〇×を交互にゲーム盤に入るようにしよう
  • 三目並べ – 3.勝敗がつくようにしよう
  • クリーンコード(Clean Code)
  • 三目並べ – 4.「スタート」「リセット」ボタンをつけよう
  • 三目並べ – 5.先攻後攻を決めて、コンピュータ対戦にしよう(前編)
  • インフラストラクチャー(サーバー、コンポーネント、RAID)
  • 機械学習入門者向け Support Vector Machine (SVM) に触れてみる
  • YOLOv8を用いた物体検出
  • 正規表現とパイプ
  • 機械学習エンジニアに必要なスキル
  • 軽量版Kubernetesディストリビューション – k0s クラスターの構築
  • ファイル操作コマンド
  • グループとユーザー
  • 困った時に使うコマンド
  • 一般グループのユーザーとグループ
  • プライバシーポリシー
  • 三目並べ – 6.先攻後攻を決めて、コンピュータ対戦にしよう(後編)
  • フロントエンド開発のための環境構築
  • ファイル検索コマンド
  • 質問
  • 仮想化環境のディスク容量を拡張する
  • ユーザー権限とアクセス権
  • データ分析基礎 – Part1
  • 三目並べ – 0.導入
  • テキスト処理
  • データベースへのデータロード
  • 機械学習概要1
  • 機械学習入門者向け Naive Bayes(単純ベイズ)アルゴリズムに触れてみる
  • ファイル管理
  • SSHを使用してホストOSからゲストOSに接続する
  • 機械学習入門者向け ChainerRLでブロック崩しの学習
  • 機械学習入門者向け ランダムフォレストによる Kaggle Titanic生存者予測
  • 機械学習概要2
  • データ分析基礎 – Part 2
  • 機械学習入門者向け 分類と回帰の違いをプログラムを書いて学ぼう
  • フロントエンドのWeb開発について
  • ダイナミックルーティング
  • 三目並べ – 1.ゲーム盤を作ろう
  • 【Python入門】Python Numpy チュートリアル
  • Amazon EC2 インスタンスの初期設定をしよう
  • AmazonEC2とVPCでネットワークとサーバーを構築しよう
  • Apache NiFi Exercise
  • Apache NiFi データパイプライン基礎
  • Apache NiFiの環境設定
  • Apache Spark 基礎
  • Apache SparkとApache Zeppelinの概要と環境構築
  • Apache Superset maptoolの使い方
  • Apache Superset 基礎
  • Apache Superset 概要と環境構築
  • Apache Zeppelin 基本機能
  • APIのデモンストレーション
  • Avinton Academy コンテンツガイド
  • AWS CLIをインストールしてコマンド操作しよう
  • AWS CLIを使ってEC2のファイルをS3へアップロードしよう
  • AWS Route 53を使って独自ドメインのWebページを表示させてみよう
  • AWSアカウントの作成と必ずやるべきセキュリティ対策
  • AWSのEC2インスタンスでWordPressブログを公開してみよう
  • AWS入門者向け 初心者が最初に理解すべきEC2とVPCの基本的な用語解説
  • CCNA
  • Certbotを使ってSSL証明書を発行し、HTTP通信を暗号化しよう
  • CISCO 1800ルータセットアップ
  • CSV import & export – Node.js, mySQL – 1
  • CSV import & export – Node.js, mySQL – 2
  • Docker Compose(Nginx + Flask + MySQL)演習
  • Docker Engineのubuntu上へのinstall
  • Docker 概要とセットアップ
  • Docker, Kubernetesの学び方について
  • Dockerコンテナイメージの最適化/ベストプラクティス
  • DockerとApacheを使ってWebサーバーを構築しよう
  • EC2からS3へ自動でぽいぽいアップロードするスクリプトの作成
  • ESP32-CAMのサンプルアプリケーションを実行する
  • 01 – Sparkfun Inventor’s Kit の準備
  • 02 – Sparkfun Inventor’s KitでLチカ
  • 03 ポテンショメータでLEDの点滅間隔をアナログ入力する
  • 04 フォトレジスタで明るさに反応するシステムをつくる
  • 05 LCDに文字列を表示する
  • 06 – BME280とLCDを組み合わせて温度計をつくる
  • ESP32とArduino IDE/PlatfromIOでHello Worldアプリケーションの実行
  • ESP32と超音波センサー HC-SR04 で物体の距離を計測する
  • ESXi – Switchの追加とVLAN
  • ESXi – VyOS
  • ESXi – 小規模ネットワーク 構築
  • Gitとは
  • VS CodeでGitHub Copilotを設定する
  • VSCode リモート開発環境
  • GNS3のセットアップ
  • Kubernetesクラスター上へのOpenVINOモデルサーバーを使用したサンプルアプリケーションのデプロイ
  • Linuxとは
  • NAT
  • NodeJSでWebアプリケーション開発 – React編
  • NodeJSでWebアプリケーション開発 – React編
  • NodeJSでWebアプリケーション開発 – React編
  • NodeJSでWebアプリケーション開発 – Socket.IO編
  • NVIDIA Cumulus VX + GNS3でBGPネットワークのシミュレーション
  • OpenCVのテストプログラム
  • PacketTracerのセットアップ
  • Pandasによる構造化データ分析
  • PCからルータ、スイッチへのSSH接続設定
  • PostGIS exercise
  • PostgreSQL – Python – Apache – Bootstrap
  • MySQLとMySQL Workbench のセットアップ
  • PostgreSQL Setup
  • PostgreSQL – インデックスを利用したパフォーマンス改善方法
  • PostgreSQL – パーティショニングを利用したパフォーマンス改善方法
  • PostgreSQLによるデータ分析
  • postgreSQLへのshp fileのimport
  • Python2.7とOpenCVのインストール
  • Python3.8 と OpenCV のインストール (Ubuntu20.04LTS)
  • Pythonでデータベースを操作する
  • Pythonで画像を分類するプログラムを作成する
  • Pythonによるマルチスレッドプログラミング実践
  • Raspberry Pi 4B のセットアップ
  • Raspberry PiとBME280を使用して温度と湿度、気圧を読み取る
  • REDIS
  • Redux基礎 – 主要な概念と用語
  • Ruby on Rails を MySQLでセットアップ
  • Ruby on Railsによる簡単なウェブアプリケーション
  • SampleアプリケーションのKubernetes上へのデプロイ
  • Scala 基礎
  • scikit-learnとは
  • Spark SQL エクササイズ
  • SparkMLによるKaggle Titanic生存者予測
  • SparkMLによる住宅価格予測
  • SQL 便利な関数
  • Ubuntuの基本設定
  • uhubctlでUSBデバイスのオンオフをコントロール
  • Terraform入門 2 – Terraformのstate管理
  • Terraform入門 1 – TerraformでAWS上にEC2インスタンスを作成する
  • Virtualisation and Container (仮想化とコンテナ) – Ansible, Docker and Kubernetes
  • viエディタ
  • VLAN
  • VMware ESXi サーバー構築
  • Webアプリ開発に欠かせないGoogle Chrome DevToolsの基本
  • Windows Server 2012 R2 Hyper-V
  • YOLOv5を用いた物体検出
Home Avintonアカデミー インフラストラクチャー(サーバー、コンポーネント、RAID)

ITインフラストラクチャーとは、物理的なマシン、ネットワーク、オペレーティングシステム、データベース、クラウドなど多岐にわたる領域を指します。

ほとんどのサービスはITインフラストラクチャーに依存しており、これらのインフラストラクチャーが停止することはあってはいけません。もし、停止するようなことがあれば、ユーザーはサービスを利用できなくなり、(高額な)問題が発生します。

本記事では、サーバーのコンポーネントを紹介しながら、システムがバックグラウンドでどのように動作するのかを説明しています。

物理サーバー(ベアメタルサーバー)

物理サーバーには多数のハードウェアコンポーネントが含まれています。ほとんどのサーバーにはCPU、GPU、RAM、ストレージ(HDD、SSD)、電源ユニットなどの主要なコンポーネントがあります。以下がサーバーの内部です。

 

Server components

 

※ ホットスワップ:機器の電源を入れ稼動状態を保ったまま、部品やケーブルなどを交換、装着、抜去が可能。
※ ドライブベイ:コンピュータケース内にストレージ装置など内蔵型の周辺機器を収納するための場所。
※ DIMM(Dual Inline Memory Module)は、複数のDRAMチップをプリント基板上に搭載したメモリモジュールのこと。

Physical server (bare-metal server) components

仮想サーバー(仮想マシン)

仮想サーバーは、ハードウェアの構成要素をソフトウェアで実現したものです。仮想化ソフトウェアを使用すると、PCに簡単にサーバーインスタンスをデプロイできます。以下に示すように、仮想サーバーには大きく3つのタイプがあります。

Virtual Server (Virtual Machine) infrastructure

 

  • ホスト型

ホスト型では、物理マシンのホストOSに、ホスト型仮想化ソフトウェアをインストールして、仮想化ソフトウェア上に仮想マシン(ゲストOS+アプリケーション)を作成します。例)VMware Fusion、VMware Workstation Player、Oracle VM VirtualBox等。

  • 特徴:
    • ホストOSと異なるOSをゲストOSとしてインストール可能
    • 仮想化ソフトウェア以外にもホストOS側にリソースが許す限りアプリケーションを実行することが可能
    • CPU やメモリのようなハードウェアリソースへのアクセスには、ホストOSを経由する必要があるため、オーバーヘッド(余計な処理)が大きい

Oracle VM VirtualBox components

 

  • ハイパーバイザー型

ハイパーバイザー型は物理マシンにハイパーバイザー型仮想化ソフトウェアをインストールし、仮想マシンを作成します。例)VMware ESXi、Hyper-V、LinuxのKVM(Kernel-based Virtual Machine)。

  • 特徴:
    • 物理マシンのホストOSが不要
    • ハイパーバイザー型は、ホストOSを必要としないため、ホスト型よりも、オーバーヘッドが小さく、速度低下が小さい

VMWare ESXi infrastructure

 

  • コンテナ型

コンテナ型は、物理マシンのホストOSに、コンテナ管理ソフトウェア(例. Docker)をインストールします。そして、コンテナイメージ(アプリケーションやソフトウェアを実行環境とともにパッケージ化したもの)を起動することで、コンテナイメージ内のアプリケーションやソフトウェアが実行されます。

  • 特徴:
    • ゲストOS、仮想化ソフトウェアは不要
    • ホストOSのカーネルを共有し、アプリケーションレベルで環境を分離(ホスト型、ハイパーバイザー型はOSレベルの分離)
    • ゲストOSを実行する必要がないため、軽量で高速に起動可能

Containerized applications overview

仮想化やコンテナについては、こちら(Virtualisation and Container (仮想化とコンテナ))の記事が詳しいです。

サーバーのコンポーネント

Server components overview

  • CPU

中央処理装置 (CPU) は、コンピュータプログラムの指示を実行する電子回路です。CPUは、プログラムによって指示された基本的な演算、制御、および入出力 (I/O) 操作を実行します。CPUの性能を決めるパラメータの一つとして、クロック周波数(Hz)があります。クロック周波数は、CPUが1秒間に動作する回数を示します。クロック周波数が高いほどCPUの性能は向上します。また、複数のコア(CPUに内蔵しているプロセッサー)を利用することで、並列処理を可能とし性能が向上します。

コンピュータの基本動作である「フェッチ実行サイクル」において、CPUは以下のように動作します。

1. CPUは、RAMから1つずつ命令をレジスタ(CPU内部にある記憶装置)に取り込みます。プログラムカウンタ(pc)と呼ばれるレジスタがあり、プログラムカウンタ(pc)はメインメモリから次に取り出す命令のメモリアドレスを保持します。

2. CPUは、制御ユニットで命令をデコードします。

3. CPUは、演算/論理ユニットで命令を実行します。

4. 命令がなくなるまで1-3を繰り返します。

Fetch-Execute cycle of a program

 

  • GPU

グラフィックス処理装置 (GPU) は、出力用のフレームバッファ(ディスプレイに表示する画像データを一時的に保存するメモリ)における画像の作成を加速するために、迅速にメモリを操作および変更するために設計された専用の電子回路です。また、機械学習にも使用されます。マザーボードのPCIeスロットに接続されます。

  • ファン

ファンは、熱したコンポーネントを冷却するために、コンピュータ内部に取り付けられています。ファンは、外部からケースに冷たい空気を吸い込み、内部から暖かい空気を排出し、ヒートシンクを通して特定のコンポーネントを冷却するために使用されます。

  • RAM

ランダムアクセスメモリ (RAM) は、任意の順序で読み取りおよび変更できるコンピュータメモリの形式で、通常は作業データとマシンコードを格納するために使用されます。揮発性メモリ。

※ 揮発性メモリとは、電源を供給しないと記憶している情報を保持できないメモリのこと。これに対して、不揮発性メモリとは、電源を供給しなくても情報を失わない永続的な保存を可能とするメモリのこと。

  • HDD(ストレージ)

ハードディスクドライブ (HDD) は、磁気ストレージを使用してデジタルデータを格納および検索する電気機械式データストレージデバイスです。磁気ディスク(磁性体でコーティングされた1つまたは複数の高速回転する円盤(プラッタ))にデータを読み書きします。

  • SSD(ストレージ)

ソリッドステートドライブ (SSD) は、データを永続的に格納するために集積回路アセンブリ(フラッシュメモリから成る)を使用するストレージデバイスです。コンピュータストレージの階層でセカンダリストレージとして機能します。不揮発性メモリ。現在は、SATA SSDではなく、より転送速度に優れたNVMe SSDが主流です。

※SATA(Serial ATA):コンピュータにHDD、SSDを接続するためのインタフェース規格。ストレージプロトコルはAHCI(Advanced Host Controller Interface)が使用される。
※NVMe(Non-Volatile Memory Express):インターフェイス規格であるPCIe (Peripheral Component Interconnect Express, 周辺機器コンポーネント相互接続エクスプレス) でSSDに接続するためのストレージプロトコル。NVMe SSDは直接マザーボードに接続される。

  • ネットワークLANポート

ネットワークLANケーブルの接続口。

関連するキーワードとして、以下のようなものがある。

  • Ethernet: ネットワークにおいて、LAN構成する有線ネットワークの主流な通信規格。

 

  • マザーボード

電子回路基板のこと。CPU、DIMM、ストレージ、PCI、ビデオカード、電源装置など、コンピュータを構成するのに必要なパーツが接続されます。

  • 電源装置

電源装置は、コンピュータの内部コンポーネントのために、交流電源を低電圧規定された直流電源に変換します。冗長化のために、サーバーには2つのユニットを用意する場合があります。

  • RAIDコントローラー

RAIDコントローラーは、RAIDアレイを制御し、物理ディスクドライブの機能を維持するために管理するデバイスです。また、RAIDコントローラーは、RAID内のディスクが論理ユニットとして機能するように制御する働きもあります。

※RAIDコントローラーのようなハードウェアでRAIDを実現するハードウェアRAIDに対して、ソフトウェアでRAIDを実現するソフトウェアRAIDという方法もあります。

RAID controller

RAID

RAIDは、複数の物理的なディスクドライブコンポーネントを1つまたは複数の論理ユニットのように扱うことで、データの冗長性とパフォーマンスの向上を目的としたストレージ仮想化技術です。以下にいくつかの種類のRAIDを示します。

  • RAID 0

RAID 0(ストライプセットまたはストライプボリュームとも呼ばれる)は、複数のディスクに均等にデータを分割(ストライプ)します。パリティ情報(データを復元するために使われる符号)は保存されません。RAID 0は耐障害性や冗長性を提供しないため、1つのドライブが故障すると、すべてのデータが失われる危険性があります。

RAID 0 explanation

 

  • RAID 1

RAID 1は、複数のディスクにデータセットのコピー(ミラー)を書き込みます。古典的なRAID 1ミラーペアは、2つのディスクから構成されます。この構成では、データがアレイに属するすべてのディスクにミラーリングされているため、パリティやディスクスペースのストライピングはありません。

 

RAID 1 explanation

 

  • RAID 5

RAID 5は、分散パリティを持つブロックレベルのストライピングで構成されています。パリティ情報はドライブ間で分散されます。単一のドライブの故障時、分散パリティからの読み取りを計算することで、データを失うことなく次の読み取りが可能です。RAID 5には、少なくとも3つのディスクが必要です。

 

RAID 5 explanation

 

  • RAID 6

RAID 6は、別のパリティブロックを追加することでRAID5を拡張します。ブロックレベルのストライピングを使用し、2つのパリティブロックがすべてのメンバーディスクに分散されます。RAID5と同様に、RAID6ディスクアレイのレイアウトは、データブロックやパリティブロックの位置に依存して、多数存在します。

 

RAID 6 explanation

 

まとめ

今回は、物理サーバー、仮想サーバー、そして、そのサーバーのコンポーネント、RAIDについて紹介しました。ITインフラストラクチャーには、必ず物理的なマシーンがどこかに存在し、今回紹介したようなコンポーネントから構成されます。これは、昨今普及しているクラウドであっても同様です。最初に述べたように、ITサービスがITインフラストラクチャーに依存する以上、今回紹介したような内容は、ITサービスに携わるエンジニアにとって知っておくべき知識と言えるでしょう。

採用情報

採用情報

Categories

  • 相互学習
  • 採用
  • 社員インタビュー
  • 学習&資格取得
  • 技術解説
  • イベント告知
  • 学内説明会&講義
  • 産学連携
  • 就職活動
  • イベントレポート
  • その他
  • 技術ブログ&インタビュー
  • mainpage
  • New Graduates Interviews
  • 中途エンジニア
  • カテゴリーなし
  • ニュースリリース&イベント

Avinton SDGs

SDGsへの貢献

Search

タグ

ARoP C Digital Transformation DX Imagine Analysis JVCKENWOOD K0s K3s LPIC-1 Manufacturing Industry Safety Management まつもとゆきひろ イノベーターシップ イベント ウェビナー キャリア キャリアチェンジ サーバー スマートシティ スマートマニュファクチャリング セキュリティ ゼンリンデータコム データベース データ分析 ビックデータ ビックデータ プロンプトエンジニアリング マシンビジョン 中途 共創 動画 地域貢献 地域連携 教師なし学習 新卒社員 暗号化 最新技術 森部好樹 生成AI人材 真鶴町 説明会 資格 農業体験 野田真 開発者
© 2023 Avinton | All Rights Reserved | プライバシーポリシー
  • サービス
    • Avinton Data Platform
    • エッジAIカメラ
      • 自動車ナンバープレート自動認識システム
    • プライベートクラウド
    • AIサービス開発
    • AIカメラ/画像解析無料体験版
  • 最新情報
    • ニュースリリース&イベント情報
    • 技術ブログ&インタビュー
  • アカデミー
    • Avintonアカデミー
    • Academy on Campus
    • Academy with Platform
  • 採用情報
    • Avintonジャパン 採用ページ
    • 求人一覧
    • よくある質問
    • 新卒採用
  • 企業情報
    • 会社概要
    • 代表からご挨拶
    • SDGsへの貢献
  • お問い合わせ
  • 日本語
    • English (英語)
Avinton Japan