Did you find a solution ?

*here is my connection string:*

db = 
DAL('mysql://user%40w-mysql-001-se:water123...@w-mysql-1254-se.mysql.database.azure.com/dbname',
 decode_credentials=True)


Now it is showing 

InternalError: (1043, u'Bad handshake')



On Friday, December 1, 2017 at 6:40:29 AM UTC+6, Daniel Luna wrote:
>
> I Strill trying to connect, idk if my uri string is wrong, or if i did a 
> mistake. Anyway, my string is like this-> 
> mysql://user@db:password@server:3306/db 
>
 

> And my DAL is like this -> DAL(myconf.get('db.uri'),
> pool_size=myconf.get('db.pool_size'),
> migrate_enabled=myconf.get('db.migrate'),
> check_reserved=['all'], decode_credentials=True)
>
> Em domingo, 11 de junho de 2017 04:38:40 UTC-3, Massimo Di Pierro escreveu:
>>
>> I was having the same problem.
>>
>> DAL(..., decode_credentials=True) 
>>
>> this will allow you to have urlencoded (@ -> %40) username and password.
>>
>> Massimo
>>
>>
>>
>> On Thursday, 8 June 2017 16:06:32 UTC-5, Raul Romay Barrero wrote:
>>>
>>> Hi all,
>>>
>>> Azure has just launched "Azure database for MySQL" a managed Mysql 
>>> service. It's in PREVIEW state and I was giving it a try with our web2py 
>>> based application.
>>>
>>> Any user name you configure to connect to the database instance gets 
>>> appended an "@database_name", so in our case it's something like 
>>> 'user@mnp-db'. This is creating a problem when connecting to database:
>>>
>>> 2017-06-08 13:49:45,437 - cmp - 114405 - models.db.py - 44 - <module> - 
>>> ERROR - Exception generating DAL. Failure to connect, tried 5 times:
>>> Traceback (most recent call last):
>>>   File "/home/www-data/web2py/gluon/dal.py", line 7563, in __init__
>>>     self._adapter = ADAPTERS[self._dbname](**kwargs)
>>>   File "/home/www-data/web2py/gluon/dal.py", line 2573, in __init__
>>>     if do_connect: self.reconnect()
>>>   File "/home/www-data/web2py/gluon/dal.py", line 606, in reconnect
>>>     self.connection = f()
>>>   File "/home/www-data/web2py/gluon/dal.py", line 2571, in connector
>>>     return self.driver.connect(**driver_args)
>>>   File "/home/www-data/web2py/gluon/contrib/pymysql/__init__.py", line 
>>> 93, in Connect
>>>     return Connection(*args, **kwargs)
>>>   File "/home/www-data/web2py/gluon/contrib/pymysql/connections.py", 
>>> line 575, in __init__
>>>     self._connect()
>>>   File "/home/www-data/web2py/gluon/contrib/pymysql/connections.py", 
>>> line 741, in _connect
>>>     self._request_authentication()
>>>   File "/home/www-data/web2py/gluon/contrib/pymysql/connections.py", 
>>> line 796, in _request_authentication
>>>     self._send_authentication()
>>>   File "/home/www-data/web2py/gluon/contrib/pymysql/connections.py", 
>>> line 845, in _send_authentication
>>>     auth_packet.check_error()
>>>   File "/home/www-data/web2py/gluon/contrib/pymysql/connections.py", 
>>> line 341, in check_error
>>>     raise_mysql_exception(self.__data)
>>>   File "/home/www-data/web2py/gluon/contrib/pymysql/err.py", line 142, 
>>> in raise_mysql_exception
>>>     _check_mysql_exception(errinfo)
>>>   File "/home/www-data/web2py/gluon/contrib/pymysql/err.py", line 138, 
>>> in _check_mysql_exception
>>>     raise InternalError, (errno, errorvalue)
>>> InternalError: (2001, u'The server name you tried cannot be found. 
>>> Please use the correct name and retry. Please check your server name 
>>> mnp.\x00')
>>>
>>> The error is missleading as it's not related to the server name but to 
>>> the fact the user name includes an "@". Encoding it as %40 in the URI is 
>>> not solving the issue.
>>>
>>> I was debugging inside pymysql when I relized I could change to 
>>> MySQL-python. It worked fine.
>>>
>>> So hopefully this will save some of you some time.
>>>
>>> Another thing to consider is that this service is in PREVIEW state but 
>>> from my point of view is more an ALPHA state: connections from virtual 
>>> machines in same resource group that the database instance are reaching the 
>>> database through the public IP address, via internet. It's not only a 
>>> latency issue, nor a bandwith concern, also a privacy issue...
>>>
>>> Best regards,
>>> Raúl.
>>>
>>

-- 
Resources:
- http://web2py.com
- http://web2py.com/book (Documentation)
- http://github.com/web2py/web2py (Source code)
- https://code.google.com/p/web2py/issues/list (Report Issues)
--- 
You received this message because you are subscribed to the Google Groups 
"web2py-users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to web2py+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to