I have a python script that connects to a remote MySQL database using the python library MySQLdb. It works fine but how can I get it to connect through a proxy that I'm behind when at work. I can connect via the command line in ssh, but how do I get the python script to use the proxy settings. There doesnt seem to be any options in the MySQLdb commands for proxy configurations.
import MySQLdb as mdb
conn=mdb.connect(host='mysite.com',user='myuser',passwd='mypassword',db='mydb')
cursor = conn.cursor()
I know this is a rather old post, but I thought I'd answer it anyway. you can use your SSH connection as a proxy The easiest way it to use
proxychains
The default port for proxychains is 9050 so when when you connect to the remote host include the-D
parameter like:ssh -D 9050 -l user remotehost
Then from a separate terminal window, or usingscreen
, on your local machine any command you preface withproxychains
is routed through the SSH server, for example:proxychains python myscript.py
will route all outbound TCP requests, whether a database connection or a urllib2/requests HTTP(S) request. Proxychains is not specific to python, but anything. You can just as easily launch a web browser or anything else. Tryproxychains firefox
orproxychains curl https://api.ipify.org