[prev in list] [next in list] [prev in thread] [next in thread] 

List:       unison-users
Subject:    Re: [unison-users] Synchronization of file while local copy is in progress
From:       "'Benjamin C. Pierce' bcpierce () cis ! upenn ! edu [unison-users]" <unison-users-norep
Date:       2014-10-22 19:27:17
Message-ID: 496913AD-3B8B-40B4-8617-9B2A3ED390E2 () cis ! upenn ! edu
[Download RAW message or body]

Looks like the function to fix is safeFingerprint, in module os.ml.  Possible fix is \
to add a short sleep before retrying (i.e., before the first call to retryLoop).

Simpler workaround is to reduce the number of retries (to 1 or 2, say, from 10).

    - Benjamin



On Oct 22, 2014, at 3:15 PM, rcollinson@att.net [unison-users] \
<unison-users-noreply@yahoogroups.com> wrote:

> 
> 
> Wondering if there is a way to hold Unison off from calculating its hash when a new \
> file is being copied into a synchronization folder? 
> 
> 
> If a file is open and is being changed from a copy operation, could Unison ignore \
> it until it is no longer open? 
> 
> 
> What I am seeing is CPU utilization spike with Unison during the copy of a file to \
> a folder that is designated for synchronization. 
> 
> 
> It appears that the synchronization (copy to other computer) is delayed until the \
> local copy is complete, but the hash calculation is constantly being performed, \
> hence high CPU utilization, before the local copy is complete. 
> 
> 
> Does Unison check if a file is open and being modified before calculating the hash \
> or determining if directories are different? 
> 
> 
> 


