mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2025-01-08 15:44:11 +00:00
s3fs: print unmounting hint when the mount point is stale (#2295)
When the error code returned by the stat information of the mount point is ENOTCONN, print unmount command hint for user to fix. Signed-off-by: Qinqi Qu <quqinqi@linux.alibaba.com>
This commit is contained in:
parent
e8cb6d6d34
commit
68c45ce791
36
src/s3fs.cpp
36
src/s3fs.cpp
@ -146,6 +146,8 @@ static bool set_mountpoint_attribute(struct stat& mpst);
|
|||||||
static int set_bucket(const char* arg);
|
static int set_bucket(const char* arg);
|
||||||
static int my_fuse_opt_proc(void* data, const char* arg, int key, struct fuse_args* outargs);
|
static int my_fuse_opt_proc(void* data, const char* arg, int key, struct fuse_args* outargs);
|
||||||
static fsblkcnt_t parse_bucket_size(char* value);
|
static fsblkcnt_t parse_bucket_size(char* value);
|
||||||
|
static bool is_cmd_exists(const std::string& command);
|
||||||
|
static int print_umount_message(const std::string& mp, bool force);
|
||||||
|
|
||||||
//-------------------------------------------------------------------
|
//-------------------------------------------------------------------
|
||||||
// fuse interface functions
|
// fuse interface functions
|
||||||
@ -4635,6 +4637,35 @@ static fsblkcnt_t parse_bucket_size(char* max_size)
|
|||||||
return n_bytes;
|
return n_bytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool is_cmd_exists(const std::string& command)
|
||||||
|
{
|
||||||
|
// The `command -v` is a POSIX-compliant method for checking the existence of a program.
|
||||||
|
std::string cmd = "command -v " + command + " >/dev/null 2>&1";
|
||||||
|
int result = system(cmd.c_str());
|
||||||
|
return (result !=-1 && WIFEXITED(result) && WEXITSTATUS(result) == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int print_umount_message(const std::string& mp, bool force)
|
||||||
|
{
|
||||||
|
std::string cmd;
|
||||||
|
if (is_cmd_exists("fusermount")){
|
||||||
|
if (force){
|
||||||
|
cmd = "fusermount -uz " + mp;
|
||||||
|
} else {
|
||||||
|
cmd = "fusermount -u " + mp;
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
if (force){
|
||||||
|
cmd = "umount -l " + mp;
|
||||||
|
} else {
|
||||||
|
cmd = "umount " + mp;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
S3FS_PRN_EXIT("MOUNTPOINT %s is stale, you could use this command to fix: %s", mp.c_str(), cmd.c_str());
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
// This is repeatedly called by the fuse option parser
|
// This is repeatedly called by the fuse option parser
|
||||||
// if the key is equal to FUSE_OPT_KEY_OPT, it's an option passed in prefixed by
|
// if the key is equal to FUSE_OPT_KEY_OPT, it's an option passed in prefixed by
|
||||||
@ -4670,7 +4701,12 @@ static int my_fuse_opt_proc(void* data, const char* arg, int key, struct fuse_ar
|
|||||||
set_mountpoint_attribute(stbuf);
|
set_mountpoint_attribute(stbuf);
|
||||||
#else
|
#else
|
||||||
if(stat(arg, &stbuf) == -1){
|
if(stat(arg, &stbuf) == -1){
|
||||||
|
// check stale mountpoint
|
||||||
|
if(errno == ENOTCONN){
|
||||||
|
print_umount_message(mountpoint, true);
|
||||||
|
} else {
|
||||||
S3FS_PRN_EXIT("unable to access MOUNTPOINT %s: %s", mountpoint.c_str(), strerror(errno));
|
S3FS_PRN_EXIT("unable to access MOUNTPOINT %s: %s", mountpoint.c_str(), strerror(errno));
|
||||||
|
}
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if(!(S_ISDIR(stbuf.st_mode))){
|
if(!(S_ISDIR(stbuf.st_mode))){
|
||||||
|
Loading…
Reference in New Issue
Block a user