Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
ansible
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
OpenEdx
ansible
Commits
cfd0413b
Commit
cfd0413b
authored
May 05, 2013
by
Michael DeHaan
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2815 from jarv/devel
EC2 ELB management
parents
4f5bcd70
e5d9dad2
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
201 additions
and
0 deletions
+201
-0
library/cloud/ec2_elb
+201
-0
No files found.
library/cloud/ec2_elb
0 → 100644
View file @
cfd0413b
#!/usr/bin/python
# This file is part of Ansible
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
DOCUMENTATION
=
"""
---
module: ec2_elb
short_description: De-registers or registers instances from EC2 ELB(s)
description:
- This module de-registers or registers an AWS EC2 instance from the ELB(s)
that it belongs to.
- Returns fact "ec2_elbs" which is a list of elbs attached to the instance
if state=absent is passed as an argument.
- Will be marked changed when called only if there are ELBs found to operate on.
version_added: "1.2"
requirements: [ "boto" ]
author: John Jarvis
options:
state:
description:
- register or deregister the instance
required: true
instance_id:
description:
- EC2 Instance ID
required: true
ec2_elbs:
description:
- List of ELB names, required for registration. The ec2_elbs fact should be used if there was a previous de-register.
required: false
default: None
ec2_secret_key:
description:
- AWS Secret API key
required: false
default: None
ec2_access_key:
description:
- AWS Access API key
required: false
default: None
"""
EXAMPLES
=
"""
# basic pre_task and post_task example
pre_tasks:
- name: Gathering ec2 facts
ec2_facts:
- name: Instance De-register
local_action: ec2_elb
args:
instance_id: "{{ ansible_ec2_instance_id }}"
state: 'absent'
roles:
- myrole
post_tasks:
- name: Instance Register
local_action: ec2_elb
args:
instance_id: "{{ ansible_ec2_instance_id }}"
ec2_elbs: "{{ ec2_elbs }}"
state: 'present'
"""
import
time
import
sys
import
os
try
:
import
boto
except
ImportError
:
print
"failed=True msg='boto required for this module'"
sys
.
exit
(
1
)
class
ElbManager
:
"""Handles EC2 instance ELB registration and de-registration"""
def
__init__
(
self
,
module
,
instance_id
=
None
,
ec2_elbs
=
None
,
ec2_access_key
=
None
,
ec2_secret_key
=
None
):
self
.
ec2_access_key
=
ec2_access_key
self
.
ec2_secret_key
=
ec2_secret_key
self
.
module
=
module
self
.
instance_id
=
instance_id
self
.
lbs
=
self
.
_get_instance_lbs
(
ec2_elbs
)
# if there are no ELBs to operate on
# there will be no changes made
if
len
(
self
.
lbs
)
>
0
:
self
.
changed
=
True
else
:
self
.
changed
=
False
def
deregister
(
self
):
"""De-register the instance from all ELBs and wait for the ELB
to report it out-of-service"""
for
lb
in
self
.
lbs
:
lb
.
deregister_instances
([
self
.
instance_id
])
self
.
_await_elb_instance_state
(
lb
,
'OutOfService'
)
def
register
(
self
):
"""Register the instance for all ELBs and wait for the ELB
to report the instance in-service"""
for
lb
in
self
.
lbs
:
lb
.
register_instances
([
self
.
instance_id
])
self
.
_await_elb_instance_state
(
lb
,
'InService'
)
def
_await_elb_instance_state
(
self
,
lb
,
awaited_state
):
"""Wait for an ELB to change state
lb: load balancer
awaited_state : state to poll for (string)"""
while
True
:
state
=
lb
.
get_instance_health
([
self
.
instance_id
])[
0
]
.
state
if
state
==
awaited_state
:
break
else
:
time
.
sleep
(
1
)
def
_get_instance_lbs
(
self
,
ec2_elbs
=
None
):
"""Returns a list of ELBs attached to self.instance_id
ec2_elbs: an optional list of elb names that will be used
for elb lookup instead of returning what elbs
are attached to self.instance_id"""
try
:
elb
=
boto
.
connect_elb
(
self
.
ec2_access_key
,
self
.
ec2_secret_key
)
except
boto
.
exception
.
NoAuthHandlerFound
,
e
:
self
.
module
.
fail_json
(
msg
=
str
(
e
))
elbs
=
elb
.
get_all_load_balancers
()
if
ec2_elbs
:
lbs
=
sorted
(
lb
for
lb
in
elbs
if
lb
.
name
in
ec2_elbs
)
else
:
lbs
=
[]
for
lb
in
elbs
:
for
info
in
lb
.
instances
:
if
self
.
instance_id
==
info
.
id
:
lbs
.
append
(
lb
)
return
lbs
def
main
():
module
=
AnsibleModule
(
argument_spec
=
dict
(
state
=
{
'required'
:
True
,
'choices'
:
[
'present'
,
'absent'
]},
instance_id
=
{
'required'
:
True
},
ec2_elbs
=
{
'default'
:
None
,
'required'
:
False
},
ec2_secret_key
=
{
'default'
:
None
,
'aliases'
:
[
'EC2_SECRET_KEY'
]},
ec2_access_key
=
{
'default'
:
None
,
'aliases'
:
[
'EC2_ACCESS_KEY'
]}
)
)
ec2_secret_key
=
module
.
params
[
'ec2_secret_key'
]
ec2_access_key
=
module
.
params
[
'ec2_access_key'
]
ec2_elbs
=
module
.
params
[
'ec2_elbs'
]
if
module
.
params
[
'state'
]
==
'present'
and
'ec2_elbs'
not
in
module
.
params
:
module
.
fail_json
(
msg
=
"ELBs are required for registration"
)
if
not
ec2_secret_key
and
'EC2_SECRET_KEY'
in
os
.
environ
:
ec2_secret_key
=
os
.
environ
[
'EC2_SECRET_KEY'
]
if
not
ec2_access_key
and
'EC2_ACCESS_KEY'
in
os
.
environ
:
ec2_access_key
=
os
.
environ
[
'EC2_ACCESS_KEY'
]
instance_id
=
module
.
params
[
'instance_id'
]
elb_man
=
ElbManager
(
module
,
instance_id
,
ec2_elbs
,
ec2_access_key
,
ec2_secret_key
)
if
module
.
params
[
'state'
]
==
'present'
:
elb_man
.
register
()
elif
module
.
params
[
'state'
]
==
'absent'
:
elb_man
.
deregister
()
ansible_facts
=
{
'ec2_elbs'
:
[
lb
.
name
for
lb
in
elb_man
.
lbs
]}
ec2_facts_result
=
dict
(
changed
=
elb_man
.
changed
,
ansible_facts
=
ansible_facts
)
module
.
exit_json
(
**
ec2_facts_result
)
# this is magic, see lib/ansible/module_common.py
#<<INCLUDE_ANSIBLE_MODULE_COMMON>>
main
()
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment