targetd exposes a remote API for configuring a Linux host to perform a block-based storage array role and a file system storage role. API calls use the jsonrpc-2.0 format over HTTP, on TCP port 18700. The API optionally uses TLS for connection encryption, but does authentication via HTTP Basic auth for both encrypted and non-encrypted connections.
Raw storage space on the host is a pool
. From a pool, a volume
vol
is allocated. A volume is shared with remote hosts via an
export
.
For file system related operations, the pool refers to a btrfs mount point. Each newly created file system is a subvolume on that mount point.
- All sizes are in bytes, and are passed as numbers.
- All names must only contain characters in '[a-z][A-Z][0-9]_-'
- Uuid fields are represented as strings.
- If an error occurs, it will be indicated by returning a jsonrpc error object with a negative error code. Non-negative error codes (including 0) are not defined.
Pools are configured on the host, and are not remotely configurable via this API.
Returns an array of pool objects. Each pool object contains name
,
size
, free_size
, and type
fields, and may also contain a 'uuid'
field. The domain of the type field is [block|fs].
Returns an array of volume objects in pool
. Each volume object
contains name
, size
, and uuid
fields.
Volume names may be reused, such as when a volume is created and then removed. Another volume could then be created with the same name, but the new volume's UUID would be a different, unique value.
Creates a volume named name
with size size
in the pool pool
.
Removes name
volume from pool pool
. This destroys the backing
data, and the data in the volume is lost even if another volume with
the same name is created.
Creates a new volume named vol_new
in pool
the same size as
vol_orig
in pool
, and copies the contents from vol_orig
into
vol_new
. vol_orig
and vol_new
will have differing UUIDs.
Exports make a volume accessible to a remote iSCSI initiator.
Returns an array of export objects. Each export object contains
initiator_wwn
, lun
, vol_name
, vol_size
, vol_uuid
, and
pool
. initiator_wwn
is the iSCSI name (iqn.*) of the initiator
with access to the export. lun
is the SCSI logical unit number the
initiator will see for this export. vol_name
is the name of the
backing volume. vol_uuid
and vol_size
return the unique identifier
and size of the volume. The pool
attribute is the name of the pool
containing the backing volume.
Creates an export of volume vol
in pool pool
to the given
initiator, and maps it to logical unit number lun
.
Removes an export of vol
in pool
to initiator_wwn
.
Sets the inbound and outbound login credentials for the given initiator. 'in_user' and 'in_pass' are credentials that the initiator will use to login to the target and access luns exported by 'export_create'. 'out_user' and 'out_pass' are the credentials the target will use to authenticate itself back to the initiator.
'initiator_wwn' must be set, but 'in_user', 'in_pass', 'out_user' and 'out_pass' may be 'null'. If either or both of each directions' parameters are 'null', then authentication is disabled for that direction.
Calling this method is not required for exports to work. If it is not called, exports require no authentication.
List all initiators. Parameters: standalone_only(bool, optional): If 'standalone_only' is True, only return initiator which is not in any NodeACLGroup. By default, all initiators will be included in result. Returns: [ { 'init_id': str, 'init_type': str, }, ] The 'init_id' of result is the iSCSI IQN/NAA/EUI address of initiator. Example: 'iqn.2000-04.com.example:someone-01' The 'init_type' is reserved for future use, currently, it is 'iscsi'.
Errors: N/A
Access Group is a group of initiators which sharing the same volume mapping status.
List all access groups.
Parameters: N/A Returns: [ { 'name': str 'init_ids': list(str), 'init_type': str, }, ] The 'name' is the name of acccess group. The 'init_ids' of result is the iSCSI IQN/NAA/EUI address of initiators which belong to current access group. Example: ['iqn.2000-04.com.example:someone-01'] The 'init_type' is reserved for future use, currently, it is 'iscsi'.
Errors: N/A
Create new access group.
Parameters: ag_name (str): Access group name init_id (str): iSCSI initiator address init_type (str): Reserved for future use. Should be set as 'iscsi' Returns: N/A Errors: -32602: Invalid parameter. Provided 'ag_name' is illegal. Check 'Conventions' for detail. -153: No support. The 'init_type' is not 'iscsi' -50: Name conflict. Requested 'ag_name' is in use -52: Exists initiator. Requested 'init_id' is in use
Delete a access group including it's initiator and volume masking status. No error will be raised even provided access group name does not exist. Parameters: ag_name (str): Access group name Returns: N/A Errors: N/A
Add a new initiator into a access group. If defined access group does not exist, create one with requested initiator. Parameters: ag_name (str): Access group name init_id (str): iSCSI initiator address init_type (str): Reserved for future use. Should be set as 'iscsi' Returns: N/A Errors: -52: Exists initiator. Requested 'init_id' is in use
Remove a initiator from an access group. If requested initiator not in defined access group, return silently. If defined access group does not exist, return silently. Parameters: ag_name (str): Access group name init_id (str): iSCSI initiator address init_type (str): Reserved for future use. Should be set as 'iscsi' Returns: N/A Errors: N/A
Query volume mapping status of all access groups. Parameters: N/A Returns: [ { 'ag_name': str, 'h_lun_id': int, 'pool_name': str, 'vol_name': str, } ] The 'ag_name' is the name of access group. The 'h_lun_id' is the SCSI LUN ID seen by iSCSI initiator. The 'pool_name' is the name of pool which volume is belonging to. The 'vol_name' is the name of volume. Errors: N/A
Grant certain access group the rw access to defined volume. Parameters: pool_name (str): The name of pool which defined volume belongs to. vol_name (str): The name of volume. ag_name (str): Access group name h_lun_id (int, optional): Host LUN ID (the SCSI LUN ID seen by iSCSI initiator). Range is 0 to 255. If not defined, targetd will try to find the next available one. Returns: N/A Errors: -1000: No free host_lun_id. LUN ID between 0 ~ 255 is in use. -200: Access group not found.
Revoke the rw access of certain access group to defined volume. Parameters: pool_name (str): The name of pool which defined volume belongs to. vol_name (str): The name of volume. ag_name (str): Access group name Returns: N/A Errors: N/A
Ability to create different file systems and perform operation on them. The pool is a btrfs sub volume and new file systems are sub volumes within that sub volume.
Returns an array of file system objects. Each file system object contains:
name
, uuid
, total_space
, free_space
and pool
they were created from.
Destroys the sub volume identified by file system uuid
and any snapshots
created from it.
Create a new sub volume within the specified pool_name
with the new name
.
The parameter size_bytes
is currently ignored, but will eventually be used
to set the quota for the sub volume.
Create a read/write-able copy of the file system with uuid fs_uuid
to the new
name of dest_fs_name
. If snapshot_id
is specified the new file system
contents will be created from the snapshot copy.
Returns an array of read only snapshot objects for the file system specified in
fs_uuid
. The returned objects contain: name
, uuid
, timestamp
. Time
stamp is when the snapshot was taken and it is represented as seconds from epoch.
Creates a read only copy of the file system specified by fs_uuid
. The new
file system has the name represented by dest_ss_name
.
Deletes the read only snapshot specified by fs_uuid
and ss_uuid
.
Returns an array of supported NFS client authentication mechanisms.
Returns an array of export objects. Each export object contains: host
, path
, options
.
Adds a NFS export given a host
, and an export path
to export and a list of options
Options is a list of NFS export options. Each option can be either a single value
eg. no_root_squash or can be a key=value
like sec=sys
. See man 5 exports
for all available
supported options and the formats supported for host
.
Removes a NFS export given a host
and an export path
Obsolete, no longer defined.