LinuxでQoS(Quality of Service)設定を行う詳細ガイド

この記事ではLinuxでのQuality of Service(QoS)設定について解説します。具体的なコマンドとその解説、さらには応用例を多数掲載しています。

目次

QoS(Quality of Service)とは?

Quality of Service(QoS)とは、ネットワークの品質を制御するための設定やプロトコルの総称です。Linuxでは、`iptables`や`tc`コマンドを使って、細かなトラフィック制御が可能です。

なぜQoSが必要なのか

QoS設定は、ネットワークの帯域を効率的に使い、高負荷時でもパフォーマンスを保つために必要です。例えば、ビデオ通話とファイルダウンロードが同時に行われている場合、どちらにも帯域を確保する必要があります。

LinuxでのQoS設定の基本

LinuxでQoSを設定する基本的な方法は、`iptables`と`tc`コマンドを使用することです。

`iptables`による設定

`iptables`は、Linuxのファイアウォール設定ツールであり、パケットフィルタリングも行えます。

# iptablesでポート80を優先させる
sudo iptables -A PREROUTING -t mangle -p tcp --sport 80 -j TOS --set-tos Minimize-Delay

こちらのコードは、ポート80(通常のHTTP通信で使用される)に高い優先度を設定しています。

`tc`による設定

`tc`(Traffic Control)は、Linuxでトラフィックを制御するためのコマンドです。

# tcで帯域制限を設定
sudo tc qdisc add dev eth0 root handle 1: htb default 12
sudo tc class add dev eth0 parent 1: classid 1:1 htb rate 1mbit

上記のコードで、`eth0`というネットワークインターフェースに対して、1Mbpsの帯域制限がかかります。

応用例

特定のIPアドレスに優先度を与える

特定のIPアドレス(例:192.168.1.10)に対して優先度を高く設定する方法です。

# 特定のIPに優先度を与える
sudo iptables -A PREROUTING -t mangle -s 192.168.1.10 -j TOS --set-tos Maximize-Throughput

特定のプロトコルに対する帯域制限

FTP(ポート21)に対する帯域制限を設定する方法です。

# FTPに対する帯域制限
sudo tc class add dev eth0 parent 1:1 classid 1:21 htb rate 500kbit

トラフィックの監視

`tc`で設定したトラフィックを監視する方法です。

# トラフィックを監視
sudo tc -s qdisc ls dev eth0

一時的に全ての制限を解除する

すべての`tc`設定を一時的に解除する方法です。

# 一時的に制限を解除
sudo tc qdisc del dev eth0 root

特定のサービスに帯域を確保

SSH(ポート22)に帯域を確保する方法です。

# SSHに帯域を確保
sudo tc class add dev eth0 parent 1:1 classid 1:22 htb rate 2mbit

まとめ

LinuxでのQoS設定は、`iptables`と`tc`コマンドを用いて行うことができます。この記事で紹介した各設定や応用例を活用して、効率的なネットワーク環境を構築してみてください。

created by Rinker
オライリージャパン
¥3,080 (2025/01/19 00:35:17時点 Amazon調べ-詳細)

コメント

コメントする

目次