如何使用Ansible在多个服务器上为多个用户部署多个ssh_key?

时间:2015-08-21 07:17:01

标签: ansible multiple-instances ansible-playbook authorized-keys

我的环境由2个Web服务器和2个db服务器组成。

我的团队中有一位新的开发人员。我需要在每台服务器上部署他的ssh密钥。

他必须能够在网络服务器上与用户ubuntuwww-data以及数据库服务器上的用户ubuntu连接。

我的服务器配置了Ansible。

我该怎么做?

2 个答案:

答案 0 :(得分:4)

我通过创建一个像这样的ssh-key任务来解决它。

roles/ssh-keys/tasks/main.yml

---
- name: add authorized key
  authorized_key: user={{ item }} key="{{ lookup('file', 'authorized_keys') }}"
  with_items: authorized_ssh_users
  when: authorized_ssh_users is defined

roles/ssh-keys/files/authorized_keys

ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQ[ssh_pub_key_of_dev1] dev1
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQ[ssh_pub_key_of_dev2] dev2
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQ[ssh_pub_key_of_dev3] dev3

hosts/production

[webservers]
webserv1-hostname
webserv2-hostname

[webservers:vars]
authorized_ssh_users=['ubuntu','www-data']

[dbservers]
dbserv1-hostname
dbserv2-hostname

[dbservers:vars]
authorized_ssh_users=['ubuntu']

然后在playbook.yml

- name: Provision ssh keys
  hosts: all
  sudo: true
  roles:
  - ssh-keys

使用此解决方案,我可以管理服务器/用户的每个组合以部署密钥。

答案 1 :(得分:0)

这个角色对你很有用。努力将其纳入Galaxy,但由于某种原因它不会导入。

https://github.com/smiller171/ansible-user-management

此角色已设置,因此您只需传入所需用户和组的变量,以及要删除的任何用户,如下所示:

---
- hosts: all
  sudo: yes
  roles:
  - scott.miller171.manage_users
  vars:
  - manage_users_allowed:
    - name: foo
      authorized:
      - "ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAQEAlPYybp3CWDzRPo0uF/woyqkfhpZK2T7zn16z+fGYlRQl6gXATIUB4JYfr9pfD+SOW2T4X78P+/h1o4QPCwoesLacaFEFGwUb+SzhVVm6B6q4WMAiJWD6OVXh+SVVvD9rdcz5RMVLqQngrRqBlj4kBIMQ3S8h1cCESbR2P6jszgFj0I6p3tQCpo9yjcVwLqvWFKJgzEm2E2wV/gmrc0PhVRP2guIRN4p6M2ZyIPprdZ6PA8m7Rs4yN3jQ/0alrQ23ECCU4lHoVG9fwvLIq1vh4ikPcUrdA8sSHTE1pkpzvrTv7FtkuUcBrDMedFE7E8dB9pPS+vXIBWVUYJhp9WzVkQ== user@domain.com"

  - manage_users_unauthorized:
    - foobar

  - manage_users_groups: "sudo,adm,dialout,cdrom,floppy,audio,video,plugdev"