26.如何使用python操作我们自己创建的docker image呢?
因为逻辑复杂
我们建个文件来
python #是单行注释
'''是多行注释
或者”””
我们想使用python来操作docker 那么就要一个api
https://github.com/docker/docker-py官方API 以python来使用docker命令
我其实就想用这个api的 docker run 这个命令 不过是以python的方式
定义一下image
下面就是写 build——and——run了
他的原理是什么呢?
原理就是使用python操作docker的client
的docker run的API
那么怎么把用户代码传进去呢?
这里有个磁盘映射
就是将我们ubuntu一个文件夹映射到我们docker下面的某个文件
那么在我们docker container里面就看到 这些映射的内容
通过这种映射的方式传入用户代码
当然实现这个的前提是
我们将客户代码写入一个文件(ubuntu)中
然后将这个包含文件的文件夹映射给我们的docker
那么docker在运行的时候通过自带的load_image方法就会自动得到用户代码
所以我们将本地代码写入文件去
我们先把返回的结构体写一下
我们为啥这么写呢?因为我们在rest.js里面已经定义了返回体了我们看看
这里的build 和run 就是我们 上面返回的东西
python自带的库
就是为了唯一指定 用户代码 因为我们execution srvice 服务于多个request 这样好区分
每个用户对于不同的id和文件夹
定义一下目录存放位置
本地存放位置用了os这个类库(pyhton自带的库 一般先查就好)
host就是在ubuntu上
guest在docker container 的ubuntu里面的test文件夹下
其实就是将host的文件夹下所有内容映射到guest文件夹下
是一一对应映射的关系
然后创建文件夹
这个方法 os可以模拟很多在linux下面的命令
比如下面的创建文件夹
然后打印log信息
那么下面就要将用户代码写入一个文件
下面就是我们这个系统最核心的部分
这个bulid 就类似 javac xxx
这个execute 就类似java XXX
然后把map拿过来
然后我们在executor——service来调用
为了简单 我们取名eu
然后
再启动我们flask之前我们先加载image
因为可能本地没image 或者我们部署在远程server上
或者本地你删掉了
总之 你先load image 确保本地有iamge
我们用 postman来验证一下
报错了
这是因为
'/home/han/Projects/BittigerCS503/week4/executor/tmp//df8ea3ef-42fe-409a-86f2-ce180bab8873/example.py'
说没这个文件夹
因为我们还没创建
成功
我们再测
没问题
那么我们将所有的都穿起来
nodeserver 和 exrctionserver 穿起来
我们测试一下
提交
nodeserver
flask
OK
然后我们改改launcher.sh
改成
以后直接运行sudo ./launcher.sh就行了!
26.如何使用python操作我们自己创建的docker image呢?的更多相关文章
- jira python操作,自动创建问题
jira web api地址 http://jira.**.com/plugins/servlet/restbrowser http://jira.**.com/rest/api/2/issue/cr ...
- python操作excel常用的方法
读操作模块安装 pip install xlrd 写操作模块安装 pip install xlwt xlrd读操作 1.打开excel xl = xlrd.open_workbook('test.xl ...
- 用来创建用户docker registry认证的Secret
集群环境:1.k8s用的是二进制方式安装2.操作系统是linux (centos)3.操作系统版本为 7.4/7.94.k8s的应用管理.node管理.pod管理等用rancher.k8s令牌以及ma ...
- Python 【第六章】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy
Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...
- python操作数据库
一,安装mysql 如果是windows 用户,mysql 的安装非常简单,直接下载安装文件,双击安装文件一步一步进行操作即可. Linux 下的安装可能会更加简单,除了下载安装包进行安装外,一般的l ...
- Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy
Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...
- Python开发【第十九篇】:Python操作MySQL
本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...
- Python操作memcached及redis
Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...
- Python之路【第九篇】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy
Python之路[第九篇]:Python操作 RabbitMQ.Redis.Memcache.SQLAlchemy Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用 ...
随机推荐
- AWS之搭建深度学习主机
B.G 至2017.11 GPU选型:(参考知乎.CSDN) 高性价比的两款:GTX1080ti, Titan X --通常调试算法 i7CPU+32G内存+SSD+2*GPU(单块显存>6G ...
- RabbitMQ install (Ubuntu)
1. key 1) Online way apt-key adv --keyserver "hkps.pool.sks-keyservers.net" --recv-keys &q ...
- 学习js第三天小结
1.冒泡排序分析: 例:将数组[9,8,7,6,5,4,3,2,1,0]按照从小打大的顺序进行冒泡排序. 演变过程: 第一趟: 8,7,6,5,4,3,2,1,0,9 比较了9次: 第二趟: 7 ...
- css3选择
在一些项目中,我们常常需要实现选择类似于3的倍数的位数的元素,或者从第n个之后的元素,或者从第n个到第m个元素这种类型的选择,如果说在以前,想完全通过css实现,似乎是天方夜谭,根本不可能实现,CSS ...
- StanFord ML 笔记 第三部分
第三部分: 1.指数分布族 2.高斯分布--->>>最小二乘法 3.泊松分布--->>>线性回归 4.Softmax回归 指数分布族: 结合Ng的课程,在看这篇博文 ...
- android 开发 实现一个进入相机拍照后裁剪图片或者进入相册选中裁剪图片的功能
实现思维路径: 以进入相机拍照的思维路线为例子: 1.进入app 2.判断之前是否保存头像,如果有就显示历史图像 (下面代码中在getOldAvatar();方法中执行这个逻辑) 3.点击更换图像的B ...
- jl1.如何设置元素的宽高包含元素的边框和内边距
方法一: 文档地址:http://www.w3school.com.cn/cssref/pr_box-sizing.asp CSS3 box-sizing属性: box-sizing: bord ...
- ant 小结
ant 的配置文件是xml 格式的. 其xml根元素是 project project元素下面有 property path env target filelist patternset 其中 tar ...
- hive 索引
hive 有限的支持索引,不支持主键外键,可以对表添加索引,也可以为某个分区添加索引.维护索引也要额外的存储空间和计算资源. 创建索引需要指定索引处理器 如 as 'org.apache.hadoop ...
- 异常+远程控制Linux-14
什么是异常 a=8950/0 ZeroDivisioonError: division by zero print (a) ************** b = [1,2] ...