[sheepdog] [PATCH] sheep: disable journal by default
Liu Yuan
namei.unix at gmail.com
Fri Sep 7 11:26:28 CEST 2012
sent from my galaxy 2
在 2012-9-7 PM5:17,"MORITA Kazutaka" <morita.kazutaka at lab.ntt.co.jp>写道:
>
> It seems that most modern disk drives implement atomic sector writes
> (e.g. section 7.4 in http://www.sqlite.org/atomiccommit.html). If it
> is true, we don't need to use journal for vdi object updates because
> we don't update them across a sector boundary.
>
> This patch uses atomic_put() for vdi creation, and doesn't use journal
> for vdi updates by default.
for partial update, we can use check command to repair consistency. So can
we completely remove journal?
>
> Signed-off-by: MORITA Kazutaka <morita.kazutaka at lab.ntt.co.jp>
> ---
> sheep/ops.c | 5 ++++-
> sheep/sheep.c | 7 ++++++-
> sheep/sheep_priv.h | 2 ++
> 3 files changed, 12 insertions(+), 2 deletions(-)
>
> diff --git a/sheep/ops.c b/sheep/ops.c
> index 6aff0d5..4c0426f 100644
> --- a/sheep/ops.c
> +++ b/sheep/ops.c
> @@ -886,7 +886,10 @@ static int do_write_obj(struct siocb *iocb, struct
sd_req *hdr, uint32_t epoch,
> iocb->buf = data;
> iocb->length = hdr->data_length;
> iocb->offset = hdr->obj.offset;
> - if (is_vdi_obj(oid)) {
> +
> + if (is_vdi_obj(oid) && create)
> + ret = sd_store->atomic_put(oid, iocb);
> + else if (is_vdi_obj(oid) && sys->use_journal) {
> struct strbuf buf = STRBUF_INIT;
>
> strbuf_addf(&buf, "%s%016" PRIx64, obj_path, oid);
> diff --git a/sheep/sheep.c b/sheep/sheep.c
> index b09443f..cdf447d 100644
> --- a/sheep/sheep.c
> +++ b/sheep/sheep.c
> @@ -43,6 +43,7 @@ static struct option const long_options[] = {
> {"foreground", no_argument, NULL, 'f'},
> {"gateway", no_argument, NULL, 'g'},
> {"help", no_argument, NULL, 'h'},
> + {"journal", no_argument, NULL, 'j'},
> {"loglevel", required_argument, NULL, 'l'},
> {"myaddr", required_argument, NULL, 'y'},
> {"stdout", no_argument, NULL, 'o'},
> @@ -54,7 +55,7 @@ static struct option const long_options[] = {
> {NULL, 0, NULL, 0},
> };
>
> -static const char *short_options = "c:dDfghl:op:P:s:w:y:z:";
> +static const char *short_options = "c:dDfghjl:op:P:s:w:y:z:";
>
> static void usage(int status)
> {
> @@ -71,6 +72,7 @@ Options:\n\
> -f, --foreground make the program run in the foreground\n\
> -g, --gateway make the progam run as a gateway mode\n\
> -h, --help display this help and exit\n\
> + -j, --journal use jouranl to update vdi objects\n\
> -l, --loglevel specify the level of logging detail\n\
> -o, --stdout log to stdout instead of shared logger\n\
> -p, --port specify the TCP port on which to listen\n\
> @@ -409,6 +411,9 @@ int main(int argc, char **argv)
> case 'w':
> init_cache_type(optarg);
> break;
> + case 'j':
> + sys->use_journal = true;
> + break;
> case 'h':
> usage(0);
> break;
> diff --git a/sheep/sheep_priv.h b/sheep/sheep_priv.h
> index b31328a..5cd9d3f 100644
> --- a/sheep/sheep_priv.h
> +++ b/sheep/sheep_priv.h
> @@ -122,6 +122,8 @@ struct cluster_info {
>
> uint64_t object_cache_size;
> bool object_cache_directio;
> +
> + bool use_journal;
> };
>
> struct siocb {
> --
> 1.7.2.5
>
> --
> sheepdog mailing list
> sheepdog at lists.wpkg.org
> http://lists.wpkg.org/mailman/listinfo/sheepdog
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.wpkg.org/pipermail/sheepdog/attachments/20120907/d1953921/attachment-0002.html>
More information about the sheepdog
mailing list