1
0
mirror of https://github.com/newnius/YAO-agent.git synced 2025-06-07 13:51:56 +00:00

update api

This commit is contained in:
Newnius 2019-12-04 16:13:54 +08:00
parent 814f252b49
commit 022212a6e0
2 changed files with 38 additions and 33 deletions

View File

@ -82,36 +82,30 @@ class MyHandler(BaseHTTPRequestHandler):
docker_workspace = form.getvalue('workspace')
docker_gpus = form.getvalue('gpus')
docker_mem_limit = form.getvalue('mem_limit')
docker_cpu_limit = int(form.getvalue('cpu_limit'))
docker_cpu_limit = form.getvalue('cpu_limit')
docker_network = form.getvalue('network')
try:
client = docker.APIClient(base_url='unix://var/run/docker.sock')
script = " ".join([
"docker run",
"--gpus '\"device=" + docker_gpus + "\"'",
"--detach=True",
"--hostname " + docker_name,
"--network " + docker_network,
"--network-alias " + docker_name,
"--memory-reservation " + docker_mem_limit,
"--cpus " + docker_cpu_limit,
"--env repo=" + docker_workspace,
docker_image,
docker_cmd
])
host_config = client.create_host_config(
mem_limit=docker_mem_limit,
cpu_shares=docker_cpu_limit * 1024
)
networking_config = client.create_networking_config(
endpoints_config={
docker_network: client.create_endpoint_config(
aliases=[docker_name],
)
}
)
container = client.create_container(
image=docker_image,
command=docker_cmd,
hostname=docker_name,
detach=True,
host_config=host_config,
environment={"repo": docker_workspace, "NVIDIA_VISIBLE_DEVICES": docker_gpus},
networking_config=networking_config,
runtime='nvidia'
)
client.start(container)
msg = {"code": 0, "id": container['Id']}
client = docker.from_env()
container = client.containers.get('yao-agent-helper')
exit_code, output = container.exec_run('sh -c \'' + script + '\'')
msg = {"code": 0, "id": output.decode('utf-8').rstrip('\n')}
if exit_code != 0:
msg["code"] = 1
except Exception as e:
msg = {"code": 1, "error": str(e)}

23
test.py
View File

@ -4,8 +4,7 @@ import docker
def run():
client = docker.from_env()
try:
print(client.containers.run(image="alpine", command="nvid", environment={"KEY": "value"}))
# print(client.containers.run(image="nvidia/cuda:9.0-base", command="nvidia-smi", environment={"KEY": "value"}, runtime="nvidia"))
print(client.containers.run(image="alpine", command="pwd", environment={"KEY": "value"}))
except Exception as e:
print(e.__class__.__name__, e)
@ -78,9 +77,9 @@ def create_container():
)
networking_config = client.create_networking_config(
endpoints_config={
'yao-net-1201': client.create_endpoint_config(
aliases=['node1'],
)
# 'yao-net-1201': client.create_endpoint_config(
# aliases=['node1'],
# )
}
)
@ -95,10 +94,22 @@ def create_container():
runtime='nvidia'
)
client.start(container)
print(container)
def exec_run():
client = docker.from_env()
container = client.containers.get('yao-agent-helper')
exit_code, output = container.exec_run(cmd="sh -c 'docker run --gpus all --detach=True tensorflow/tensorflow:1.14.0-gpu nvidia-smi'")
if exit_code == 0:
print(output.decode('utf-8').rstrip('\n'))
# create_network()
# list_networks()
# remove_network()
get_status('af121babda9b')
# get_status('af121babda9b')
# exec_run()
# run()
create_container()