Skip to content

Instantly share code, notes, and snippets.

@batok
Created April 10, 2012 16:11
Show Gist options
  • Select an option

  • Save batok/2352501 to your computer and use it in GitHub Desktop.

Select an option

Save batok/2352501 to your computer and use it in GitHub Desktop.
Paramiko example using private key
import paramiko
k = paramiko.RSAKey.from_private_key_file("/Users/whatever/Downloads/mykey.pem")
c = paramiko.SSHClient()
c.set_missing_host_key_policy(paramiko.AutoAddPolicy())
print "connecting"
c.connect( hostname = "www.acme.com", username = "ubuntu", pkey = k )
print "connected"
commands = [ "/home/ubuntu/firstscript.sh", "/home/ubuntu/secondscript.sh" ]
for command in commands:
print "Executing {}".format( command )
stdin , stdout, stderr = c.exec_command(command)
print stdout.read()
print( "Errors")
print stderr.read()
c.close()
@iv8

iv8 commented Feb 28, 2019

Copy link
Copy Markdown

Thanks

@Mortimrr

Mortimrr commented Aug 1, 2019

Copy link
Copy Markdown

error: raise TypeError("Expected unicode or bytes, got {!r}".format(s))
TypeError: Expected unicode or bytes, got <paramiko.rsakey.RSAKey object at 0x000002909C542D30>

use pythn3.7 and lasted paramiko.
Can someone help me?

@kartikgvv

Copy link
Copy Markdown

not working
resulted error is "paramiko.ssh_exception.SSHException: not a valid RSA private key file"

there is my file data
---- BEGIN SSH2 PUBLIC KEY ----
Comment: "rsa-key-20111127"
AAAAB3NzaC1yc2EAAAABJQAAAIEAqAxgtgyVlblABlabLa
---- END SSH2 PUBLIC KEY ----

Please dont share any kind of keys although shown in comments

@ThaRising

Copy link
Copy Markdown

Thank you so much for providing this example!

@darshanpatil94

Copy link
Copy Markdown

I found this link useful: https://adamdehaven.com/blog/how-to-generate-an-ssh-key-and-add-your-public-key-to-the-server-for-authentication/
Added the key id_rsa to ssh-agent, and
In python code: ssh.connect(hostname, username=myuser, look_for_keys=True, allow_agent=True)
got rid of this errror. hope this helps.

@megustador

Copy link
Copy Markdown

update paramiko to latest version and then it will work even with you new OPENSSH key format

@jasonsychau

Copy link
Copy Markdown

@alexanderfournier make ssh key on computer, authorise on server, use key in program

@iamrahulgupta7

Copy link
Copy Markdown

Error:

File "/usr/lib/python3.6/site-packages/paramiko/pkey.py", line 289, in _read_private_key
raise SSHException("not a valid " + tag + " private key file")
paramiko.ssh_exception.SSHException: not a valid RSA private key file

it worked for me when I created key with type RSA

ssh-keygen -m pem -t rsa

moreover in python3.8 print statement will not work the way it is mentioned above. Also changed from read to readlines and created a loop

xlist = (stdout.readlines())
for i in xlist:
print(i)
print("++++++++++++++++")

Nothing else need to be changed.

@StefanoGITA

Copy link
Copy Markdown

Just a note, if you have generated your keys via puttygen and they are in ppk format, it's not going to work, go back to puttygen, load you ppk key and export it as OpenSSH (Conversion -> Export OpenSSH Key)

Hi, I've converted the file to OpenSSH (with puttygen)
but now if I use pkey = pk.RSAKey.from_private_key_file(key_filename)
On the connect I got

Authentication failed

If I use the filename
ssh.connect(hostname=ip_server, username=username, key_filename=key_filename)
I got

 raise ValueError("q must be exactly 160, 224, or 256 bits long")

ValueError: q must be exactly 160, 224, or 256 bits long

@sarthak405

Copy link
Copy Markdown

Just a note, if you have generated your keys via puttygen and they are in ppk format, it's not going to work, go back to puttygen, load you ppk key and export it as OpenSSH (Conversion -> Export OpenSSH Key)

Worked perfectly for me. Thanks a lot!

@Amanjain98

Copy link
Copy Markdown

Not working for me

Traceback (most recent call last):
File "/opt/cms/scripts/bam_sdrtrace.py", line 227, in
transfer_file1()
File "/opt/cms/scripts/bam_sdrtrace.py", line 148, in transfer_file1
k = paramiko.RSAKey.from_private_key_file("/home/esbc/.ssh/authorized_keys")
File "/usr/lib/python2.7/site-packages/paramiko/pkey.py", line 196, in from_private_key_file
key = cls(filename=filename, password=password)
File "/usr/lib/python2.7/site-packages/paramiko/rsakey.py", line 45, in init
self._from_private_key_file(filename, password)
File "/usr/lib/python2.7/site-packages/paramiko/rsakey.py", line 163, in _from_private_key_file
data = self._read_private_key_file('RSA', filename, password)
File "/usr/lib/python2.7/site-packages/paramiko/pkey.py", line 268, in _read_private_key_file
data = self._read_private_key(tag, f, password)
File "/usr/lib/python2.7/site-packages/paramiko/pkey.py", line 277, in _read_private_key
raise SSHException('not a valid ' + tag + ' private key file')
paramiko.ssh_exception.SSHException: not a valid RSA private key file

@anilmhaske1991

Copy link
Copy Markdown

socket.py", line 918, in getaddrinfo for res in _socket.getaddrinfo(host, port, family, type, proto, flags):
socket.gaierror: [Errno 11001] getaddrinfo failed
what's wrong

@vickyvikas7988

Copy link
Copy Markdown

Not working for me, while use the key using ssh client it works

Traceback (most recent call last):
File "/Users/xx/code/compute-ops/scripts/launch_intance_benchmark.py", line 105, in
k = paramiko.RSAKey.from_private_key_file("/Users/xx/.ssh/id_rsa.pem")
File "/Users/xx/code/compute-ops/venv3/lib/python3.7/site-packages/paramiko/pkey.py", line 206, in from_private_key_file
key = cls(filename=filename, password=password)
File "/Users/xx/code/compute-ops/venv3/lib/python3.7/site-packages/paramiko/rsakey.py", line 48, in init
self._from_private_key_file(filename, password)
File "/Users/xx/code/compute-ops/venv3/lib/python3.7/site-packages/paramiko/rsakey.py", line 169, in _from_private_key_file
data = self._read_private_key_file('RSA', filename, password)
File "/Users/xx/code/compute-ops/venv3/lib/python3.7/site-packages/paramiko/pkey.py", line 279, in _read_private_key_file
data = self._read_private_key(tag, f, password)
File "/Users/xx/code/compute-ops/venv3/lib/python3.7/site-packages/paramiko/pkey.py", line 289, in _read_private_key
raise SSHException('not a valid ' + tag + ' private key file')
paramiko.ssh_exception.SSHException: not a valid RSA private key file

@vickyvikas7988

Copy link
Copy Markdown

Converting the key
resolves the error
ssh-keygen -p -m PEM -f ~/.ssh/id_rsa

@dovanpho

dovanpho commented May 7, 2021

Copy link
Copy Markdown

thanks.
if your private key is in .ppk, you need convert to .pem.

@rdiazg14

Copy link
Copy Markdown

I resolve this problem with version paramiko-2.10.4

@jyotsna-atrium

Copy link
Copy Markdown

I see this error:

ModuleNotFoundError: No module named 'paramiko'

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment