diff --git a/doc/source/contributor/api-ref-guideline.rst b/doc/source/contributor/api-ref-guideline.rst
new file mode 100644
index 000000000000..4cca9f6e3e0f
--- /dev/null
+++ b/doc/source/contributor/api-ref-guideline.rst
@@ -0,0 +1,233 @@
+=======================
+API reference guideline
+=======================
+
+The API reference should be updated when compute or placement APIs are modified
+(microversion is bumped, etc.).
+This page describes the guideline for updating the API reference.
+
+API reference
+=============
+
+* `Compute API reference `_
+* `Placement API reference `_
+
+The guideline to write the API reference
+========================================
+
+The API reference consists of the following files.
+
+Compute API reference
+---------------------
+
+* API reference text: ``api-ref/source/*.inc``
+* Parameter definition: ``api-ref/source/parameters.yaml``
+* JSON request/response samples: ``doc/api_samples/*``
+
+Placement API reference
+-----------------------
+
+* API reference text: ``placement-api-ref/source/*.inc``
+* Parameter definition: ``placement-api-ref/source/parameters.yaml``
+* JSON request/response samples: ``placement-api-ref/source/samples/*``
+
+Structure of inc file
+---------------------
+
+Each REST API is described in the text file (\*.inc).
+The structure of inc file is as follows:
+
+- Title
+
+ - API Name
+
+ - REST Method
+
+ - URL
+ - Description
+ - Normal status code
+ - Error status code
+ - Request
+
+ - Parameters
+ - JSON request body example (if exists)
+ - Response
+
+ - Parameters
+ - JSON response body example (if exists)
+ - API Name (Next)
+
+ - ...
+
+REST Method
+-----------
+
+The guideline for describing HTTP methods is described in this section.
+All supported methods by resource should be listed in the API reference.
+
+The order of methods
+~~~~~~~~~~~~~~~~~~~~
+
+Methods have to be sorted by each URI in the following order:
+
+1. GET
+2. POST
+3. PUT
+4. PATCH (unused by Nova)
+5. DELETE
+
+And sorted from broadest to narrowest. So for /severs it would be:
+
+1. GET /servers
+2. POST /servers
+3. GET /servers/details
+4. GET /servers/{server_id}
+5. PUT /servers/{server_id}
+6. DELETE /servers/{server_id}
+
+Method titles spelling and case
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+The spelling and the case of method names in the title have to match
+what is in the code. For instance, the title for the section on method
+"Get Rdp Console" should be "Get Rdp Console (os-getRDPConsole Action)"
+NOT "Get Rdp Console (Os-Getrdpconsole Action)"
+
+Response codes
+~~~~~~~~~~~~~~
+
+The normal response codes (20x) and error response codes
+have to be listed. The order of response codes should be in ascending order.
+The description of typical error response codes are as follows:
+
+.. list-table:: Error response codes
+ :header-rows: 1
+
+ * - Response codes
+ - Description
+ * - 400
+ - badRequest(400)
+ * - 401
+ - unauthorized(401)
+ * - 403
+ - forbidden(403)
+ * - 404
+ - itemNotFound(404)
+ * - 409
+ - conflict(409)
+ * - 410
+ - gone(410)
+ * - 501
+ - notImplemented(501)
+ * - 503
+ - serviceUnavailable(503)
+
+Parameters
+----------
+
+Parameters need to be defined by 2 subsections.
+The one is in the 'Request' subsection, the other is in the 'Response'
+subsection. The queries, request headers and attributes go in the 'Request'
+subsection and response headers and attributes go in the 'Response'
+subsection.
+
+The order of parameters in each API
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+The request and response parameters have to be listed in the following order
+in each API in the text file.
+
+1. Header
+2. Path
+3. Query
+4. Body
+
+ a. Top level object (i.e. server)
+ b. Required fields
+ c. Optional fields
+ d. Parameters added in microversions (by the microversion they were added)
+
+Parameter type
+~~~~~~~~~~~~~~
+
+The parameters are defined in the parameter file (``parameters.yaml``).
+The type of parameters have to be one of followings:
+
+* ``array``
+
+ It is a list.
+
+* ``boolean``
+* ``float``
+* ``integer``
+* ``none``
+
+ The value is always ``null`` in a response or
+ should be ``null`` in a request.
+
+* ``object``
+
+ The value is dict.
+
+* ``string``
+
+ If the value can be specified by multiple types, specify one type
+ in the file and mention the other types in the description.
+
+Required or optional
+~~~~~~~~~~~~~~~~~~~~
+
+In the parameter file, define the ``required`` field in each parameter.
+
+.. list-table::
+ :widths: 15 85
+
+ * - ``true``
+ - The parameter must be specified in the request, or
+ the parameter always appears in the response.
+ * - ``false``
+ - It is not always necessary to specify the parameter in the request, or
+ the parameter does not appear in the response in some cases.
+ e.g. A config option defines whether the parameter appears
+ in the response or not. A parameter appears when administrators call
+ but does not appear when non-admin users call.
+
+If a parameter must be specified in the request or always appears
+in the response in the micoversion added or later,
+the parameter must be defined as required (``true``).
+
+The order of parameters in the parameter file
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+The order of parameters in the parameter file has to be kept as follows:
+
+1. By in type
+
+ a. Header
+ b. Path
+ c. Query
+ d. Body
+
+2. Then alphabetical by name
+
+Example
+-------
+
+.. TODO::
+
+ The guideline for request/response JSON bodies should be added.
+
+Body
+----
+
+.. TODO::
+
+ The guideline for the introductory text and the context for the resource
+ in question should be added.
+
+Reference
+=========
+
+* `Verifying the Nova API Ref `_
+* `The description for Parameters whose values are null `_
+* `The definition of "Optional" parameter `_
diff --git a/doc/source/contributor/index.rst b/doc/source/contributor/index.rst
index ef08f82d8b38..8116bacb514a 100644
--- a/doc/source/contributor/index.rst
+++ b/doc/source/contributor/index.rst
@@ -90,6 +90,9 @@ changes done to the API, as the impact can be very wide.
you need to do when adding an API exposed feature that needs a new
microversion.
+* :doc:`/contributor/api-ref-guideline`: The guideline to write the API
+ reference.
+
Nova Major Subsystems
=====================
diff --git a/doc/source/index.rst b/doc/source/index.rst
index d5c9ad726516..5a2dd2d69f6e 100644
--- a/doc/source/index.rst
+++ b/doc/source/index.rst
@@ -210,6 +210,7 @@ looking parts of our architecture. These are collected below.
contributor/development-environment
contributor/api
contributor/api-2
+ contributor/api-ref-guideline
contributor/blueprints
contributor/code-review
contributor/documentation