[Attachment #3 (text/html)]

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" \
"http://www.w3.org/TR/html4/strict.dtd"> <html>
<head>
</head>






 
<body style="background-color: #fff;">
<span style="display:none">&nbsp;</span>

<!--~-|**|PrettyHtmlStartT|**|-~-->
<div id="ygrp-mlmsg" style="position:relative;">
  <div id="ygrp-msg" style="z-index: 1;">
<!--~-|**|PrettyHtmlEndT|**|-~-->

    <div id="ygrp-text" >
      
      
      <p>Looks like the function to fix is safeFingerprint, in module os.ml. \
&nbsp;Possible fix is to add a short sleep before retrying (i.e., before the first \
call to retryLoop).<div><br></div><div>Simpler workaround is to reduce the number of \
retries (to 1 or 2, say, from 10).</div><div><br></div><div>&nbsp; &nbsp; - \
Benjamin</div><div><br><div><br><div><br><div><div>On Oct 22, 2014, at 3:15 PM, <a \
href="mailto:rcollinson@att.net">rcollinson@att.net</a> [unison-users] &lt;<a \
href="mailto:unison-users-noreply@yahoogroups.com">unison-users-noreply@yahoogroups.com</a>&gt; \
wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div \
style="font-family: Helvetica;font-size: 18px;font-style: normal;font-variant: \
normal;font-weight: normal;letter-spacing: normal;text-align: start;text-indent: \
0px;text-transform: none;white-space: normal;"><br><br><p style="padding: 15px 0px \
3px;overflow: hidden;"><span>Wondering if there is a way to hold Unison off from \
calculating its hash when a new file is being copied into a synchronization \
folder?</span></p><p style="padding: 15px 0px 3px;overflow: \
hidden;"><span><br></span></p><p style="padding: 15px 0px 3px;overflow: \
hidden;"><span>If a file is open and is being changed from a copy operation, could \
Unison ignore it until it is no longer open?</span></p><p style="padding: 15px 0px \
3px;overflow: hidden;"><span><br></span></p><p style="padding: 15px 0px 3px;overflow: \
hidden;"><span>What I am seeing is CPU utilization spike with Unison during the copy \
of a file to a folder that is designated for synchronization.</span></p><p \
style="padding: 15px 0px 3px;overflow: hidden;"><span><br></span></p><p \
style="padding: 15px 0px 3px;overflow: hidden;"><span>It appears that the \
synchronization (copy to other computer) is delayed until the local copy is complete, \
but the hash calculation is constantly being performed, hence high CPU utilization, \
before the local copy is complete.</span></p><p style="padding: 15px 0px \
3px;overflow: hidden;"><span><br></span></p><p style="padding: 15px 0px 3px;overflow: \
hidden;"><span>Does Unison check if a file is open and being modified before \
calculating the hash or determining if directories are \
different?</span></p><br><br><div width="1" style="color: \
white;"></div></div></blockquote></div><br></div></div></div></p>

    </div>
     

    <!--~-|**|PrettyHtmlStart|**|-~-->
    <div style="color: #fff; height: 0;">__._,_.___</div>

          
  
 

    
    <div style="clear:both"> </div>

    <div id="fromDMARC" style="margin-top: 10px;">
        <hr style="height:2px ; border-width:0; color:#E3E3E3; \
background-color:#E3E3E3;">  Posted by: &quot;Benjamin C. Pierce&quot; \
&lt;bcpierce@cis.upenn.edu&gt;        <hr style="height:2px ; border-width:0; \
color:#E3E3E3; background-color:#E3E3E3;">  </div>
    <div style="clear:both"> </div>

    <table cellspacing=4px style="margin-top: 10px; margin-bottom: 10px; color: \
#2D50FD;">  <tbody>
        <tr>
          <td style="font-size: 12px; font-family: arial; font-weight: bold; padding: \
7px 5px 5px;"  >  <a style="text-decoration: none; color: #2D50FD" \
href="https://groups.yahoo.com/neo/groups/unison-users/conversations/messages/11371;_y \
lc=X3oDMTJwYnJhNnM1BF9TAzk3MzU5NzE0BGdycElkAzQ3OTc2NwRncnBzcElkAzE3MDUwMDQ3MjYEbXNnSWQ \
DMTEzNzEEc2VjA2Z0cgRzbGsDcnBseQRzdGltZQMxNDE0MDA2MDUz?act=reply&messageNum=11371">Reply \
via web post</a>  </td>
          <td>&bull;</td>
          <td style="font-size: 12px; font-family: arial; padding: 7px 5px 5px;" >
            <a href="mailto:bcpierce@cis.upenn.edu?subject=Re%3A%20%5Bunison-users%5D%20Synchronization%20of%20file%20while%20local%20copy%20is%20in%20progress" \
style="text-decoration: none; color: #2D50FD;">  Reply to sender            </a>
          </td>
          <td>&bull;</td>
          <td style="font-size: 12px; font-family: arial; padding: 7px 5px 5px;">
            <a href="mailto:unison-users@yahoogroups.com?subject=Re%3A%20%5Bunison-users%5D%20Synchronization%20of%20file%20while%20local%20copy%20is%20in%20progress" \
style="text-decoration: none; color: #2D50FD">  Reply to group            </a>
          </td>
          <td>&bull;</td>
          <td style="font-size: 12px; font-family: arial; padding: 7px 5px 5px;" >
            <a href="https://groups.yahoo.com/neo/groups/unison-users/conversations/ne \
wtopic;_ylc=X3oDMTJkYXFtb3E2BF9TAzk3MzU5NzE0BGdycElkAzQ3OTc2NwRncnBzcElkAzE3MDUwMDQ3MjYEc2VjA2Z0cgRzbGsDbnRwYwRzdGltZQMxNDE0MDA2MDUz" \
style="text-decoration: none; color: #2D50FD">Start a New Topic</a>  </td>
          <td>&bull;</td>
          <td style="font-size: 12px; font-family: arial; padding: 7px 5px 5px;color: \
#2D50FD;" >  <a href="https://groups.yahoo.com/neo/groups/unison-users/conversations/t \
opics/11370;_ylc=X3oDMTM1NG04dTJwBF9TAzk3MzU5NzE0BGdycElkAzQ3OTc2NwRncnBzcElkAzE3MDUwM \
DQ3MjYEbXNnSWQDMTEzNzEEc2VjA2Z0cgRzbGsDdnRwYwRzdGltZQMxNDE0MDA2MDUzBHRwY0lkAzExMzcw" \
style="text-decoration: none; color: #2D50FD;">Messages in this topic</a>  (2)
                      </td>
        </tr>
      </tbody>
    </table>

        

<!------- Start Nav Bar ------>
<!-- |**|begin egp html banner|**| -->
<!-- |**|end egp html banner|**| -->




 

<!-- |**|begin egp html banner|**| -->
<div id="ygrp-vital" style="background-color: #f2f2f2; font-family: Verdana; \
font-size: 10px; margin-bottom: 10px; padding: 10px;">

    <span id="vithd" style="font-weight: bold; color: #333; text-transform: \
uppercase; "><a href="https://groups.yahoo.com/neo/groups/unison-users/info;_ylc=X3oDM \
TJkdjk3NmdzBF9TAzk3MzU5NzE0BGdycElkAzQ3OTc2NwRncnBzcElkAzE3MDUwMDQ3MjYEc2VjA3Z0bARzbGsDdmdocARzdGltZQMxNDE0MDA2MDUz" \
style="text-decoration: none;">Visit Your Group</a></span>

     <ul style="list-style-type: none; margin: 0; padding: 0; display: inline;">
            <li style="border-right: 1px solid #000; font-weight: 700; display: \
inline; padding: 0 5px; margin-left: 0;">  <span class="cat"><a \
href="https://groups.yahoo.com/neo/groups/unison-users/members/all;_ylc=X3oDMTJldHI3MT \
l1BF9TAzk3MzU5NzE0BGdycElkAzQ3OTc2NwRncnBzcElkAzE3MDUwMDQ3MjYEc2VjA3Z0bARzbGsDdm1icnMEc3RpbWUDMTQxNDAwNjA1Mw--" \
style="text-decoration: none;">New Members</a></span>  <span class="ct" style="color: \
#ff7900;">4</span>  </li>
                                              </ul>
  </div>


<div id="ft" style="font-family: Arial; font-size: 11px; margin-top: 5px; padding: 0 \
2px 0 0; clear: both;">  <a \
href="https://groups.yahoo.com/neo;_ylc=X3oDMTJjcTJzZm10BF9TAzk3NDc2NTkwBGdycElkAzQ3OTc2NwRncnBzcElkAzE3MDUwMDQ3MjYEc2VjA2Z0cgRzbGsDZ2ZwBHN0aW1lAzE0MTQwMDYwNTM-" \
style="float: left;"><img \
src="http://l.yimg.com/ru/static/images/yg/img/email/new_logo/logo-groups-137x15.png" \
height="15" width="137" alt="Yahoo! Groups" style="border: 0;"/></a>  <div \
style="color: #747575; float: right;"> &bull; <a \
href="https://info.yahoo.com/privacy/us/yahoo/groups/details.html" \
style="text-decoration: none;">Privacy</a> &bull; <a \
href="mailto:unison-users-unsubscribe@yahoogroups.com?subject=Unsubscribe" \
style="text-decoration: none;">Unsubscribe</a> &bull; <a \
href="https://info.yahoo.com/legal/us/yahoo/utos/terms/" style="text-decoration: \
none;">Terms of Use</a> </div> </div>
<br>

<!-- |**|end egp html banner|**| -->

  </div> <!-- ygrp-msg -->

 
  <!-- Sponsor -->
  <!-- |**|begin egp html banner|**| -->
  <div id="ygrp-sponsor" style="width:160px; float:right; clear:none; margin:0 0 25px \
0; background: #fff;">

<!-- Start Recommendations -->
<div id="ygrp-reco">
     </div>
<!-- End Recommendations -->



  </div>   <!-- |**|end egp html banner|**| -->

  <div style="clear:both; color: #FFF; font-size:1px;">.</div>
</div>

  <img src="http://geo.yahoo.com/serv?s=97359714/grpId=479767/grpspId=1705004726/msgId=11371/stime=1414006053" \
width="1" height="1"> <br>

<img src="http://y.analytics.yahoo.com/fpc.pl?ywarid=515FB27823A7407E&a=10001310322279&js=no&resp=img" \
width="1" height="1"> 

<div style="color: #fff; height: 0;">__,_._,___</div>
<!--~-|**|PrettyHtmlEnd|**|-~-->

</body>

<!--~-|**|PrettyHtmlStart|**|-~-->
<head>
  <style type="text/css">
  <!--
  #ygrp-mkp {
  border: 1px solid #d8d8d8;
  font-family: Arial;
  margin: 10px 0;
  padding: 0 10px;
}

