<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>IaC on Ingenboy.inc</title>
    <link>https://blog.ingenboy.com/categories/iac/</link>
    <description>Recent content in IaC on Ingenboy.inc</description>
    <image>
      <title>Ingenboy.inc</title>
      <url>https://blog.ingenboy.com/%3Clink%20or%20path%20of%20image%20for%20opengraph,%20twitter-cards%3E</url>
      <link>https://blog.ingenboy.com/%3Clink%20or%20path%20of%20image%20for%20opengraph,%20twitter-cards%3E</link>
    </image>
    <generator>Hugo -- 0.152.2</generator>
    <language>en</language>
    <lastBuildDate>Sun, 04 Aug 2024 20:06:01 +0900</lastBuildDate>
    <atom:link href="https://blog.ingenboy.com/categories/iac/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Master_ansible</title>
      <link>https://blog.ingenboy.com/post/master_ansible/</link>
      <pubDate>Sun, 04 Aug 2024 20:06:01 +0900</pubDate>
      <guid>https://blog.ingenboy.com/post/master_ansible/</guid>
      <description>&lt;h1 id=&#34;背景&#34;&gt;背景&lt;/h1&gt;
&lt;p&gt;業務で必要なansibleをマスターしたい。&lt;/p&gt;
&lt;h1 id=&#34;ansibleとは&#34;&gt;ansibleとは&lt;/h1&gt;
&lt;p&gt;ansibleとは、Infrastructure as Codeを実現するための構成管理ツールである。
例えば、middlewareをデプロイする際に、ある程度の複雑さでのデプロイを可能にするツールである。&lt;/p&gt;
&lt;h1 id=&#34;ansibleの特徴&#34;&gt;ansibleの特徴&lt;/h1&gt;
&lt;ul&gt;
&lt;li&gt;可読性を意識した設定ファイル
&lt;ul&gt;
&lt;li&gt;柔軟性がないとも言える&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;豊富なモジュール群
&lt;ul&gt;
&lt;li&gt;これは柔軟性の高い（＝可読性が低い）ことの裏返しだと思う&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;冪等性の担保
&lt;ul&gt;
&lt;li&gt;何度ファイルを実行しても、対象の結果は変わらない&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;agentlessなツール
&lt;ul&gt;
&lt;li&gt;ローカルホストで実行し、sshで各サーバにログインして設定をする。構成管理をしたいサーバに別途ソフトを導入する必要などはない。&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;用途が似たツールにterraformがある。それとの違いに関してはまた今度としよう。&lt;/p&gt;
&lt;h1 id=&#34;ansibleのアーキテクチャ&#34;&gt;ansibleのアーキテクチャ&lt;/h1&gt;
&lt;ul&gt;
&lt;li&gt;ansiblでは、コマンドを実行する「コントロールノード」と処理の対象となる「ターゲットノード」に分かれる。設定ファイルに書かれたモジュールをコントロールノード側でPythonのコードに変換し、sftpでターゲットノードに転送し、そこでPythonコードを実行する流れになっている。そのため、コントロールノード、ターゲットノードのどちらにもPythonがインストールされている必要がある。&lt;/li&gt;
&lt;/ul&gt;
&lt;h1 id=&#34;ansibleの用語&#34;&gt;ansibleの用語&lt;/h1&gt;
&lt;ul&gt;
&lt;li&gt;インベントリ：ターゲットノードの一覧が書かれた設定ファイルである。ターゲットノードをグループ化することも可能である。&lt;/li&gt;
&lt;li&gt;プレイブック：実行するモジュールが書かれた設定ファイルである。&lt;/li&gt;
&lt;li&gt;モジュール：「ファイルの転送」や「サービスの起動、停止」などの処理の単位。Ansible側で用意されたモジュールを使って構成管理をする。（では、逆にansibleのモジュールにない設定を反映させたい場合にはどうするのか？ーー＞自分でモジュールを開発することもできる）&lt;/li&gt;
&lt;li&gt;プラグイン：Ansibleの基本機能を拡張してくれる。モジュールはタスクとして実行されるが、プラグインは、Ansible コアを拡張してくれる感じです。&lt;/li&gt;
&lt;li&gt;コレクション：&lt;/li&gt;
&lt;/ul&gt;
&lt;h1 id=&#34;ansibleのインストール方法&#34;&gt;ansibleのインストール方法&lt;/h1&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;apt install ansible-core
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;インストールを確認&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;ray@delta:~$ ansible-playbook --version
ansible-playbook [core 2.12.0]
  config file = None
  configured module search path = [&amp;#39;/home/ray/.ansible/plugins/modules&amp;#39;, &amp;#39;/usr/share/ansible/plugins/modules&amp;#39;]
  ansible python module location = /usr/lib/python3/dist-packages/ansible
  ansible collection location = /home/ray/.ansible/collections:/usr/share/ansible/collections
  executable location = /usr/bin/ansible-playbook
  python version = 3.10.12 (main, Jul 29 2024, 16:56:48) [GCC 11.4.0]
  jinja version = 3.0.3
  libyaml = True
&lt;/code&gt;&lt;/pre&gt;&lt;h1 id=&#34;設定ファイル&#34;&gt;設定ファイル&lt;/h1&gt;
&lt;p&gt;~/.ansible/ansible.cfg配下におくといいです。このファイルに以下の設定を書き込みましょう&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
