On Tue, 28 Jun 2016, Xiaoxi Chen wrote: > Hi, > > In jewel , when handling "inject-args" command, monitor will report > "unchangeable" for those non-tracking args, nevertheless, the config > is still updated. as "ceph daemon config show " will give out the new > value. > > It looks to me like if the configuration is not dynamically > changeable, we may better NOT to update the config? as the config set > by injectargs is not persist to disk , so before reboot the daemon, > config will not take effect, after reboot the daemon, config will > lost...it doesnt work(i.e make the config change) anyway. > > We notice this because we had an accident on our network switch so > lots of the OSD down and out, and we would intent to speed up the > recovery, then we inject "osd_recovery_max_active= 10" and got > "unchangeable", but in admin socket we can see this configuration so > we assume it is working but actually not. My point is the non-tracking > args showing in admin socket config dump is really misleading, other > guys will never know whether the args in config dump is make effect if > they don't know how this is set, via admin socket or via configuration > files. > > Kefu and I had some discussion on the original PR and would like to > here more opinions, See pr for more background: > https://github.com/ceph/ceph/pull/7085. We desperately need to overhaul the way that config options are described and updated. Right now we are cheating by letting any integer option be changed, regardless of whether an observer is defined, and no string options to be changed without an observer. (This is the minimum necessary to make config updates thread safe.) I think we need to extend the config_opts.h definitions of config options to include things like accepted values (for enums), and annotations indicating whether online updates are possible. This *could* be implied by the presence of observers, but in practice most of the options are used directly out of g_conf and don't have observers defined...that would be a bigger changes. Just setting a flag in the config options would be a start. We've discussed this a few times in the past and there is probably an etherpad sitting around somewhere from an old CDS... As to your specific question(s), 1- injectargs is never going to persis anything. but we're looking at the ability to define config options for the cluster via the mon, that that would be persisted. 2- making message you see accurate would be good. 3- we may want to revise the observer framework a bit so that a set option can be rejected. Right now the internal interface doesn't allow this. sage -- To unsubscribe from this list: send the line "unsubscribe ceph-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html