table of contents
CEPHFS-SHELL(8) | Ceph | CEPHFS-SHELL(8) |
NAME¶
cephfs-shell - Shell-like tool talking with CephFS
SYNOPSIS¶
cephfs-shell [options] [command] cephfs-shell [options] -- [command, command,...]
DESCRIPTION¶
CephFS Shell provides shell-like commands that directly interact with the Ceph File System.
This tool can be used in interactive mode as well as in non-interactive mode. In former mode, cephfs-shell opens a shell session and after the given command is finished, it prints the prompt string and waits indefinitely. When the shell session is finished, cephfs-shell quits with the return value of last executed command. In non-interactive mode, cephfs-shell issues a command and exits right after the command's execution is complete with the command's return value.
Behaviour of CephFS Shell can be tweaked using cephfs-shell.conf. Refer to CephFS Shell Configuration File for details.
OPTIONS¶
- -b, --batch FILE
- Path to batch file.
- -c, --config FILE
- Path to cephfs-shell.conf
- -f, --fs FS
- Name of filesystem to mount.
- -t, --test FILE
- Path to transcript(s) in FILE for testing
NOTE:
[build]$ python3 -m venv venv && source venv/bin/activate && pip3 install cmd2 [build]$ source vstart_environment.sh && source venv/bin/activate && python3 ../src/tools/cephfs/shell/cephfs-shell
COMMANDS¶
NOTE:
Usage :
For example,
CephFS:~/>>> !ls # Lists the local file system directory contents. CephFS:~/>>> ls # Lists the Ceph File System directory contents.
mkdir¶
Create the directory(ies), if they do not already exist.
Usage :
- •
- directory - name of the directory to be created.
- -m MODE
- Sets the access mode for the new directory.
- -p, --parent
- Create parent directories as necessary. When this option is specified, no error is reported if a directory already exists.
put¶
Copy a file/directory to Ceph File System from Local File System.
Usage :
- •
- if . copies all the file/directories in the local working directory.
- if - Reads the input from stdin.
- •
- •
- if . files/directories are copied to the remote working directory.
get¶
Copy a file from Ceph File System to Local File System.
Usage :
- •
- •
- if . copies all the file/directories in the remote working directory.
- •
- if . files/directories are copied to the local working directory.
- if - Writes output to stdout.
ls¶
List all the files and directories in the current working directory.
Usage :
- •
- •
- By default current working directory's files/directories are listed.
cat¶
Concatenate files and print on the standard output
Usage :
- •
- file - name of the file
ln¶
Add a hard link to an existing file or create a symbolic link to an existing file or directory.
Usage:
- target - file/directory to which a link is to be created
- link_name - link to target with the name link_name
- -s, --symbolic
- Create symbolic link
- -v, --verbose
- Print name of each linked file
- -f, --force
- Force create link/symbolic link
cd¶
Change current working directory.
Usage :
- •
- •
- If '.' moves to the parent directory of the current directory.
cwd¶
Get current working directory.
Usage :
quit/Ctrl + D¶
Close the shell.
chmod¶
Change the permissions of file/directory.
Usage :
mv¶
Moves files/Directory from source to destination.
Usage :
rmdir¶
Delete a directory(ies).
Usage :
rm¶
Remove a file(es).
Usage :
write¶
Create and Write a file.
Usage :
lls¶
Lists all files and directories in the specified directory.Current local directory files and directories are listed if no path is mentioned
Usage:
lcd¶
Moves into the given local directory.
Usage :
lpwd¶
Prints the absolute path of the current local directory.
Usage :
umask¶
Set and get the file mode creation mask
Usage :
alias¶
Define or display aliases
Usage:
- name - name of the alias being looked up, added, or replaced
- value - what the alias will be resolved to (if adding or replacing) this can contain spaces and does not need to be quoted
run_pyscript¶
Runs a python script file inside the console
Usage:
- •
- Console commands can be executed inside this script with cmd ("your command") However, you cannot run nested "py" or "pyscript" commands from within this script. Paths or arguments that contain spaces must be enclosed in quotes
NOTE:
py¶
Invoke python command, shell, or script
Usage :
shortcuts¶
Lists shortcuts (aliases) available
Usage :
history¶
View, run, edit, and save previously entered commands.
Usage :
unalias¶
Unsets aliases
Usage :
- •
- name - name of the alias being unset
set¶
Sets a settable parameter or shows current settings of parameters.
Usage :
- •
- Call without arguments for a list of settable parameters with their values.
edit¶
Edit a file in a text editor.
Usage:
- •
- file_path - path to a file to open in editor
run_script¶
Runs commands in script file that is encoded as either ASCII or UTF-8 text. Each command in the script should be separated by a newline.
Usage:
- •
- file_path - a file path pointing to a script
NOTE:
shell¶
Execute a command as if at the OS prompt.
Usage:
locate¶
Find an item in File System
Usage:
stat¶
Display file status.
Usage :
snap¶
Create or Delete Snapshot
Usage:
- snap_name - Snapshot name to be created or deleted
- dir_name - directory under which snapshot should be created or deleted
setxattr¶
Set extended attribute for a file
Usage :
- path - Path to the file
- name - Extended attribute name to get or set
- value - Extended attribute value to be set
getxattr¶
Get extended attribute value for the name associated with the path
Usage :
- path - Path to the file
- name - Extended attribute name to get or set
listxattr¶
List extended attribute names associated with the path
Usage :
- •
- path - Path to the file
df¶
Display amount of available disk space
Usage :
- •
- file - name of the file
du¶
Show disk usage of a directory
Usage :
- •
- paths - name of the directory
quota¶
Quota management for a Directory
Usage :
- {get,set} - quota operation type.
- path - name of the directory.
- -h, --help
- Shows the help message
- --max_bytes MAX_BYTES
- Set max cumulative size of the data under this directory
- --max_files MAX_FILES
- Set total number of files under this directory tree
CEPHFS SHELL CONFIGURATION FILE¶
By default, CephFS Shell looks for cephfs-shell.conf in the path provided by the environment variable CEPHFS_SHELL_CONF and then in user's home directory (~/.cephfs-shell.conf).
Right now, CephFS Shell inherits all its options from its dependency cmd2. Therefore, these options might vary with the version of cmd2 installed on your system. Refer to cmd2 docs for a description of these options.
Following is a sample cephfs-shell.conf
[cephfs-shell] prompt = CephFS:~/>>> continuation_prompt = > quiet = False timing = False colors = True debug = False abbrev = False autorun_on_edit = False echo = False editor = vim feedback_to_output = False locals_in_py = True
EXIT CODE¶
Following exit codes are returned by cephfs shell
Error Type | Exit Code |
Miscellaneous | 1 |
Keyboard Interrupt | 2 |
Operation not permitted | 3 |
Permission denied | 4 |
No such file or directory | 5 |
I/O error | 6 |
No space left on device | 7 |
File exists | 8 |
No data available | 9 |
Invalid argument | 10 |
Operation not supported on transport endpoint | 11 |
Range error | 12 |
Operation would block | 13 |
Directory not empty | 14 |
Not a directory | 15 |
Disk quota exceeded | 16 |
Broken pipe | 17 |
Cannot send after transport endpoint shutdown | 18 |
Connection aborted | 19 |
Connection refused | 20 |
Connection reset | 21 |
Interrupted function call | 22 |
FILES¶
~/.cephfs-shell.conf
COPYRIGHT¶
2010-2023, Inktank Storage, Inc. and contributors. Licensed under Creative Commons Attribution Share Alike 3.0 (CC-BY-SA-3.0)
October 24, 2023 | dev |