#ygrp-mkp hr {
  border: 1px solid #d8d8d8;
}

#ygrp-mkp #hd {
  color: #628c2a;
  font-size: 85%;
  font-weight: 700;
  line-height: 122%;
  margin: 10px 0;
}

#ygrp-mkp #ads {
  margin-bottom: 10px;
}

#ygrp-mkp .ad {
  padding: 0 0;
}

#ygrp-mkp .ad p {
  margin: 0;
}

#ygrp-mkp .ad a {
  color: #0000ff;
  text-decoration: none;
}
  #ygrp-sponsor #ygrp-lc {
  font-family: Arial;
}

#ygrp-sponsor #ygrp-lc #hd {
  margin: 10px 0px;
  font-weight: 700;
  font-size: 78%;
  line-height: 122%;
}

#ygrp-sponsor #ygrp-lc .ad {
  margin-bottom: 10px;
  padding: 0 0;
}

  #actions {
    font-family: Verdana;
    font-size: 11px;
    padding: 10px 0;
  }

  #activity {
    background-color: #e0ecee;
    float: left;
    font-family: Verdana;
    font-size: 10px;
    padding: 10px;
  }

  #activity span {
    font-weight: 700;
  }

  #activity span:first-child {
    text-transform: uppercase;
  }

  #activity span a {
    color: #5085b6;
    text-decoration: none;
  }

  #activity span span {
    color: #ff7900;
  }

  #activity span .underline {
    text-decoration: underline;
  }

  .attach {
    clear: both;
    display: table;
    font-family: Arial;
    font-size: 12px;
    padding: 10px 0;
    width: 400px;
  }

  .attach div a {
    text-decoration: none;
  }

  .attach img {
    border: none;
    padding-right: 5px;
  }

  .attach label {
    display: block;
    margin-bottom: 5px;
  }

  .attach label a {
    text-decoration: none;
  }
  
  blockquote {
    margin: 0 0 0 4px;
  }

  .bold {
    font-family: Arial;
    font-size: 13px;
    font-weight: 700;
  }

  .bold a {
    text-decoration: none;
  }

  dd.last p a {
    font-family: Verdana;
    font-weight: 700;
  }

  dd.last p span {
    margin-right: 10px;
    font-family: Verdana;
    font-weight: 700;
  }

  dd.last p span.yshortcuts {
    margin-right: 0;
  }

  div.attach-table div div a {
    text-decoration: none;
  }

  div.attach-table {
    width: 400px;
  }

  div.file-title a, div.file-title a:active, div.file-title a:hover, div.file-title \
