Flask Multiprocessing - PullRequest
       18

Flask Multiprocessing

0 голосов
/ 24 июня 2018

Я пытаюсь разработать небольшое приложение, которое в основном построит некоторые графики на основе набора данных, предоставленных или запрошенных пользователем. Функция process_order должна запускаться одновременно с другим набором данных. Почему-то я получаю только первый график, а не второй и последующий. Я открыл другой сеанс браузера с другим пользователем получил тот же результат.

Пример Я попытался открыть браузер один из IE, а другой из Chrome, вошедший в систему как user1 с набором из 5 входов - в IE (ожидается 5 графиков) и как user2 с набором из 20 входов - в Chrome (ожидается 20 Графики) Я ожидал 2 окна браузера с 5 графиками из одного и 20 графиками из второго окна:

Я новичок в питоне и фляге извинения, если что-то уже задавали / отвечали на разные вопросы

app = Flask(__name__)
plot = None
my_session = None
session_id = None

@app.route('/')
def home():
    if not session.get('logged_in'):
        return render_template('login.html')
    else:
        return render_template('template.html')

@app.route('/login', methods=['POST'])
def do_admin_login():

    if request.form['password'] == 'password' and request.form['username'] in 'admin' :
        session['logged_in'] = True
        my_session = Bot(request.form['username'])
        my_session.session_id = request.form['username']
        session['user'] = request.form['username']
        return render_template('template.html')
    else:
        flash('wrong password!')
    return home()

@app.route("/ask", methods=['POST','GET'])
def ask():

    string = str(request.form['message'])

    res = my_session.process(string)
    return jsonify({'status':'OK','answer':bot_res})


class Bot():
    #Define user level 
    def __init__(self,session_id):
      self.return_string = ""
      self.session_id = session_id

    def process(self, string):
        self.session_id = session['user']
        self.string = string
        self.return_string = self.process_order() #  This method I would like to execute as concurrent at the same time for multiple users/session with different set ot data
        return self.return_string

    def process_order(self):

        self.plot = Plot()
        self.plot.global_url = range(5)
        self.i = 0
        self.inputs = [] #tuples
        self.number = range(5)

        self.url_values = zip(self.number,self.inputs)

        self.pool = Pool()
        self.func = partial(self.plot.do_plot,self.var1)
        self.pool.map(self.func,self.url_values)
        self.pool.close()
        self.pool.join()

        process_confirmation = "Your request is complete"
        return process_confirmation


class Plot():

    def __init__(self):
        pass
    def do_plot(self, var1):

        self.number, self.url = plot_values
        self.var1 = var1

        fig = plt.figure(self.number)
        self.line = str(self.url[1])

        self.res  = urllib.request.urlopen(self.line)
        plt.imshow(plt.imread(self.res))

        self.file_name = "%03d.png"%(self.number,)
        plt.savefig(self.file_name)

        plt.close()

if __name__ == "__main__":
    session_id = None
    app.secret_key = os.urandom(12)
    my_session = Bot(session_id)
    app.run(host='0.0.0.0', port=80)

1 Ответ

0 голосов
/ 24 июня 2018

Если проблема в том, что отдельные запросы занимают много времени, ваша проблема может быть связана с использованием встроенного сервера фляг.

Вы можете попробовать развернуть приложение с помощью gevent: http://flask.pocoo.org/docs/1.0/deploying/wsgi-standalone/#gevent

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...