]> git.proxmox.com Git - ceph.git/blobdiff - ceph/src/mds/Server.h
update sources to ceph Nautilus 14.2.1
[ceph.git] / ceph / src / mds / Server.h
index 2be8f10c4e38cae73fce2e28df418ed3769eaa6c..e46cf2cad4eb3b5eb5a13dd3d69d83212224aea1 100644 (file)
 #ifndef CEPH_MDS_SERVER_H
 #define CEPH_MDS_SERVER_H
 
-#include <boost/utility/string_view.hpp>
+#include <string_view>
 
 #include <common/DecayCounter.h>
 
+#include "messages/MClientReconnect.h"
+#include "messages/MClientReply.h"
+#include "messages/MClientRequest.h"
+#include "messages/MClientSession.h"
+#include "messages/MClientSnap.h"
+#include "messages/MClientReclaim.h"
+#include "messages/MClientReclaimReply.h"
+#include "messages/MLock.h"
+
 #include "MDSRank.h"
 #include "Mutation.h"
+#include "MDSContext.h"
 
 class OSDMap;
 class PerfCounters;
 class LogEvent;
 class EMetaBlob;
 class EUpdate;
-class MMDSSlaveRequest;
-struct SnapInfo;
-class MClientRequest;
-class MClientReply;
 class MDLog;
+struct SnapInfo;
 
 enum {
   l_mdss_first = 1000,
@@ -87,14 +94,17 @@ private:
   bool is_full;
 
   // State for while in reconnect
-  MDSInternalContext *reconnect_done;
+  MDSContext *reconnect_done;
   int failed_reconnects;
   bool reconnect_evicting;  // true if I am waiting for evictions to complete
                             // before proceeding to reconnect_gather_finish
-  time reconnect_start = time::min();
-  time reconnect_last_seen = time::min();
+  time reconnect_start = clock::zero();
+  time reconnect_last_seen = clock::zero();
   set<client_t> client_reconnect_gather;  // clients i need a reconnect msg from.
 
+  feature_bitset_t supported_features;
+  feature_bitset_t required_client_features;
+
   double cap_revoke_eviction_timeout = 0;
 
   friend class MDSContinuation;
@@ -114,7 +124,7 @@ public:
   void create_logger();
 
   // message handler
-  void dispatch(Message *m);
+  void dispatch(const Message::const_ref &m);
 
   void handle_osd_map();
 
@@ -122,13 +132,15 @@ public:
   bool waiting_for_reconnect(client_t c) const;
   void dump_reconnect_status(Formatter *f) const;
 
-  void handle_client_session(class MClientSession *m);
   time last_recalled() const {
     return last_recall_state;
   }
+
+  void handle_client_session(const MClientSession::const_ref &m);
   void _session_logged(Session *session, uint64_t state_seq, 
                       bool open, version_t pv, interval_set<inodeno_t>& inos,version_t piv);
   version_t prepare_force_open_sessions(map<client_t,entity_inst_t> &cm,
+                                       map<client_t,client_metadata_t>& cmm,
                                        map<client_t,pair<Session*,uint64_t> >& smap);
   void finish_force_open_sessions(const map<client_t,pair<Session*,uint64_t> >& smap,
                                  bool dec_import=true);
@@ -139,8 +151,19 @@ public:
   void kill_session(Session *session, Context *on_safe);
   size_t apply_blacklist(const std::set<entity_addr_t> &blacklist);
   void journal_close_session(Session *session, int state, Context *on_safe);
-  void reconnect_clients(MDSInternalContext *reconnect_done_);
-  void handle_client_reconnect(class MClientReconnect *m);
+
+  set<client_t> client_reclaim_gather;
+  size_t get_num_pending_reclaim() const { return client_reclaim_gather.size(); }
+  Session *find_session_by_uuid(std::string_view uuid);
+  void reclaim_session(Session *session, const MClientReclaim::const_ref &m);
+  void finish_reclaim_session(Session *session, const MClientReclaimReply::ref &reply=nullptr);
+  void handle_client_reclaim(const MClientReclaim::const_ref &m);
+
+  void reconnect_clients(MDSContext *reconnect_done_);
+  void handle_client_reconnect(const MClientReconnect::const_ref &m);
+  void infer_supported_features(Session *session, client_metadata_t& client_metadata);
+  void update_required_client_features();
+
   //void process_reconnect_cap(CInode *in, int from, ceph_mds_cap_reconnect& capinfo);
   void reconnect_gather_finish();
   void reconnect_tick();
@@ -155,54 +178,49 @@ public:
   void force_clients_readonly();
 
   // -- requests --
-  void handle_client_request(MClientRequest *m);
+  void handle_client_request(const MClientRequest::const_ref &m);
 
   void journal_and_reply(MDRequestRef& mdr, CInode *tracei, CDentry *tracedn,
                         LogEvent *le, MDSLogContextBase *fin);
   void submit_mdlog_entry(LogEvent *le, MDSLogContextBase *fin,
-                          MDRequestRef& mdr, const char *evt);
+                          MDRequestRef& mdr, std::string_view event);
   void dispatch_client_request(MDRequestRef& mdr);
-  void perf_gather_op_latency(const MClientRequestreq, utime_t lat);
+  void perf_gather_op_latency(const MClientRequest::const_ref &req, utime_t lat);
   void early_reply(MDRequestRef& mdr, CInode *tracei, CDentry *tracedn);
   void respond_to_request(MDRequestRef& mdr, int r = 0);
-  void set_trace_dist(Session *session, MClientReply *reply, CInode *in, CDentry *dn,
+  void set_trace_dist(Session *session, const MClientReply::ref &reply, CInode *in, CDentry *dn,
                      snapid_t snapid,
                      int num_dentries_wanted,
                      MDRequestRef& mdr);
 
-  void encode_empty_dirstat(bufferlist& bl);
-  void encode_infinite_lease(bufferlist& bl);
-  void encode_null_lease(bufferlist& bl);
 
-  void handle_slave_request(MMDSSlaveRequest *m);
-  void handle_slave_request_reply(MMDSSlaveRequest *m);
+  void handle_slave_request(const MMDSSlaveRequest::const_ref &m);
+  void handle_slave_request_reply(const MMDSSlaveRequest::const_ref &m);
   void dispatch_slave_request(MDRequestRef& mdr);
   void handle_slave_auth_pin(MDRequestRef& mdr);
-  void handle_slave_auth_pin_ack(MDRequestRef& mdr, MMDSSlaveRequest *ack);
+  void handle_slave_auth_pin_ack(MDRequestRef& mdr, const MMDSSlaveRequest::const_ref &ack);
 
   // some helpers
   bool check_fragment_space(MDRequestRef& mdr, CDir *in);
   bool check_access(MDRequestRef& mdr, CInode *in, unsigned mask);
   bool _check_access(Session *session, CInode *in, unsigned mask, int caller_uid, int caller_gid, int setattr_uid, int setattr_gid);
-  CDir *validate_dentry_dir(MDRequestRef& mdr, CInode *diri, boost::string_view dname);
+  CDir *validate_dentry_dir(MDRequestRef& mdr, CInode *diri, std::string_view dname);
   CDir *traverse_to_auth_dir(MDRequestRef& mdr, vector<CDentry*> &trace, filepath refpath);
-  CDentry *prepare_null_dentry(MDRequestRef& mdr, CDir *dir, boost::string_view dname, bool okexist=false);
+  CDentry *prepare_null_dentry(MDRequestRef& mdr, CDir *dir, std::string_view dname, bool okexist=false);
   CDentry *prepare_stray_dentry(MDRequestRef& mdr, CInode *in);
   CInode* prepare_new_inode(MDRequestRef& mdr, CDir *dir, inodeno_t useino, unsigned mode,
                            file_layout_t *layout=NULL);
   void journal_allocated_inos(MDRequestRef& mdr, EMetaBlob *blob);
   void apply_allocated_inos(MDRequestRef& mdr, Session *session);
 
-  CInode* rdlock_path_pin_ref(MDRequestRef& mdr, int n, set<SimpleLock*>& rdlocks, bool want_auth,
-                             bool no_want_auth=false,
-                             file_layout_t **layout=NULL,
+  CInode* rdlock_path_pin_ref(MDRequestRef& mdr, int n, MutationImpl::LockOpVec& lov,
+                             bool want_auth, bool no_want_auth=false,
+                             file_layout_t **layout=nullptr,
                              bool no_lookup=false);
   CDentry* rdlock_path_xlock_dentry(MDRequestRef& mdr, int n,
-                                    set<SimpleLock*>& rdlocks,
-                                    set<SimpleLock*>& wrlocks,
-                                   set<SimpleLock*>& xlocks, bool okexist,
-                                   bool mustexist, bool alwaysxlock,
-                                   file_layout_t **layout=NULL);
+                                   MutationImpl::LockOpVec& lov,
+                                   bool okexist, bool mustexist, bool alwaysxlock,
+                                   file_layout_t **layout=nullptr);
 
   CDir* try_open_auth_dirfrag(CInode *diri, frag_t fg, MDRequestRef& mdr);
 
@@ -211,6 +229,7 @@ public:
   void handle_client_getattr(MDRequestRef& mdr, bool is_lookup);
   void handle_client_lookup_ino(MDRequestRef& mdr,
                                bool want_parent, bool want_dentry);
+  void _lookup_snap_ino(MDRequestRef& mdr);
   void _lookup_ino_2(MDRequestRef& mdr, int r);
   void handle_client_readdir(MDRequestRef& mdr);
   void handle_client_file_setlock(MDRequestRef& mdr);
@@ -220,23 +239,20 @@ public:
   void handle_client_setlayout(MDRequestRef& mdr);
   void handle_client_setdirlayout(MDRequestRef& mdr);
 
+  int parse_quota_vxattr(string name, string value, quota_info_t *quota);
+  void create_quota_realm(CInode *in);
   int parse_layout_vxattr(string name, string value, const OSDMap& osdmap,
                          file_layout_t *layout, bool validate=true);
-  int parse_quota_vxattr(string name, string value, quota_info_t *quota);
   int check_layout_vxattr(MDRequestRef& mdr,
                           string name,
                           string value,
                           file_layout_t *layout);
   void handle_set_vxattr(MDRequestRef& mdr, CInode *cur,
                         file_layout_t *dir_layout,
-                        set<SimpleLock*> rdlocks,
-                        set<SimpleLock*> wrlocks,
-                        set<SimpleLock*> xlocks);
+                        MutationImpl::LockOpVec& lov);
   void handle_remove_vxattr(MDRequestRef& mdr, CInode *cur,
                            file_layout_t *dir_layout,
-                           set<SimpleLock*> rdlocks,
-                           set<SimpleLock*> wrlocks,
-                           set<SimpleLock*> xlocks);
+                           MutationImpl::LockOpVec& lov);
   void handle_client_setxattr(MDRequestRef& mdr);
   void handle_client_removexattr(MDRequestRef& mdr);
 
@@ -255,21 +271,21 @@ public:
   // link
   void handle_client_link(MDRequestRef& mdr);
   void _link_local(MDRequestRef& mdr, CDentry *dn, CInode *targeti);
-  void _link_local_finish(MDRequestRef& mdr,
-                         CDentry *dn, CInode *targeti,
-                         version_t, version_t);
+  void _link_local_finish(MDRequestRef& mdr, CDentry *dn, CInode *targeti,
+                         version_t, version_t, bool);
 
   void _link_remote(MDRequestRef& mdr, bool inc, CDentry *dn, CInode *targeti);
   void _link_remote_finish(MDRequestRef& mdr, bool inc, CDentry *dn, CInode *targeti,
                           version_t);
 
   void handle_slave_link_prep(MDRequestRef& mdr);
-  void _logged_slave_link(MDRequestRef& mdr, CInode *targeti);
+  void _logged_slave_link(MDRequestRef& mdr, CInode *targeti, bool adjust_realm);
   void _commit_slave_link(MDRequestRef& mdr, int r, CInode *targeti);
   void _committed_slave(MDRequestRef& mdr);  // use for rename, too
-  void handle_slave_link_prep_ack(MDRequestRef& mdr, MMDSSlaveRequest *m);
+  void handle_slave_link_prep_ack(MDRequestRef& mdr, const MMDSSlaveRequest::const_ref &m);
   void do_link_rollback(bufferlist &rbl, mds_rank_t master, MDRequestRef& mdr);