a:visited {  text-decoration: none;
  }

  div.photo-title a, div.photo-title a:active, div.photo-title a:hover, \
div.photo-title a:visited {  text-decoration: none;
  }

  div#ygrp-mlmsg #ygrp-msg p a span.yshortcuts {
    font-family: Verdana;
    font-size: 10px;
    font-weight: normal;
  }

  .green {
    color: #628c2a;
  }

  .MsoNormal {
    margin: 0 0 0 0;
  }

  o {
    font-size: 0;
  }

  #photos div {
    float: left;
    width: 72px;
  }

  #photos div div {
    border: 1px solid #666666;
    height: 62px;
    overflow: hidden;
    width: 62px;
  }

  #photos div label {
    color: #666666;
    font-size: 10px;
    overflow: hidden;
    text-align: center;
    white-space: nowrap;
    width: 64px;
  }

  #reco-category {
    font-size: 77%;
  }

  #reco-desc {
    font-size: 77%;
  }

  .replbq {
    margin: 4px;
  }

  #ygrp-actbar div a:first-child {
   /* border-right: 0px solid #000;*/
    margin-right: 2px;
    padding-right: 5px;
  }

  #ygrp-mlmsg {
    font-size: 13px;
    font-family: Arial, helvetica,clean, sans-serif;
    *font-size: small;
    *font: x-small;
  }

  #ygrp-mlmsg table {
    font-size: inherit;
    font: 100%;
  }

  #ygrp-mlmsg select, input, textarea {
    font: 99% Arial, Helvetica, clean, sans-serif;
  }

  #ygrp-mlmsg pre, code {
    font:115% monospace;
    *font-size:100%;
  }

  #ygrp-mlmsg * {
    line-height: 1.22em;
  }

  #ygrp-mlmsg #logo {
    padding-bottom: 10px;
  }


  #ygrp-msg p a {
    font-family: Verdana;
  }

  #ygrp-msg p#attach-count span {
    color: #1E66AE;
    font-weight: 700;
  }

  #ygrp-reco #reco-head {
    color: #ff7900;
    font-weight: 700;
  }

  #ygrp-reco {
    margin-bottom: 20px;
    padding: 0px;
  }

  #ygrp-sponsor #ov li a {
    font-size: 130%;
    text-decoration: none;
  }

  #ygrp-sponsor #ov li {
    font-size: 77%;
    list-style-type: square;
    padding: 6px 0;
  } 

  #ygrp-sponsor #ov ul {
    margin: 0;
    padding: 0 0 0 8px;
  }

  #ygrp-text {
    font-family: Georgia;
  }

  #ygrp-text p {
    margin: 0 0 1em 0;
  }

  #ygrp-text tt {
    font-size: 120%;
  }

  #ygrp-vital ul li:last-child {
    border-right: none !important; 
  } 
  -->
  </style>
</head>

<!--~-|**|PrettyHtmlEnd|**|-~-->
</html>
<!-- end group email -->



[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic