Supported File URL Formats for Writers
The File URL attribute lets you type in the file URL directly, or open the URL File Dialog.
The URL shown below can also contain placeholders – a dollar sign or hash sign.
Important | |
---|---|
Dollar and hash signs serve for different purposes.
|
Below are examples of possible URLs for Writers:
Writing to Local Files
/path/filename.out
Writes specified file on disk.
/path1/filename1.out;/path2/filename2.out
Writes two specified files on disk.
/path/filename$.out
Writes a number of files on disk. The dollar sign represents one digit. Thus, the output files can have the name range from
filename0.out
tofilename9.out
. The dollar sign is used when Records per file is set./path/filename$$.out
Writes a number of files on disk. Two dollar signs represent two digits. Thus, the output files can have the name range from
filename00.out
tofilename99.out
. The dollar sign is used when Records per file is set./path/filename#.out
Writes a number of files on disk. If Partition file tag is set to Key file tag, the hash sign in the file name is replaced with Partition key field value. Otherwise, the hash sign is replaced with number.
zip:(/path/file$.zip)
Writes a number of compressed files on disk. The dollar sign represents one digit. Thus, the compressed output files can have the names from
file0.zip
tofile9.zip
. The dollar sign is used when Records per file is set.zip:(/path/file$.zip)#innerfolder/filename.out
Writes a specified file inside the compressed files on disk. The dollar sign represents one digit. Thus, the compressed output files containing the specified
filename.out
file can have the name range fromfile0.zip
tofile9.zip
. The dollar sign is used when Records per file is set.gzip:(/path/file$.gz)
Writes a number of compressed files on disk. The dollar sign represents one digit. Thus, the compressed output files can have the name ranges from
file0.gz
tofile9.gz
. The dollar sign is used when Records per file is set.
Note | |
---|---|
Although CloverDX can read data from a |
Writing to Remote Files
ftp://user:password@server/path/filename.out
Writes a specified
filename.out
file on a remote server connected via an FTP protocol using username and password.sftp://user:password@server/path/filename.out
Writes a specified
filename.out
file on a remote server connected via an SFTP protocol using a username and password.If a certificate-based authentication is used, certificates are placed in the
${PROJECT}/ssh-keys/
directory. For more information, see SFTP Certificate in CloverDX.Note, that only certificates without a password are currently supported. The certificate-based authentication has a URL without a password:
sftp://username@server/path/filename.txt
zip:(ftp://username:password@server/path/file.zip)#innerfolder/filename.txt
Writes a specified
filename.txt
file compressed in thefile.zip
file on a remote server connected via an FTP protocol using username and password.zip:(ftp://username:password@server/path/file.zip)#innerfolder/filename.txt
Writes a specified
filename.txt
file compressed in thefile.zip
file on a remote server connected via an FTP protocol.zip:(zip:(ftp://username:password@server/path/name.zip)#innerfolder/file.zip)#innermostfolder/filename.txt
Writes a specified
filename.txt
file compressed in afile.zip
file that is also compressed in aname.zip
file on a remote server connected via an FTP protocol using username and password.gzip:(ftp://username:password@server/path/file.gz)
Writes the first file compressed in a
file.gz
file on a remote server connected via an FTP protocol.http://username:password@server/filename.out
Writes a specified
filename.out
file on a remote server connected via a WebDAV protocol using username and password.s3://access_key_id:secret_access_key@s3.amazonaws.com/bucketname/path/filename.out
Writes to
path/filename.out
object located in the Amazon S3 web storage service in a bucketbucketname
using an access key ID and secret access key.See Amazon S3 URL.
It is recommended to connect to S3 via a region-specific S3 URL:
s3://s3.eu-central-1.amazonaws.com/bucket.name/
. A region-specific URL have much better performance than a generic one (s3://s3.amazonaws.com/bucket.name/
).See recommendation on Amazon S3 URL.
Note s3:// URL protocol is available since CloverETL 4.1. More information about the deprecated http:// S3 protocol can be found in CloverDX 4.0 User Guide.
hdfs://CONN_ID/path/filename.dat
Writes a file on a Hadoop distributed file system (HDFS). To which HDFS NameNode to connect to is defined in a Hadoop connection with
CONN_ID
. This example file URL writes a file with/path/filename.dat
absolute HDFS path.smb://domain%3Buser:password@server/path/filename.txt
Writes a file to a Windows share (Microsoft SMB version 1/CIFS protocol). The
server
part may be a DNS name, an IP address or a NetBIOS name. The Userinfo part of the URL (domain%3Buser:password
) is not mandatory and any URL reserved character it contains should be escaped using the %-encoding similarly to the semicolon;
character with%3B
in the example (the semicolon is escaped because it collides with the default CloverDX file URL separator). Also note that the dollar sign$
in the URL path (e.g. in the case of writing to an Administrative share) is reserved for the file partitioning feature so it too needs be escaped (with%24
).The SMB protocol is implemented in the JCIFS library which may be configured using Java system properties. For a list of all configurable properties, see Setting Client Properties in JCIFS documentation.
smb2://domain%3Buser:password@server/path/filename.txt
Writes a file to a Windows share (Microsoft SMB version 2 and 3).
The SMB version 2 and 3 protocol is implemented in the SMBJ library which depends on the Bouncy Castle library.
Writing to Output Port
port:$0.FieldName:discrete
If this URL is used, the output port of the Writer must be connected to another component. Output metadata must contain a
FieldName
of one of the following data types:string
,byte
orcbyte
. Each data record that is received by the Writer through the input port is processed according to the input metadata, sent out through the optional output port, and written as the value of the specified field of the metadata of the output edge. Next records are parsed in the same way as described here.
Using Proxy in Writers
http:(direct:)//seznam.cz
Without proxy.
http:(proxy://user:password@212.93.193.82:443)//seznam.cz
Proxy setting for HTTP protocol.
ftp:(proxy://user:password@proxyserver:1234)//seznam.cz
Proxy setting for ftp protocol.
ftp:(proxy://proxyserver:443)//server/path/file.dat
Proxy setting for FTP protocol.
sftp:(proxy://66.11.122.193:443)//user:password@server/path/file.dat
Proxy setting for SFTP protocol.
s3:(proxy://user:password@66.11.122.193:443)//access_key_id:secret_access_key@s3.amazonaws.com/bucketname/path/filename.out
Proxy setting for S3 protocol.
Writing to Dictionary
Sandbox Resource as Data Source
A sandbox resource, whether it is a shared, local or partitioned sandbox, is specified in the graph under the fileURL attributes as a so called sandbox URL like:
sandbox://data/path/to/file/file.dat
where data
is a code for sandbox
and path/to/file/file.dat
is the path to the resource from the sandbox root.
The URL is evaluated by CloverDX Server during graph execution
and a component (Reader or Writer) obtains the opened stream from the Server.
This may be a stream to a local file or to some other remote resource.
Thus, a graph does not have to run on the node which has local access to the resource.
There may be more sandbox resources used in the graph and each of them may be on a different node.
In such cases, CloverDX Server would choose the node with the most local resources to minimize remote streams.
The sandbox URL has a specific use for parallel data processing. When the sandbox URL with the resource in a partitioned sandbox is used, that part of graph/phase runs in parallel, according to the node allocation specified by the list of partitioned sandbox locations. Thus, each worker has its own local sandbox resource. CloverDX Server evaluates the sandbox URL on each worker and provides an open stream to a local resource to the component.