Commit 1515a12e authored by Yang's avatar Yang

docker-compose add

parent 5839e8d0
<?xml version="1.0" encoding="UTF-8"?>
<module type="PYTHON_MODULE" version="4">
<component name="NewModuleRootManager">
<content url="file://$MODULE_DIR$" />
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
<component name="TestRunnerService">
<option name="projectConfiguration" value="Nosetests" />
<option name="PROJECT_TEST_RUNNER" value="Nosetests" />
</component>
</module>
\ No newline at end of file
<component name="InspectionProjectProfileManager">
<settings>
<option name="useProjectProfile" value="false" />
<option name="USE_PROJECT_PROFILE" value="false" />
<version value="1.0" />
</settings>
</component>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" project-jdk-name="Python 2.7.10 (/usr/bin/python)" project-jdk-type="Python SDK" />
</project>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/.idea/DRIP.iml" filepath="$PROJECT_DIR$/.idea/DRIP.iml" />
</modules>
</component>
</project>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="$PROJECT_DIR$" vcs="Git" />
</component>
</project>
\ No newline at end of file
This diff is collapsed.
#! /usr/bin/env python
# Copyright 2017 --Yang Hu--
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
__author__ = 'Yang Hu'
import paramiko, os
from vm_info import VmInfo
def deploy_compose(vm, compose_file, compose_name):
try:
print "%s: ====== Start Docker Compose Deploying ======" % (vm.ip)
paramiko.util.log_to_file("deployment.log")
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(vm.ip, username=vm.user, key_filename=vm.key)
sftp = ssh.open_sftp()
sftp.chdir('/tmp/')
sftp.put(compose_file, "docker-compose.yml")
stdin, stdout, stderr = ssh.exec_command("sudo docker stack deploy --compose-file /tmp/docker-compose.yml %s" % (compose_name))
stdout.read()
print "%s: ======= Deployment of Compose Finished =========" % (vm.ip)
except Exception as e:
print '%s: %s' % (vm.ip, e)
return "ERROR:" + vm.ip + " " + str(e)
ssh.close()
return "SUCCESS"
def run(vm_list, compose_file, compose_name):
for i in vm_list:
if i.role == "master":
ret = deploy_compose(i, compose_file, compose_name)
if "ERROR" in ret:
return ret
else:
swarm_file = open(i.key)
ret = swarm_file.read()
swarm_file.close()
break
return ret
\ No newline at end of file
...@@ -22,9 +22,15 @@ import threading ...@@ -22,9 +22,15 @@ import threading
def install_engine(vm): def install_engine(vm):
try: try:
print "%s: ====== Start Docker Engine Installing ======" % (vm.ip) print "%s: ====== Start Docker Engine Installing ======" % (vm.ip)
paramiko.util.log_to_file("deployment.log")
ssh = paramiko.SSHClient() ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(vm.ip, username=vm.user, key_filename=vm.key) ssh.connect(vm.ip, username=vm.user, key_filename=vm.key)
stdin, stdout, stderr = ssh.exec_command("sudo dpkg --get-selections | grep docker")
temp_list = stdout.readlines()
temp_str = ""
for i in temp_list: temp_str += i
if temp_str.find("docker") != -1: return "SUCCESS"
sftp = ssh.open_sftp() sftp = ssh.open_sftp()
sftp.chdir('/tmp/') sftp.chdir('/tmp/')
file_path = os.path.dirname(os.path.abspath(__file__)) file_path = os.path.dirname(os.path.abspath(__file__))
......
...@@ -7,5 +7,5 @@ sudo apt-key fingerprint 0EBFCD88 ...@@ -7,5 +7,5 @@ sudo apt-key fingerprint 0EBFCD88
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
sudo apt-get update sudo apt-get update
sudo apt-get -y install docker-ce sudo apt-get -y install docker-ce
sudo echo "{ \"insecure-registries\":[\"129.7.98.3:5000\"] }" > /etc/docker/daemon.json #sudo echo "{ \"insecure-registries\":[\"129.7.98.3:5000\"] }" > /etc/docker/daemon.json
sudo service docker restart #sudo service docker restart
...@@ -22,9 +22,15 @@ from vm_info import VmInfo ...@@ -22,9 +22,15 @@ from vm_info import VmInfo
def install_manager(vm): def install_manager(vm):
try: try:
print "%s: ====== Start Swarm Manager Installing ======" % (vm.ip) print "%s: ====== Start Swarm Manager Installing ======" % (vm.ip)
paramiko.util.log_to_file("deployment.log")
ssh = paramiko.SSHClient() ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(vm.ip, username=vm.user, key_filename=vm.key) ssh.connect(vm.ip, username=vm.user, key_filename=vm.key)
stdin, stdout, stderr = ssh.exec_command("sudo docker info | grep Swarm")
temp_list = stdout.readlines()
temp_str = ""
for i in temp_list: temp_str += i
if temp_str.find("Swarm: active") != -1: return "SUCCESS"
stdin, stdout, stderr = ssh.exec_command("sudo docker swarm leave --force") stdin, stdout, stderr = ssh.exec_command("sudo docker swarm leave --force")
stdout.read() stdout.read()
stdin, stdout, stderr = ssh.exec_command("sudo docker swarm init --advertise-addr %s" % (vm.ip)) stdin, stdout, stderr = ssh.exec_command("sudo docker swarm init --advertise-addr %s" % (vm.ip))
...@@ -39,6 +45,7 @@ def install_manager(vm): ...@@ -39,6 +45,7 @@ def install_manager(vm):
def install_worker(join_cmd, vm): def install_worker(join_cmd, vm):
try: try:
print "%s: ====== Start Swarm Worker Installing ======" % (vm.ip) print "%s: ====== Start Swarm Worker Installing ======" % (vm.ip)
paramiko.util.log_to_file("deployment.log")
ssh = paramiko.SSHClient() ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(vm.ip, username=vm.user, key_filename=vm.key) ssh.connect(vm.ip, username=vm.user, key_filename=vm.key)
...@@ -59,6 +66,11 @@ def run(vm_list): ...@@ -59,6 +66,11 @@ def run(vm_list):
join_cmd = install_manager(i) join_cmd = install_manager(i)
if "ERROR" in join_cmd: if "ERROR" in join_cmd:
return join_cmd return join_cmd
elif "SUCCESS" in join_cmd:
swarm_file = open(i.key)
swarm_string = swarm_file.read()
swarm_file.close()
return swarm_string
else: else:
join_cmd = join_cmd.encode() join_cmd = join_cmd.encode()
join_cmd = join_cmd.replace("\n" , "") join_cmd = join_cmd.replace("\n" , "")
......
...@@ -8,6 +8,7 @@ from vm_info import VmInfo ...@@ -8,6 +8,7 @@ from vm_info import VmInfo
import docker_kubernetes import docker_kubernetes
import docker_engine import docker_engine
import docker_swarm import docker_swarm
import docker_compose
import control_agent import control_agent
import ansible_playbook import ansible_playbook
import sys, argparse import sys, argparse
...@@ -69,8 +70,9 @@ def handleDelivery(message): ...@@ -69,8 +70,9 @@ def handleDelivery(message):
fo.close() fo.close()
elif name == "composer": elif name == "composer":
value = param["value"] value = param["value"]
docker-composer = path + "docker-composer.yml" compose_file = path + "docker-compose.yml"
fo = open(docker-composer, "w") compose_name = param["attributes"]["name"]
fo = open(compose_file, "w")
fo.write(value) fo.write(value)
fo.close() fo.close()
...@@ -82,9 +84,8 @@ def handleDelivery(message): ...@@ -82,9 +84,8 @@ def handleDelivery(message):
if "ERROR" in ret: return ret if "ERROR" in ret: return ret
ret = docker_swarm.run(vm_list) ret = docker_swarm.run(vm_list)
if "ERROR" in ret: return ret if "ERROR" in ret: return ret
ret1 = control_agent.run(vm_list) # ret1 = control_agent.run(vm_list)
#deploy_composer.run(vm_list,docker-composer) ret = docker_compose.run(vm_list, compose_file, compose_name)
if "ERROR" in ret1: ret = ret1
return ret return ret
elif manager_type == "ansible": elif manager_type == "ansible":
ret = ansible_playbook.run(vm_list,playbook) ret = ansible_playbook.run(vm_list,playbook)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment