1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
|
:orphan:
===================================================
cephfs-shell -- Shell-like tool talking with CephFS
===================================================
.. program:: cephfs-shell
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
=======
.. option:: -b, --batch FILE
Path to batch file.
.. option:: -c, --config FILE
Path to cephfs-shell.conf
.. option:: -f, --fs FS
Name of filesystem to mount.
.. option:: -t, --test FILE
Path to transcript(s) in FILE for testing
.. note::
Latest version of the cmd2 module is required for running cephfs-shell.
If CephFS is installed through source, execute cephfs-shell in the build
directory. It can also be executed as following using virtualenv:
.. code:: bash
[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::
Apart from Ceph File System, CephFS Shell commands can also interact
directly with the local file system. To achieve this, ``!`` (an
exclamation point) must precede the CephFS Shell command.
Usage :
!<cephfs_shell_command>
For example,
.. code:: bash
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 :
mkdir [-option] <directory>...
* directory - name of the directory to be created.
Options :
-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 :
put [options] <source_path> <target_path>
* source_path - local file/directory path to be copied to cephfs.
* if `.` copies all the file/directories in the local working directory.
* if `-` Reads the input from stdin.
* target_path - remote directory path where the files/directories are to be copied to.
* if `.` files/directories are copied to the remote working directory.
Options :
-f, --force Overwrites the destination if it already exists.
get
---
Copy a file from Ceph File System to Local File System.
Usage :
get [options] <source_path> <target_path>
* source_path - remote file/directory path which is to be copied to local file system.
* if `.` copies all the file/directories in the remote working directory.
* target_path - local directory path where the files/directories are to be copied to.
* if `.` files/directories are copied to the local working directory.
* if `-` Writes output to stdout.
Options:
-f, --force Overwrites the destination if it already exists.
ls
--
List all the files and directories in the current working directory.
Usage :
ls [option] [directory]...
* directory - name of directory whose files/directories are to be listed.
* By default current working directory's files/directories are listed.
Options:
-l, --long list with long format - show permissions
-r, --reverse reverse sort
-H human readable
-a, -all ignore entries starting with .
-S Sort by file_size
cat
---
Concatenate files and print on the standard output
Usage :
cat <file>....
* 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:
ln [options] <target> [link_name]
* target - file/directory to which a link is to be created
* link_name - link to target with the name link_name
Options:
-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 :
cd [directory]
* directory - path/directory name. If no directory is mentioned it is changed to the root directory.
* If '.' moves to the parent directory of the current directory.
cwd
---
Get current working directory.
Usage :
cwd
quit/Ctrl + D
-------------
Close the shell.
chmod
-----
Change the permissions of file/directory.
Usage :
chmod <mode> <file/directory>
mv
--
Moves files/Directory from source to destination.
Usage :
mv <source_path> <destination_path>
rmdir
-----
Delete a directory(ies).
Usage :
rmdir <directory_name>.....
rm
--
Remove a file(es).
Usage :
rm <file_name/pattern>...
write
-----
Create and Write a file.
Usage :
write <file_name>
<Enter Data>
Ctrl+D Exit.
lls
---
Lists all files and directories in the specified directory.Current local directory files and directories are listed if no path is mentioned
Usage:
lls <path>.....
lcd
---
Moves into the given local directory.
Usage :
lcd <path>
lpwd
----
Prints the absolute path of the current local directory.
Usage :
lpwd
umask
-----
Set and get the file mode creation mask
Usage :
umask [mode]
alias
-----
Define or display aliases
Usage:
alias [name] | [<name> <value>]
* 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:
run_pyscript <script_path> [script_arguments]
* 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:: This command is available as ``pyscript`` for cmd2 versions 0.9.13
or less.
py
--
Invoke python command, shell, or script
Usage :
py <command>: Executes a Python command.
py: Enters interactive Python mode.
shortcuts
---------
Lists shortcuts (aliases) available
Usage :
shortcuts
history
-------
View, run, edit, and save previously entered commands.
Usage :
history [-h] [-r | -e | -s | -o FILE | -t TRANSCRIPT] [arg]
Options:
-h show this help message and exit
-r run selected history items
-e edit and then run selected history items
-s script format; no separation lines
-o FILE output commands to a script file
-t TRANSCRIPT output commands and results to a transcript file
unalias
-------
Unsets aliases
Usage :
unalias [-a] name [name ...]
* name - name of the alias being unset
Options:
-a remove all alias definitions
set
---
Sets a settable parameter or shows current settings of parameters.
Usage :
set [-h] [-a] [-l] [settable [settable ...]]
* Call without arguments for a list of settable parameters with their values.
Options :
-h show this help message and exit
-a display read-only settings as well
-l describe function of parameter
edit
----
Edit a file in a text editor.
Usage:
edit [file_path]
* 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:
run_script <file_path>
* file_path - a file path pointing to a script
.. note:: This command is available as ``load`` for cmd2 versions 0.9.13
or less.
shell
-----
Execute a command as if at the OS prompt.
Usage:
shell <command> [arguments]
locate
------
Find an item in File System
Usage:
locate [options] <name>
Options :
-c Count number of items found
-i Ignore case
stat
------
Display file status.
Usage :
stat [-h] <file_name> [file_name ...]
Options :
-h Shows the help message
snap
----
Create or Delete Snapshot
Usage:
snap {create|delete} <snap_name> <dir_name>
* 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 :
setxattr [-h] <path> <name> <value>
* path - Path to the file
* name - Extended attribute name to get or set
* value - Extended attribute value to be set
Options:
-h, --help Shows the help message
getxattr
--------
Get extended attribute value for the name associated with the path
Usage :
getxattr [-h] <path> <name>
* path - Path to the file
* name - Extended attribute name to get or set
Options:
-h, --help Shows the help message
listxattr
---------
List extended attribute names associated with the path
Usage :
listxattr [-h] <path>
* path - Path to the file
Options:
-h, --help Shows the help message
df
--
Display amount of available disk space
Usage :
df [-h] [file [file ...]]
* file - name of the file
Options:
-h, --help Shows the help message
du
--
Show disk usage of a directory
Usage :
du [-h] [-r] [paths [paths ...]]
* paths - name of the directory
Options:
-h, --help Shows the help message
-r Recursive Disk usage of all directories
quota
-----
Quota management for a Directory
Usage :
quota [-h] [--max_bytes [MAX_BYTES]] [--max_files [MAX_FILES]] {get,set} path
* {get,set} - quota operation type.
* path - name of the directory.
Options :
-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``
.. code-block:: ini
[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``
|