Mac Developer Library Developer


This manual page is for Mac OS X version 10.9

If you are running a different version of Mac OS X, view the documentation locally:

  • In Terminal, using the man(1) command

Reading manual pages

Manual pages are intended as a quick reference for people who already understand a technology.

  • To learn how the manual is organized or to learn about command syntax, read the manual page for manpages(5).

  • For more information about this technology, look for other documentation in the Apple Developer Library.

  • For general information about writing shell scripts, read Shell Scripting Primer.

GENRSA(1)                                          OpenSSL                                         GENRSA(1)

       genrsa - generate an RSA private key

       openssl genrsa [-out filename] [-passout arg] [-des] [-des3] [-idea] [-f4] [-3] [-rand file(s)]
       [-engine id] [numbits]

       The genrsa command generates an RSA private key.

       -out filename
           the output filename. If this argument is not specified then standard output is used.

       -passout arg
           the output file password source. For more information about the format of arg see the PASS PHRASE
           ARGUMENTS section in openssl(1).

           These options encrypt the private key with the DES, triple DES, or the IDEA ciphers respectively
           before outputting it. If none of these options is specified no encryption is used. If encryption
           is used a pass phrase is prompted for if it is not supplied via the -passout argument.

           the public exponent to use, either 65537 or 3. The default is 65537.

       -rand file(s)
           a file or files containing random data used to seed the random number generator, or an EGD socket
           (see RAND_egd(3)).  Multiple files can be specified separated by a OS-dependent character.  The
           separator is ; for MS-Windows, , for OpenVMS, and : for all others.

       -engine id
           specifying an engine (by it's unique id string) will cause req to attempt to obtain a functional
           reference to the specified engine, thus initialising it if needed. The engine will then be set as
           the default for all available algorithms.

           the size of the private key to generate in bits. This must be the last option specified. The
           default is 512.

       RSA private key generation essentially involves the generation of two prime numbers. When generating
       a private key various symbols will be output to indicate the progress of the generation. A .
       represents each number which has passed an initial sieve test, + means a number has passed a single
       round of the Miller-Rabin primality test. A newline means that the number has passed all the prime
       tests (the actual number depends on the key size).

       Because key generation is a random process the time taken to generate a key may vary somewhat.

       A quirk of the prime generation algorithm is that it cannot generate small primes. Therefore the
       number of bits should not be less that 64. For typical private keys this will not matter because for
       security reasons they will be much larger (typically 1024 bits).


50                                               2013-03-05                                        GENRSA(1)

Reporting Problems

The way to report a problem with this manual page depends on the type of problem:

Content errors
Report errors in the content of this documentation to the OpenSSL project by sending email to
Bug reports
Report bugs in the functionality of the described tool or API to Apple through Bug Reporter and to the OpenSSL project by sending email to
Formatting problems
Report formatting mistakes in the online version of these pages with the feedback links below.