Solucionado (ver solução)
Solucionado
(ver solução)
4
respostas

Problema de conexão servidor remoto

Executei normalmente o script prepara_banco.py, criando meu banco remotamente em meu servidor e inserindo os dados. Ao prosseguir com a codificação em aula, /novo inseri os dados e depois repetidamente recebi a mensagem de: MySQLdb._exceptions.OperationalError: (2013, "Lost connection to MySQL server at 'waiting for initial communication packet', system error: 110").

Segue codificação:

from flask import Flask, render_template, request, redirect, session, flash,\
    url_for
from models import Jogo, Usuario
from dao import JogoDao
from flask_mysqldb import MySQL


app = Flask(__name__)
app.secret_key = 'alura'

app.config['MYSQL_HOST'] = "192.168.1.100"
app.config['MYSQL_USER'] = "programador"
app.config['MYSQL_PASSWORD'] = "programador"
app.config['MYSQL_DB'] = "jogoteca"
app.config['MYSQL_PORT'] = 3306


db = MySQL(app)

jogo_dao = JogoDao(db)


usuario1 = Usuario('luan', 'Luan Marques', '1234')
usuario2 = Usuario('Nico', 'Nico Steppat', '7a1')
usuario3 = Usuario('flavio', 'flavio Almeida', 'javascript')

usuarios = {usuario1.id: usuario1,
            usuario2.id: usuario2,
            usuario3.id: usuario3}


jogo1 = Jogo('Super Mario', 'Ação', 'SNES')
jogo2 = Jogo('Pokemon Gold', 'RPG', 'GBA')
lista = [jogo1, jogo2]


@app.route('/')
def index():
    return render_template('lista.html', titulo='Jogos', jogos=lista)


@app.route('/novo')
def novo():
    if 'usuario_logado' not in session or session['usuario_logado'] == None:
        return redirect(url_for('login', proxima=url_for('novo')))
    return render_template('novo.html', titulo='Novo Jogo')


@app.route('/criar', methods=['POST', ])
def criar():
    nome = request. form['nome']
    categoria = request. form['categoria']
    console = request. form['console']
    jogo = Jogo(nome, categoria, console)
    jogo_dao.salvar(jogo)
    return redirect(url_for('index'))


@app.route('/login')
def login():
    proxima = request.args.get('proxima')
    return render_template('login.html', proxima=proxima)


@app.route('/autenticar', methods=['POST', ])
def autenticar():
    if request.form['usuario'] in usuarios:
        usuario = usuarios[request.form['usuario']]
        if usuario.senha == request.form['senha']:
            session['usuario_logado'] = usuario.id
            flash(usuario.nome + ' logou com sucesso!')
            proxima_pagina = request.form['proxima']
            return redirect(proxima_pagina)
    else:
        flash('Não logado, tente novamente!')
        return redirect(url_for('login'))


@app.route('/logout')
def logout():
    session['usuario_logado'] = None
    flash('Nenhum usuário logado!')
    return redirect(url_for('index'))


app.run(debug=True)

Obs.: A maquina de desenvolvimento é diferente da máquina que está instalada o servidor de banco de dados. Percebo que após executar a rotina do novo, a barra inferior do chrome fica buscando em 127.0.0.1. mariadb --version mariadb Ver 15.1 Distrib 10.3.18-MariaDB, for debian-linux-gnu (x86_64) using readline 5.2

4 respostas
Removido a pedido do usuario.

Obrigado por responder. Porem, através do método:

import MySQLdb                                                         
print('Conectando...')                                                 
conn = MySQLdb.connect(user='programador', passwd='programador', host='192.168.1.100', port=3306) 

que foi utilizado no script "prepara_banco.py", ocorreu a conexão perfeitamente. Além da conexão ocorrer perfeitamente, pude executar todo o script, criando banco de dados, criando a tabela e alimentando ela.

O problema é que ao executar a parte de conexão proposta, através do método:

from flask import Flask, render_template, request, redirect, session, flash,\
    url_for
from models import Jogo, Usuario
from dao import JogoDao
from flask_mysqldb import MySQL


app = Flask(__name__)
app.secret_key = 'alura'

app.config['MYSQL_HOST'] = "192.168.1.100"
app.config['MYSQL_USER'] = "programador"
app.config['MYSQL_PASSWORD'] = "programador"
app.config['MYSQL_DB'] = "jogoteca"
app.config['MYSQL_PORT'] = 3306

A conexão não ocorre, retornando as mensagens citadas no escopo deste tópico:

MySQLdb._exceptions.OperationalError: (2013, "Lost connection to MySQL server at 'waiting for initial communication packet', system error: 110")

Se o problema fosse permissões de acesso, não ocorreria a conexão nem através do método usado em prepara_banco.py.

Mais uma vez agradeço a atenção, mas continuo no mesmo impasse.

Removido a pedido do usuario.
solução!

Mais uma vez muito obrigado pela colaboração. Após ler o material que você enviou, desinstalei o flask e flask-mysql sugerido anteriormente no curso e fiz a instalação através do comando:

pip3 install flask flask-mysql

Ignorando a versão sugerida no curso. Desta forma, foi possível realizar a operação junto ao banco de dados sem qualquer alteração em linha de código.