@@ -1973,6 +1973,7 @@ static ssize_t __ceph_copy_file_range(struct file *src_file, loff_t src_off,
int src_got = 0, dst_got = 0, err, dirty;
bool do_final_copy = false;
LIST_HEAD(osd_reqs);
+ unsigned int ncopies = cfr_throttle;
if (src_inode->i_sb != dst_inode->i_sb) {
struct ceph_fs_client *dst_fsc = ceph_inode_to_client(dst_inode);
@@ -2151,6 +2152,15 @@ static ssize_t __ceph_copy_file_range(struct file *src_file, loff_t src_off,
src_off += object_size;
dst_off += object_size;
ret += object_size;
+ if (cfr_throttle && (--ncopies == 0)) {
+ err = wait_copy_from_reqs(&osd_reqs);
+ if (err) {
+ if (!ret)
+ ret = err;
+ goto out_caps;
+ }
+ ncopies = cfr_throttle;
+ }
}
err = wait_copy_from_reqs(&osd_reqs);
@@ -1238,6 +1238,10 @@ static void __exit exit_ceph(void)
destroy_caches();
}
+unsigned int cfr_throttle = 0;
+module_param(cfr_throttle, uint, 0644);
+MODULE_PARM_DESC(cfr_throttle, "copy_file_range throttle value.");
+
module_init(init_ceph);
module_exit(exit_ceph);
@@ -72,6 +72,8 @@
#define CEPH_CAPS_WANTED_DELAY_MIN_DEFAULT 5 /* cap release delay */
#define CEPH_CAPS_WANTED_DELAY_MAX_DEFAULT 60 /* cap release delay */
+extern unsigned int cfr_throttle;
+
struct ceph_mount_options {
unsigned int flags;
This patch adds a ceph kernel module parameter that allows to throttle the amount of parallel requests that can be sent to the OSDs before waiting for the completion. This allows to prevent DoS'ing the ODSs with too many requests at once when copying a big file. Signed-off-by: Luis Henriques <lhenriques@suse.com> --- fs/ceph/file.c | 10 ++++++++++ fs/ceph/super.c | 4 ++++ fs/ceph/super.h | 2 ++ 3 files changed, 16 insertions(+)