CentOS 6.0 初期設定


Table of Contents

はじめに

初回起動時の設定

初回起動時の設定を行います。

ライセンス情報

centos6.0_11.jpg
  • ライセンス内容を確認して同意します。

ユーザーの作成

centos6.0_12.jpg
  • hogeユーザを作成します。

日付と時刻

centos6.0_13.jpg
  • ntpを設定します。

Kdump

centos6.0_14.jpg
  • Kdumpを設定します。(メモリが少ない場合は利用できません)

vimの設定

  • viコマンドでvimを起動するようにエイリアスを追加します。
    # vi /etc/bashrc
    
    # ファイルの最後に下記1行を追加します。
    alias vi='vim'
  • vimの全体設定を変更して利用しやすくします。
    # vi /etc/vimrc
    
    # ファイルの最後に下記3行を追加します。
    set ts=4
    set nu
    autocmd FileType * set formatoptions-=ro
  • 「set ts=4」 :タブの幅をスペース4つ分に設定する
  • 「set nu」  :行番号を表示する
  • 「autocmd…」:改行時に自動でコメントを挿入しない

SSHの設定

  • 設定ファイル「/etc/ssh/sshd_config」を以下のように変更します。
    # vi /etc/ssh/sshd_config
    
    # 42行目:rootでのログインを禁止する
    PermitRootLogin no
    
    # 65行目:パスワード無しのログインを禁止する
    PermitEmptyPasswords no
    
    # 最終行に追加:ユーザhogeのみ接続許可をする(不特定多数にSSHを利用させない)
    AllowUsers hoge 

  • 設定変更を有効にするためサービスを再起動します
    # /etc/init.d/sshd restart

ファイアウォールの設定

  • 下記ポリシーに沿ってファイアウォールの設定を行います。
    • 入力パケットは全て破棄
    • 転送パケットは全て破棄
    • 出力パケットは全て許可
    • LAN(192.168.11.0/24)からのアクセスは全て許可
    • ポリシーにマッチしない通信は「/var/log/messages」に記録する

  • 上記ポリシーに従い「/etc/sysconfig/iptables」を以下のように設定します。
    # vi /etc/sysconfig/iptables
    
    *filter
    :INPUT DROP [0:0]
    :FORWARD DROP [0:0]
    :OUTPUT ACCEPT [0:0]
    -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
    -A INPUT -p icmp -j ACCEPT
    -A INPUT -i lo -j ACCEPT
    
    ##LANの許可
    -A INPUT -s 192.168.11.0/24 -j ACCEPT
    
    ##ログ記録
    -A INPUT -j LOG --log-level info --log-prefix "[iptables] "
    
    -A INPUT -j REJECT --reject-with icmp-host-prohibited
    COMMIT
・-j LOG --log-level info --log-prefix "[iptables] "
 プライオリティをinfoとしてログを記録する。記録の際、[iptables] を付加する
・-m state --state NEW -s 192.168.11.0/24 -j ACCEPT
 送信元が192.168.11.0/24のパケットは許可する
・-j REJECT --reject-with icmp-host-prohibited
 すべての入力パケットを拒絶
  • 設定を有効にするためサービスを再起動します
    # /etc/init.d/iptables restart

ipv6の無効化

  • ipv6は利用しないため無効にします。「disable_ipv6.conf」は新規で作成します。
    # vi /etc/modprobe.d/disable_ipv6.conf
    
    options ipv6 disable=1

  • 設定は再起動後に有効となるため再起動します。
    # shutdown -r now

  • ifconfigコマンドでipv6のIPアドレスが表示されなければ、問題ありません。
    # ifconfig |grep "inet6 addr"
    (何も表示されない)

不要サービスの停止

  • ntsysvコマンドを利用して不要なサービスの自動起動を停止します。
    # ntsysv --level 345
    
    
       [ ] NetworkManager
       [*] abrtd
       [ ] acpid            
       [ ] atd              
       [*] auditd           
       [ ] avahi-daemon 
       [ ] cgconfig        
       [ ] cgred           
       [*] cpuspeed         
       [*] crond            
       [ ] dnsmasq  
       [ ] firstboot 
       [ ] haldaemon        
       [ ] ip6tables        
       [*] iptables         
       [*] irqbalance       
       [ ] kdump            
       [*] lvm2-monitor     
       [*] mdmonitor        
       [*] messagebus       
       [ ] microcode_ctl 
       [ ] netconsole       
       [ ] netfs            
       [*] network          
       [*] ntpd 
       [ ] ntpdate  
       [*] postfix          
       [ ] psacct           
       [ ] rdisc            
       [ ] restorecond      
       [*] rsyslog          
       [ ] saslauthd        
       [*] smartd           
       [*] sshd             
       [*] sysstat           
       [ ] udev-post    
       [ ] wpa_supplicant
  • 今回は以下のサービスを停止しました。
    サービス名説明
    NetworkManager有線や無線のネットワーク設定がGUIで可能になります。クライアント向け機能
    acpid電源管理(Advanced Configuration and Power Interface)ノートPC以外は不要
    atd指定時刻にコマンドを実行するためのサービス
    avahi-daemonDNS サーバを使わずにIPマルチキャストで名前やアドレスを参照するサービス
    cgconfigグループ単位でプロセスのリソース使用量を制御するサービス
    cgredCgred は、/etc/cgrules.conf ファイルで設定されたパラメータに従ってタスクを cgroups に移動するデーモン
    haldaemonハードウェア情報収集サービス。messagebus を動かす必要がある。halは比較的新しい機構で、Linuxカーネルはこの仕組みを使ってデバイスを管理できるようになっている。PCI, USB, SCSIなどのバスも監視する。ホットプラグの支援も行う。
    ip6tablesIP v6 用のファイアウォール
    kdumpカーネルクラッシュダンプのサービス
    microcode_ctlIntel IA32マイクロコードの更新をできるようにするためのドライバ
    netfsNFSクライアント
    psacctアカウントの利用統計を取得する
    rdiscネットワークルータディスカバリーデーモン。ルータとして動作させないのであれば不要
    restorecondSELinux関連のデーモン。inotify(ファイルの作成や更新を監視)を使って、ファイルのラベルを自動更新する。SELinuxを使わないなら不要。
    saslauthdsasl認証サービス
    udev-postハードウェア自動認識を行うデーモン
    wpa_supplicant無線LANクライアントとしてWPAで暗号化する場合に必要なサービス


  • 自動起動の設定変更後に再起動します。これで不要サービスが停止した状態になります。
    # shutdown -r now

  • 最終的なデーモンを確認します。デーモンはSSH、postfix(ローカル配送限定)のみになります。
    # netstat -lntup
    
    Active Internet connections (only servers)
    Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name
    tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      996/sshd
    tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      1086/master
    udp        0      0 192.168.11.50:123           0.0.0.0:*                               1008/ntpd
    udp        0      0 127.0.0.1:123               0.0.0.0:*                               1008/ntpd
    udp        0      0 0.0.0.0:123                 0.0.0.0:*                               1008/ntpd

