diff options
| author | Raghavendra Bhat <raghavendra@redhat.com> | 2013-04-19 12:27:03 +0530 | 
|---|---|---|
| committer | Vijay Bellur <vbellur@redhat.com> | 2014-02-10 23:32:05 -0800 | 
| commit | 28209283a67f13802cc0c1d3df07c676926810a2 (patch) | |
| tree | 5cf62085fa1a4bbc6d76eb1763f343c6116ea195 /xlators/performance | |
| parent | 97ce783de326b51fcba65737f07db2c314d1e218 (diff) | |
protocol/server: do not do root-squashing for trusted clients
* As of now clients mounting within the storage pool using that machine's
  ip/hostname are trusted clients (i.e clients local to the glusterd).
* Be careful when the request itself comes in as nfsnobody (ex: posix tests).
  So move the squashing part to protocol/server when it creates a new frame
  for the request, instead of auth part of rpc layer.
* For nfs servers do root-squashing without checking if it is trusted client,
  as all the nfs servers would be running within the storage pool, hence will
  be trusted clients for the bricks.
* Provide one more option for mounting which actually says root-squash
  should/should not happen. This value is given priority only for the trusted
  clients. For non trusted clients, the volume option takes the priority. But
  for trusted clients if root-squash should not happen, then they have to be
  mounted with root-squash=no option. (This is done because by default
  blocking root-squashing for the trusted clients will cause problems for smb
  and UFO clients for which the requests have to be squashed if the option is
  enabled).
* For geo-replication and defrag clients do not do root-squashing.
* Introduce a new option in open-behind for doing read after successful open.
Change-Id: I8a8359840313dffc34824f3ea80a9c48375067f0
BUG: 954057
Signed-off-by: Raghavendra Bhat <raghavendra@redhat.com>
Reviewed-on: http://review.gluster.org/4863
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Vijay Bellur <vbellur@redhat.com>
Diffstat (limited to 'xlators/performance')
| -rw-r--r-- | xlators/performance/open-behind/src/open-behind.c | 23 | 
1 files changed, 21 insertions, 2 deletions
| diff --git a/xlators/performance/open-behind/src/open-behind.c b/xlators/performance/open-behind/src/open-behind.c index 29ef64364dc..742e4df3fdf 100644 --- a/xlators/performance/open-behind/src/open-behind.c +++ b/xlators/performance/open-behind/src/open-behind.c @@ -23,6 +23,11 @@ typedef struct ob_conf {  					   like mandatory locks  					*/  	gf_boolean_t  lazy_open; /* delay backend open as much as possible */ +        gf_boolean_t  read_after_open; /* instead of sending readvs on +                                               anonymous fds, open the file +                                               first and then send readv i.e +                                               similar to what writev does +                                            */  } ob_conf_t; @@ -367,8 +372,14 @@ ob_readv (call_frame_t *frame, xlator_t *this, fd_t *fd, size_t size,  {  	call_stub_t  *stub = NULL;  	fd_t         *wind_fd = NULL; +        ob_conf_t    *conf = NULL; -	wind_fd = ob_get_wind_fd (this, fd); +        conf = this->private; + +        if (!conf->read_after_open) +                wind_fd = ob_get_wind_fd (this, fd); +        else +                wind_fd = fd_ref (fd);  	stub = fop_readv_stub (frame, default_readv_resume, wind_fd,  			       size, offset, flags, xdata); @@ -894,6 +905,8 @@ reconfigure (xlator_t *this, dict_t *options)  			  bool, out);          GF_OPTION_RECONF ("lazy-open", conf->lazy_open, options, bool, out); +        GF_OPTION_RECONF ("read-after-open", conf->read_after_open, options, +                          bool, out);          ret = 0;  out: @@ -924,7 +937,7 @@ init (xlator_t *this)          GF_OPTION_INIT ("use-anonymous-fd", conf->use_anonymous_fd, bool, err);          GF_OPTION_INIT ("lazy-open", conf->lazy_open, bool, err); - +        GF_OPTION_INIT ("read-after-open", conf->read_after_open, bool, err);          this->private = conf;  	return 0; @@ -996,6 +1009,12 @@ struct volume_options options[] = {            "FOP arrives (e.g writev on the FD, unlink of the file). When option "            "is disabled, perform backend open right after unwinding open().",          }, +        { .key  = {"read-after-open"}, +          .type = GF_OPTION_TYPE_BOOL, +          .default_value = "no", +          .description = "read is sent only after actual open happens and real " +          "fd is obtained, instead of doing on anonymous fd (similar to write)", +        },          { .key  = {NULL} }  }; | 
