質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
86.12%
CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

SSH

SSH(Secure Shell)は、セキュアチャネルを通してデータを交換するためのネットワークプロトコルです。リモートサーバーへのコマンド実行やファイル転送を行う時に一般的に使用されます。

Ansible

Ansibleは、Python で書かれたサーバーの設定を管理するための 構成管理ツールです。

解決済

Ansible playbook実行時のsshエラー

papachiropa
papachiropa

総合スコア14

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

SSH

SSH(Secure Shell)は、セキュアチャネルを通してデータを交換するためのネットワークプロトコルです。リモートサーバーへのコマンド実行やファイル転送を行う時に一般的に使用されます。

Ansible

Ansibleは、Python で書かれたサーバーの設定を管理するための 構成管理ツールです。

1回答

0リアクション

0クリップ

6193閲覧

投稿2020/06/01 08:39

編集2020/06/02 07:14

サーバA(192.168.100.251)とB(192.168.100.253)に対して
Ansible playbookを実行すると下記のようなエラーが出ます。(Ansible操作端末も対象サーバもCentOS7です)

[root@hoge tmp]# ansible-playbook OracleJDK.yml -i hosts PLAY ***************************************************************************************************************************** TASK [create target dir.] ***************************************************************************************************************** Enter passphrase for key '/root/.ssh/id_rsa': Enter passphrase for key '/root/.ssh/id_rsa': ok: [192.168.100.251] fatal: [192.168.100.253]: UNREACHABLE! => {"changed": false, "msg": "Failed to connect to the host via ssh: Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password).\r\n", "unreachable": true}

サーバAは成功しますが、Bは失敗します。上記エラーの解消方法をご教示頂けたらと思います。

また、下記サイトの通りにansible all -m ping -i hostsを
実行してみるとエラーが出たので、ssh-copy-idコマンドで対象サーバーに公開鍵を設置してみましたが
ansible all -m ping -i hostsの結果が都度変わるような状況です。(下のパターン⓵と⓶参照)

ansible で UNREACHABLE! Failed to connect to the host via ssh: Permission denied エラーで対象ホストにログインできない

#⓵ [root@hoge tmp]# ansible all -m ping -i hosts Enter passphrase for key '/root/.ssh/id_rsa': Enter passphrase for key '/root/.ssh/id_rsa': Enter passphrase for key '/root/.ssh/id_rsa': 192.168.100.251 | SUCCESS => { "changed": false, "ping": "pong" } 192.168.100.253 | UNREACHABLE! => { "changed": false, "msg": "Failed to connect to the host via ssh: Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password).\r\n", "unreachable": true #⓶ [root@hoge tmp]# ansible all -m ping -i hosts Enter passphrase for key '/root/.ssh/id_rsa': Enter passphrase for key '/root/.ssh/id_rsa': 192.168.100.253 | SUCCESS => { "changed": false, "ping": "pong" } 192.168.100.251 | UNREACHABLE! => { "changed": false, "msg": "Failed to connect to the host via ssh: Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password).\r\n", "unreachable": true }

端折って申し訳ございません。実行予定のplaybookは下記です。

YAML

- hosts: tomcat vars:   ansible_user: root   ansible_ssh_private_key_file: /root/.ssh/id_rsa gather_facts: no remote_user: root become: true tasks: - name: create target dir. file: path=/root/soft state=directory - copy: src=/tmp/jdk-8u202-linux-x64.rpm dest=/root/soft/jdk-8u202-linux-x64.rpm owner=root group=root mode=0644 - name: install JDK 14 from a local file yum: name=/root/soft/jdk-8u202-linux-x64.rpm state=present

6/2時点エラー状況

[root@hoge tmp]# ansible-playbook OracleJDK.yml -i hosts PLAY [tomcat] ************************************************************************************************************************************ TASK [create target dir.] ************************************************************************************************************************ Enter passphrase for key '/root/.ssh/id_rsa': Enter passphrase for key '/root/.ssh/id_rsa': ok: [linux3] fatal: [linux1]: UNREACHABLE! => {"changed": false, "msg": "Failed to connect to the host via ssh: Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password).\r\n", "unreachable": true} TASK [copy] ************************************************************************************************************************************** ok: [linux3] TASK [install JDK 14 from a local file] ********************************************************************************************************** ok: [linux3] to retry, use: --limit @/tmp/OracleJDK.retry PLAY RECAP *************************************************************************************************************************************** linux1 : ok=0 changed=0 unreachable=1 failed=0 linux3 : ok=3 changed=0 unreachable=0 failed=0

宜しくお願い致します。

以下のような質問にはリアクションをつけましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
86.12%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

SSH

SSH(Secure Shell)は、セキュアチャネルを通してデータを交換するためのネットワークプロトコルです。リモートサーバーへのコマンド実行やファイル転送を行う時に一般的に使用されます。

Ansible

Ansibleは、Python で書かれたサーバーの設定を管理するための 構成管理ツールです。