-  void _link_rollback_finish(MutationRef& mut, MDRequestRef& mdr);
+  void _link_rollback_finish(MutationRef& mut, MDRequestRef& mdr,
+                            map<client_t,MClientSnap::ref>& split);
 
   // unlink
   void handle_client_unlink(MDRequestRef& mdr);
@@ -283,7 +299,7 @@ public:
   void handle_slave_rmdir_prep(MDRequestRef& mdr);
   void _logged_slave_rmdir(MDRequestRef& mdr, CDentry *srcdn, CDentry *straydn);
   void _commit_slave_rmdir(MDRequestRef& mdr, int r, CDentry *straydn);
-  void handle_slave_rmdir_prep_ack(MDRequestRef& mdr, MMDSSlaveRequest *ack);
+  void handle_slave_rmdir_prep_ack(MDRequestRef& mdr, const MMDSSlaveRequest::const_ref &ack);
   void do_rmdir_rollback(bufferlist &rbl, mds_rank_t master, MDRequestRef& mdr);
   void _rmdir_rollback_finish(MDRequestRef& mdr, metareqid_t reqid, CDentry *dn, CDentry *straydn);
 
@@ -316,21 +332,22 @@ public:
 
   // slaving
   void handle_slave_rename_prep(MDRequestRef& mdr);
-  void handle_slave_rename_prep_ack(MDRequestRef& mdr, MMDSSlaveRequest *m);
-  void handle_slave_rename_notify_ack(MDRequestRef& mdr, MMDSSlaveRequest *m);
+  void handle_slave_rename_prep_ack(MDRequestRef& mdr, const MMDSSlaveRequest::const_ref &m);
+  void handle_slave_rename_notify_ack(MDRequestRef& mdr, const MMDSSlaveRequest::const_ref &m);
   void _slave_rename_sessions_flushed(MDRequestRef& mdr);
   void _logged_slave_rename(MDRequestRef& mdr, CDentry *srcdn, CDentry *destdn, CDentry *straydn);
   void _commit_slave_rename(MDRequestRef& mdr, int r, CDentry *srcdn, CDentry *destdn, CDentry *straydn);
   void do_rename_rollback(bufferlist &rbl, mds_rank_t master, MDRequestRef& mdr, bool finish_mdr=false);
   void _rename_rollback_finish(MutationRef& mut, MDRequestRef& mdr, CDentry *srcdn, version_t srcdnpv,
-                              CDentry *destdn, CDentry *staydn, bool finish_mdr);
+                              CDentry *destdn, CDentry *staydn, map<client_t,MClientSnap::ref> splits[2],
+                              bool finish_mdr);
 
   void evict_cap_revoke_non_responders();
-  void handle_conf_change(const struct md_config_t *,
+  void handle_conf_change(const ConfigProxy& conf,
                           const std::set <std::string> &changed);
 
 private:
-  void reply_client_request(MDRequestRef& mdr, MClientReply *reply);
+  void reply_client_request(MDRequestRef& mdr, const MClientReply::ref &reply);
   void flush_session(Session *session, MDSGatherBuilder *gather);
 
   DecayCounter recall_throttle;