Skip to content

Commit

Permalink
Generate user cli doc
Browse files Browse the repository at this point in the history
- Add a new CLI command that iterates through the command tree and generates a markdown file based on each command's definition and description
- Migrate all the content in the previous User-CLI.md into the corresponding commands in golang code, mainly updating their `Long` and `Examples` fields
- Run `bin/alluxio generate user-cli` to write the generated content directly into `docs/en/operation/User-CLI.md`
			pr-link: #18144
			change-id: cid-9b29f273efef9693e1b0b303c62cc19602d77acc
  • Loading branch information
Xenorith authored Sep 19, 2023
1 parent db4fc2b commit dd863fe
Show file tree
Hide file tree
Showing 45 changed files with 1,225 additions and 685 deletions.
10 changes: 8 additions & 2 deletions cli/src/alluxio.org/cli/cmd/cache/format.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,8 +38,14 @@ func (c *FormatCommand) Base() *env.BaseJavaCommand {
func (c *FormatCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: Format.CommandName,
Short: "Format Alluxio worker nodes.",
Args: cobra.NoArgs,
Short: "Format Alluxio worker running locally",
Long: `The format command formats the Alluxio worker on this host.
This deletes all the cached data stored by the worker. Data in the under storage will not be changed.
> Warning: Format should only be called when the worker is not running`,
Example: `# Format worker
$ ./bin/alluxio cache format`,
Args: cobra.NoArgs,
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
Expand Down
19 changes: 8 additions & 11 deletions cli/src/alluxio.org/cli/cmd/cache/free.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,6 @@ type FreeCommand struct {
*env.BaseJavaCommand
worker string
path string
force bool
}

func (c *FreeCommand) Base() *env.BaseJavaCommand {
Expand All @@ -39,18 +38,20 @@ func (c *FreeCommand) Base() *env.BaseJavaCommand {

func (c *FreeCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: Free.CommandName,
Short: "Synchronously free all blocks and directories of specific worker, " +
"or free the space occupied by a file or a directory in Alluxio",
Use: Free.CommandName,
Short: "Synchronously free cached files along a path or held by a specific worker",
Example: `# Free a file by its path
$ ./bin/alluxio cache free --path /path/to/file
# Free files on a worker
$ ./bin/alluxio cache free --worker <workerHostName>`,
Args: cobra.NoArgs,
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
})
cmd.Flags().StringVar(&c.worker, "worker", "", "The worker to free")
cmd.Flags().StringVar(&c.path, "path", "", "The file or directory to free")
cmd.Flags().BoolVarP(&c.force, "force", "f", false,
"Force freeing pinned files in the directory")
cmd.MarkFlagsMutuallyExclusive("worker", "path")
return cmd
}
Expand All @@ -60,11 +61,7 @@ func (c *FreeCommand) Run(args []string) error {
if c.worker == "" {
if c.path != "" {
// free directory
javaArgs = append(javaArgs, "free")
if c.force {
javaArgs = append(javaArgs, "-f")
}
javaArgs = append(javaArgs, c.path)
javaArgs = append(javaArgs, "free", c.path)
} else {
return stacktrace.NewError("neither worker nor path to free specified")
}
Expand Down
24 changes: 23 additions & 1 deletion cli/src/alluxio.org/cli/cmd/conf/get.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,29 @@ func (c *GetCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: fmt.Sprintf("%v [key]", Get.CommandName),
Short: "Look up a configuration value by its property key or print all configuration if no key is provided",
Args: cobra.MaximumNArgs(1),
Long: `The get command prints the configured value for the given key.
If the key is invalid, it returns a nonzero exit code.
If the key is valid but isn't set, an empty string is printed.
If no key is specified, the full configuration is printed.
> Note: This command does not require the Alluxio cluster to be running.`,
Example: `# Display all the current node configuration
$ ./bin/alluxio conf get
# Display the value of a property key
$ ./bin/alluxio conf get alluxio.master.hostname
# Display the configuration of the current running Alluxio leading master
$ ./bin/alluxio conf get --master
# Display the source of the configuration
$ ./bin/alluxio conf get --source
# Display the values in a given unit
$ ./bin/alluxio conf get alluxio.user.block.size.bytes.default --unit KB
$ ./bin/alluxio conf get alluxio.master.journal.flush.timeout --unit S
`,
Args: cobra.MaximumNArgs(1),
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
Expand Down
18 changes: 17 additions & 1 deletion cli/src/alluxio.org/cli/cmd/conf/log.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,23 @@ func (c *LogCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: Log.CommandName,
Short: "Get or set the log level for the specified logger",
Args: cobra.NoArgs,
Long: `The log command returns the current value of or updates the log level of a particular class on specific instances.
Users are able to change Alluxio server-side log levels at runtime.
The --target flag specifies which processes to apply the log level change to.
The target could be of the form <master|workers|job_master|job_workers|host:webPort[:role]> and multiple targets can be listed as comma-separated entries.
The role can be one of master,worker,job_master,job_worker.
Using the role option is useful when an Alluxio process is configured to use a non-standard web port (e.g. if an Alluxio master does not use 19999 as its web port).
The default target value is the primary master, primary job master, all workers and job workers.
> Note: This command requires the Alluxio cluster to be running.`,
Example: `# Set DEBUG level for DefaultFileSystemMaster class on master processes
$ ./bin/alluxio conf log --logName alluxio.master.file.DefaultFileSystemMaster --target=master --level=DEBUG
# Set WARN level for PagedDoraWorker class on the worker process on host myHostName
$ ./bin/alluxio conf log --logName alluxio.worker.dora.PagedDoraWorker.java --target=myHostName:worker --level=WARN
`,
Args: cobra.NoArgs,
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
Expand Down
9 changes: 7 additions & 2 deletions cli/src/alluxio.org/cli/cmd/exec/test_basic_io.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,12 @@ func (c *TestRunCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: "basicIOTest",
Args: cobra.NoArgs,
Short: "Run all end-to-end tests, or a specific test, on an Alluxio cluster.",
Short: "Run all end-to-end tests or a specific test, on an Alluxio cluster.",
Example: `# Run all permutations of IO tests
$ ./bin/alluxio exec basicIOTest
# Run a specific permutation of the IO tests
$ ./bin/alluxio exec basicIOtest --operation BASIC --readType NO_CACHE --writeType THROUGH`,
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
Expand All @@ -61,7 +66,7 @@ func (c *TestRunCommand) ToCommand() *cobra.Command {
"Alluxio worker addresses to run tests on. \n"+
"If not specified, random ones will be used.")
cmd.Flags().StringVar(&c.writeType, "writeType", "",
"The write type to use, one of MUST_CACHE, CACHE_THROUGH, THROUGH, ASYNC_THROUGH. \n"+
"The write type to use, one of MUST_CACHE, CACHE_THROUGH, THROUGH. \n"+
"By default all writeTypes are tested.")
return cmd
}
Expand Down
20 changes: 16 additions & 4 deletions cli/src/alluxio.org/cli/cmd/exec/test_ufs_io.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,10 +46,22 @@ func (c *TestUfsIOCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: c.CommandName,
Short: "A benchmarking tool for the I/O between Alluxio and UFS.",
Long: "A benchmarking tool for the I/O between Alluxio and UFS." +
"This test will measure the I/O throughput between Alluxio workers and the specified UFS path. " +
"Each worker will create concurrent clients to first generate test files of the specified size " +
"then read those files. The write/read I/O throughput will be measured in the process.",
Long: `A benchmarking tool for the I/O between Alluxio and UFS.
This test will measure the I/O throughput between Alluxio workers and the specified UFS path.
Each worker will create concurrent clients to first generate test files of the specified size then read those files.
The write/read I/O throughput will be measured in the process.`,
Example: `# This runs the I/O benchmark to HDFS in your process locally
$ ./bin/alluxio runUfsIOTest --path hdfs://<hdfs-address>
# This invokes the I/O benchmark to HDFS in the Alluxio cluster
# 1 worker will be used. 4 threads will be created, each writing then reading 4G of data
$ ./bin/alluxio runUfsIOTest --path hdfs://<hdfs-address> --cluster --cluster-limit 1
# This invokes the I/O benchmark to HDFS in the Alluxio cluster
# 2 workers will be used
# 2 threads will be created on each worker
# Each thread is writing then reading 512m of data
$ ./bin/alluxio runUfsIOTest --path hdfs://<hdfs-address> --cluster --cluster-limit 2 --io-size 512m --threads 2`,
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
Expand Down
5 changes: 4 additions & 1 deletion cli/src/alluxio.org/cli/cmd/fs/cat.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,10 @@ func (c *CatCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: "cat [path]",
Short: "Print specified file's content",
Args: cobra.ExactArgs(1),
Long: `The cat command prints the contents of a file in Alluxio to the shell.`,
Example: `# Print the contents of /output/part-00000
$ ./bin/alluxio fs cat /output/part-00000`,
Args: cobra.ExactArgs(1),
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
Expand Down
11 changes: 10 additions & 1 deletion cli/src/alluxio.org/cli/cmd/fs/checksum.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,16 @@ func (c *ChecksumCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: "checksum [path]",
Short: "Calculates the md5 checksum of a specified file",
Args: cobra.ExactArgs(1),
Long: `The checksum command outputs the md5 value of a file in Alluxio.
This can be used to verify the contents of a file stored in Alluxio.`,
Example: `# Compare the checksum values
# value from Alluxio filesystem
$ ./bin/alluxio fs checksum /LICENSE
md5sum: bf0513403ff54711966f39b058e059a3
# value from local filesystem
md5 LICENSE
MD5 (LICENSE) = bf0513403ff54711966f39b058e059a3`,
Args: cobra.ExactArgs(1),
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
Expand Down
13 changes: 9 additions & 4 deletions cli/src/alluxio.org/cli/cmd/fs/chgrp.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,15 +39,20 @@ func (c *ChgrpCommand) Base() *env.BaseJavaCommand {

func (c *ChgrpCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: fmt.Sprintf("%s <group> <path>", c.CommandName),
Short: "changes the group of a file or directory specified by args",
Args: cobra.ExactArgs(2),
Use: fmt.Sprintf("%s [group] [path]", c.CommandName),
Short: "Changes the group of a file or directory",
Long: `The chgrp command changes the group of the file or directory in Alluxio.
Alluxio supports file authorization with POSIX file permissions.
The file owner or superuser can execute this command.`,
Example: `# Change the group of a file
$ ./bin/alluxio fs chgrp alluxio-group-new /input/file1`,
Args: cobra.ExactArgs(2),
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
})
cmd.Flags().BoolVarP(&c.recursive, "recursive", "R", false,
"change the group recursively")
"change the group recursively for all files and directories under the given path")
return cmd
}

Expand Down
13 changes: 9 additions & 4 deletions cli/src/alluxio.org/cli/cmd/fs/chmod.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,15 +39,20 @@ func (c *ChmodCommand) Base() *env.BaseJavaCommand {

func (c *ChmodCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: fmt.Sprintf("%s <mode> <path>", c.CommandName),
Short: "Changes the permission of a file or directory specified by args",
Args: cobra.ExactArgs(2),
Use: fmt.Sprintf("%s [mode] [path]", c.CommandName),
Short: "Changes the permission of a file or directory",
Long: `The chmod command changes the permission of a file or directory in Alluxio.
The permission mode is represented as an octal 3 digit value.
Refer to https://en.wikipedia.org/wiki/Chmod#Numerical_permissions for a detailed description of the modes.`,
Example: `# Set mode 755 for /input/file
$ ./bin/alluxio fs chmod 755 /input/file1`,
Args: cobra.ExactArgs(2),
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
})
cmd.Flags().BoolVarP(&c.recursive, "recursive", "R", false,
"change the permission recursively")
"change the permission recursively for all files and directories under the given path")
return cmd
}

Expand Down
8 changes: 6 additions & 2 deletions cli/src/alluxio.org/cli/cmd/fs/chown.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,13 +41,17 @@ func (c *ChownCommand) ToCommand() *cobra.Command {
cmd := c.Base().InitRunJavaClassCmd(&cobra.Command{
Use: fmt.Sprintf("%s <owner>[:<group>] <path>", c.CommandName),
Short: "Changes the owner of a file or directory specified by args",
Args: cobra.NoArgs,
Long: `The chown command changes the owner of a file or directory in Alluxio.
The ownership of a file can only be altered by a superuser`,
Example: `# Change the owner of /input/file1 to alluxio-user
$ ./bin/alluxio fs chown alluxio-user /input/file1`,
Args: cobra.NoArgs,
RunE: func(cmd *cobra.Command, args []string) error {
return c.Run(args)
},
})
cmd.Flags().BoolVarP(&c.recursive, "recursive", "R", false,
"change the owner recursively")
"change the owner recursively for all files and directories under the given path")
return cmd
}

Expand Down
74 changes: 0 additions & 74 deletions cli/src/alluxio.org/cli/cmd/fs/consistant_hash.go

This file was deleted.

Loading

0 comments on commit dd863fe

Please sign in to comment.