项目中需要用到容器封装不同人写的算法,最后集成到我们的系统中,算法的触发机制是定时的访问主系统的服务,查询任务库是否有该算法的任务,如果有任务就开始执行。在外部做的时候一切正常,但是打包成容器之后,算法容器就不能访问系统的服务了。最后发现容器内部访问本机的服务时,不能用127.0.0.1,应该用本机的局域网ip。
宿主机服务:app.py
from flask import Flask
from flask_restful import Resource, Api,reqparse
import psycopg2
app = Flask(__name__)
api = Api(app)
class HelloWorld(Resource):
def get(self):
return {'hello':‘word’}
api.add_resource(HelloWorld, '/')
if __name__ == '__main__':
app.run()
算法:algorithm.py
import requests
import time
url="http://127.0.0.1:"
port=5000
#发送心跳
def send_heart():
while True:
heart_url = url+str(port)
r=requests.get(heart_url)
print(r.json())
time.sleep(2)
if __name__ == '__main__':
send_heart()
在pycharm中执行app.py和algorithm.py。
程序正常运行,算法可以访问主服务。
2、算法打包成容器
容器和宿主机看成两个独立的机器,因此ip要用宿主机的局域网ip
将app.py的host改为本机的局域网ip,algorithm.py访问的ip也需要改。
app.py
查看局域网ip为192.168.1.239
if __name__ == '__main__':
app.run(host='192.168.1.239')
algorithm.py
url="http://192.168.1.239:"
port=5000
镜像打包
docker build -t algorithm .
容器执行
docker run -it algorithm
如果还是不能访问,可能是防火墙的问题