パッケージのアップデート

  • パッケージを最新版にアップデートします。
    # yum update

    yumコマンドを初めて実行する場合、 GPGキーのインポートが必要になるため以下のような警告が表示されます。
    警告: rpmts_HdrFromFdno: ヘッダ V3 RSA/SHA256 Signature, key ID c105b9de: NOKEY
    updates/gpgkey                                                                          | 3.3 kB
    Importing GPG key 0xC105B9DE "CentOS-6 Key (CentOS 6 Official Signing Key)
    <centos-6-key@centos.                   /pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

    GPGキーはRPMパッケージの正当性チェックに利用されますが、インストール直後はGPGキーがインポートされておらず、パッケージのチェックができず、警告が表示されます。
  • kernelのアップデートは再起動後に有効となるため再起動します。
    # shutdown -r now

yumの設定

  • cronで毎日5時にアップデートを実施します。アップデートログは/var/log/yum.logに記録されます。
    # crontab -e
    0 5 * * *  /usr/bin/yum -y update

システム統計情報の取得(sysstat)

システムの正常/異常を切り分けるため、sysstatでシステム統計情報を取得しておきます。

sysstatのインストール

  • sysstatが導入されていない場合はインストールします。
    # yum install sysstat
  • 主なインストールファイルは下記の通りです。
    ファイル名説明備考
    /etc/init.d/sysstat起動スクリプト
    /etc/sysconfig/sysstatシステム統計情報の保存期間、圧縮に関する設定ファイル
    /etc/cron.d/sysstatシステム統計情報の取得間隔に関する設定ファイル
    /var/log/sa/sa[日付]システム統計情報(バイナリ形式)
    /var/log/sa/sar[日付]システム統計情報(テキスト形式)

sysstatの設定

  • システム統計情報の取得頻度を5分間隔に変更します。
    # vi /etc/cron.d/sysstat
    
    
    # システム統計情報の取得間隔(デフォルトの10分間隔から5分間隔へ変更)
    */5 * * * * root /usr/lib/sa/sa1 -S DISK 1 1
    
    # システム統計情報のテキスト化
    # 1日の最後にシステム情報をテキスト化して保存します。(デフォルトの23:53)
    53 23 * * * root /usr/lib/sa/sa2 -A

  • cronを再起動します
    # /etc/init.d/crond restart

  • システム統計情報の保存期間を15日に設定します(デフォルト 7日)
    # vi /etc/sysconfig/sysstat
    
    HISTORY=15

sysstatの起動設定

  • sysstatを起動します。
    # /etc/init.d/sysstat start
    Calling the system activity data collector (sadc):

  • 自動起動の設定を行います。
    # chkconfig --add sysstat
    # chkconfig --list sysstat
    sysstat         0:off   1:off   2:on    3:on    4:off   5:on    6:off

システム統計情報の確認

  • CPUに関する統計情報
    # sar -u -f /var/log/sa/sa[日付]
  • メモリに関する統計情報
    # sar -r -f /var/log/sa/sa[日付]
  • ページングに関する統計情報を確認
    # sar -B -f /var/log/sa/sa[日付]
  • スワップに関する統計情報
    # sar -W -f /var/log/sa/sa[日付]
  • ディスクに関する統計情報
    # sar -b -f /var/log/sa/sa[日付]
  • 送受信パケットに関する統計情報
    # sar -n DEV -f /var/log/sa/sa[日付]
  • 送受信エラーパケットに関する統計情報
    # sar -n EDEV -f /var/log/sa/sa[日付]

ログ確認

  • ログにエラーが出ていない事を確認します。
    # vi /var/log/messages

以上で設定は完了です。

このエントリーをはてなブックマークに追加
Last-modified: 2011-07-25 (月) 07:39:20   最終更新のRSS