buluma.logrotate

Ansible ロール logrotate

システムに logrotate をインストールして設定します。

GitHub バージョン 問題 プルリクエスト ダウンロード
github Version Issues PullRequests Ansible Role

例のプレイブック

この例は molecule/default/converge.yml から取られており、各プッシュ、プルリクエスト、およびリリースの際にテストされています。

---
- name: Converge
  hosts: all
  become: true
  gather_facts: true

  vars:
    logrotate_frequency: daily
    logrotate_keep: 7
    logrotate_compress: true
    logrotate_entries:
      - name: example
        path: "/var/log/example/*.log"
      - name: example-frequency
        path: "/var/log/example-frequency/*.log"
        frequency: weekly
      - name: example-keep
        path: "/var/log/example-keep/*.log"
        keep: 14
      - name: example-compress
        path: "/var/log/example-compress/*.log"
        compress: true
      - name: example-copylog
        path: "/var/log/example-copylog/*.log"
        copylog: true
      - name: example-copytruncate
        path: "/var/log/example-copytruncate/*.log"
        copytruncate: true
      - name: example-delaycompress
        path: "/var/log/example-delaycompress/*.log"
        delaycompress: true
      - name: example-script
        path: "/var/log/example-script/*.log"
        postrotate: killall -HUP some_process_name
      - name: btmp
        path: /var/log/btmp
        missingok: true
        frequency: monthly
        create: true
        create_mode: "0660"
        create_user: root
        create_group: utmp
        dateext: true
        dateformat: "-%Y-%m-%d"
        keep: 1
      - name: wtmp
        path: /var/log/wtmp
        missingok: true
        frequency: monthly
        create: true
        create_mode: "0664"
        create_user: root
        create_group: utmp
        minsize: 1M
        maxsize: 128M
        dateext: true
        dateformat: "-%Y%m%d"
        keep: 1
      - name: dnf
        path: /var/log/hawkey.log
        missingok: true
        notifempty: true
        keep: 4
        frequency: weekly
        create: true
      - name: example-sharedscripts
        path: "/var/log/example-sharedscripts/*.log"
        sharedscripts: true
      - name: example-dateyesterday
        state: present
        path: "/var/log/example-dateyesterday/*.log"
        dateyesterday: true
      - name: example-absent
        state: absent

  roles:
    - role: buluma.logrotate

マシンの準備が必要です。CIでは molecule/default/prepare.yml を使用してこれを行います。

---
- name: Prepare
  hosts: all
  become: true
  gather_facts: false

  roles:
    - role: buluma.bootstrap
    - role: buluma.cron

  post_tasks:
    - name: Create log directory
      ansible.builtin.file:
        path: "{{ item }}"
        state: directory
        mode: "0755"
      loop:
        - /var/log/example
        - /var/log/example-frequency
        - /var/log/example-keep
        - /var/log/example-compress
        - /var/log/example-copylog
        - /var/log/example-copytruncate
        - /var/log/example-delaycompress
        - /var/log/example-script
        - /var/log/example-sharedscripts
        - /var/log/example-dateyesterday

    - name: Create log file
      ansible.builtin.copy:
        dest: "{{ item }}"
        content: "example"
        mode: "0644"
      loop:
        - /var/log/example/app.log
        - /var/log/example-frequency/app.log
        - /var/log/example-keep/app.log
        - /var/log/example-compress/app.log
        - /var/log/example-copylog/app.log
        - /var/log/example-copytruncate/app.log
        - /var/log/example-delaycompress/app.log
        - /var/log/example-script/app.log
        - /var/log/example-sharedscripts/app.log
        - /var/log/example-dateyesterday/app.log
        - /var/log/btmp
        - /var/log/wtmp
        - /var/log/hawkey.log

これらのロールの使用方法については、完全な説明と例も参照してください。

ロールの変数

変数のデフォルト値は defaults/main.yml に設定されています。

---
# logrotate のデフォルトファイル

# ログをローテートする頻度(daily、weekly、monthly)
logrotate_frequency: weekly

# 保存するファイルの数
logrotate_keep: 4

# ログを圧縮するか
logrotate_compress: true

# ログファイル名に日付拡張子を使用する
logrotate_dateext: false

# ローテートされたログファイルのユーザー/グループ
logrotate_user: "{{ _logrotate_user[ansible_distribution] | default(_logrotate_user['default']) }}"
logrotate_group: "{{ _logrotate_group[ansible_distribution] | default(_logrotate_group['default']) }}"

# サービスの状態を設定
logrotate_service_state: "started"
logrotate_service_enabled: true

必要条件

使用するロールの状態

以下のロールはシステムを準備するために使用されます。別の方法でシステムを準備できます。

要件 GitHub バージョン
buluma.bootstrap Ansible Molecule Version
buluma.cron Ansible Molecule Version
buluma.epel Ansible Molecule Version

コンテキスト

このロールは多くの互換性のあるロールの一部です。さらなる情報は これらのロールのドキュメント を参照してください。

関連するロールの概要は次の通りです:

依存関係

互換性

このロールは以下の コンテナイメージ でテストされています。

コンテナ タグ
Alpine all
EL 8, 9
Debian all
Fedora all
opensuse all
Ubuntu all
Kali all

Ansible の最小バージョンは 2.12 であり、以下がテストされています:

  • 前のバージョン
  • 現在のバージョン
  • 開発バージョン

問題が見つかった場合は、GitHub に登録してください。

変更履歴

ロールの履歴

ライセンス

Apache-2.0

著者情報

Shadow Walker

プロジェクトについて

Install and configure logrotate on your system.

インストール
ansible-galaxy install buluma.logrotate
ライセンス
apache-2.0
ダウンロード
67.4k
所有者
DevOps Engineer