buluma.varnish

Ansibleロール varnish

Linux向けのVarnishです。

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

サンプルプレイブック

以下のサンプルは molecule/default/converge.yml から取られ、各プッシュ、プルリクエスト、およびリリースでテストされます。

---
- name: Converge
  hosts: all
  become: true
  gather_facts: true
  vars:
    varnish_apt_use_packagecloud: false

  pre_tasks:
    - name: aptキャッシュを更新。
      apt: update_cache=yes cache_valid_time=600
      when: ansible_os_family == 'Debian'
      changed_when: false

    - name: python3.11のEXTERNALLY-MANAGEDファイルが存在するか確認
      ansible.builtin.stat:
        path: /usr/lib/python3.11/EXTERNALLY-MANAGED
      register: externally_managed_file_py311

    - name: python3.11のEXTERNALLY-MANAGEDファイルが存在する場合は名前を変更
      ansible.builtin.command:
        cmd: mv /usr/lib/python3.11/EXTERNALLY-MANAGED /usr/lib/python3.11/EXTERNALLY-MANAGED.old
      when: externally_managed_file_py311.stat.exists
      args:
        creates: /usr/lib/python3.11/EXTERNALLY-MANAGED.old

    - name: python3.12のEXTERNALLY-MANAGEDファイルが存在するか確認
      ansible.builtin.stat:
        path: /usr/lib/python3.12/EXTERNALLY-MANAGED
      register: externally_managed_file_py312

    - name: python3.12のEXTERNALLY-MANAGEDファイルが存在する場合は名前を変更
      ansible.builtin.command:
        cmd: mv /usr/lib/python3.12/EXTERNALLY-MANAGED /usr/lib/python3.12/EXTERNALLY-MANAGED.old
      when: externally_managed_file_py312.stat.exists
      args:
        creates: /usr/lib/python3.12/EXTERNALLY-MANAGED.old

  roles:
    - role: buluma.systemd
      systemd_default_target: multi-user.target
    - role: buluma.httpd
    - role: buluma.varnish

マシンを準備する必要があります。CIでは、molecule/default/prepare.yml を使って行います。

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

  roles:
    - role: buluma.bootstrap

  tasks:
    - name: aptキャッシュを更新。
      ansible.builtin.apt: update_cache=true cache_valid_time=600
      when: ansible_os_family == 'Debian'

    - name: ビルド依存関係がインストールされていることを確認。
      ansible.builtin.yum:
        name:
          - logrotate
          - systemd-sysv
        state: present
      when: ansible_os_family == 'RedHat'

    - name: curlがインストールされていることを確認。
      ansible.builtin.package: name=curl state=present

これらのロールの使い方については、完全な説明とサンプルを参照してください。

ロール変数

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

---
varnish_package_name: "varnish"
varnish_modules_package_name: ""
varnish_version: "7.5"

varnish_use_default_vcl: true
varnish_default_vcl_template_path: default.vcl.j2

varnish_default_backend_host: "127.0.0.1"
varnish_default_backend_port: "8080"

varnish_listen_address: ""
varnish_listen_port: "80"
varnish_secret: "14bac2e6-1e34-4770-8078-974373b76c90"
varnish_config_path: /etc/varnish
varnish_limit_nofile: 131072

varnish_admin_listen_host: "127.0.0.1"
varnish_admin_listen_port: "6082"

varnish_storage: "file,/var/lib/varnish/varnish_storage.bin,256M"
varnish_pidfile: /run/varnishd.pid

varnishd_extra_options: ""

varnish_enabled_services:
  - varnish

# Packagecloudのリポジトリを使用
varnish_apt_use_packagecloud: true

# RHEL/CentOSでPackagecloudリポジトリが使用されていることを確認します。
varnish_packagecloud_repo_yum_repository_priority: "1"

# RedHat / CentOS専用。
varnish_yum_repo_baseurl: "https://packagecloud.io/varnishcache/{{ varnish_packagecloud_repo }}/el/{{ ansible_distribution_major_version|int }}/$basearch"

# Debian / Ubuntu専用。
varnish_apt_repo: "deb https://packagecloud.io/varnishcache/{{ varnish_packagecloud_repo }}/packages/{{ ansible_distribution | lower }}/ {{ ansible_distribution_release }} main"
# deb https://packagecloud.io/varnishcache/varnish60lts/$ID/ $VERSION_CODENAME main

# オプションで追加のバックエンドを定義できます。
# varnish_backends:
#   apache:
#     host: 10.0.2.2
#     port: 80
#   nodejs:
#     host: 10.0.2.3
#     port: 80

# オプションで異なるバックエンドを指すvhostsを定義できます。
# varnish_vhosts:
#   example.com:
#     backend: apache
#   nodejs.example.com:
#     backend: nodejs

要件

使用されるロールの状態

システムを準備するために、以下のロールが使用されます。他の方法でシステムを準備することも可能です。

要件 GitHub バージョン
buluma.bootstrap Ansible Molecule Version
buluma.systemd Ansible Molecule Version
buluma.core_dependencies Ansible Molecule Version
buluma.httpd Ansible Molecule Version

コンテキスト

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

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

dependencies

互換性

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

コンテナ タグ
Ubuntu focal, jammy, noble
Debian bullseye

必要なAnsibleの最小バージョンは2.12で、以下のテストが行われました:

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

問題が見つかった場合は、GitHubで報告してください。

変更履歴

ロールの履歴

ライセンス

Apache-2.0

作者情報

Shadow Walker

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