Initial add of defaria.com
[clearscm.git] / defaria.com / blogs / Status / archives / 2012_09.html
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
2    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" id="sixapart-standard">
4 <head>
5    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
6    <meta name="generator" content="Movable Type 5.2.3" />
7
8    <link rel="stylesheet" href="http://defaria.com/blogs/Status/styles-site.css" type="text/css" />
9    <link rel="alternate" type="application/atom+xml" title="Atom" href="http://defaria.com/blogs/Status/atom.xml" />
10    <link rel="alternate" type="application/rss+xml" title="RSS 2.0" href="http://defaria.com/blogs/Status/index.xml"$>" />
11
12    <title>Status for Andrew DeFaria: September 2012 Archives</title>
13
14    <link rel="start" href="http://defaria.com/blogs/Status/" title="Home" />
15    <link rel="prev" href="http://defaria.com/blogs/Status/archives/2012_08.html" title="August 2012" />
16    <link rel="next" href="http://defaria.com/blogs/Status/archives/2013_02.html" title="February 2013" />
17 </head>
18 <body class="layout-one-column">
19    <div id="container">
20       <div id="container-inner" class="pkg">
21
22          <div id="banner">
23             <div id="banner-inner" class="pkg">
24                <h1 id="banner-header"><a href="http://defaria.com/blogs/Status/" accesskey="1">Status for Andrew DeFaria</a></h1>
25                <h2 id="banner-description">Searchable status reports and work log</h2>
26             </div>
27          </div>
28
29          <div id="pagebody">
30             <div id="pagebody-inner" class="pkg">
31                <div id="alpha">
32                   <div id="alpha-inner" class="pkg">
33                      
34                      <p class="content-nav">
35                         <a href="http://defaria.com/blogs/Status/archives/2012_08.html">&laquo; August 2012</a> |
36                         <a href="http://defaria.com/blogs/Status/">Main</a>
37                         | <a href="http://defaria.com/blogs/Status/archives/2013_02.html">February 2013 &raquo;</a>
38                      </p>
39                      
40                      
41                      <!--
42 <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
43          xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/"
44          xmlns:dc="http://purl.org/dc/elements/1.1/">
45 <rdf:Description
46     rdf:about="http://defaria.com/blogs/Status/archives/2012_09.html#entry-000757"
47     trackback:ping="http://defaria.com/mt/mt-tb.cgi/121"
48     dc:title="Speed of network reads as opposed to network writes"
49     dc:identifier="http://defaria.com/blogs/Status/archives/2012_09.html#entry-000757"
50     dc:subject="Broadcom"
51     dc:description=" body { font: Helvetica, Arial, sans-serif; } p { font: Helvetica, Arial, sans-serif; } .standout { font-family: verdana, arial, sans-serif; font-size: 12px; color: #993333; line-height: 13px; font-weight: bold; margin-bottom: 10px; } .code { border-top: 1px solid #ddd; border-left: 1px..."
52     dc:creator=""
53     dc:date="2012-09-21T14:06:08-06:00" />
54 </rdf:RDF>
55 -->
56
57
58                      <h2 class="date-header">September 21, 2012</h2>
59                      <a id="a000757"></a>
60                      <div class="entry" id="entry-757">
61                         <h3 class="entry-header">Speed of network reads as opposed to network writes</h3>
62                         <div class="entry-content">
63                            <div class="entry-body">
64                               <html>
65 <head>
66 <style type="text/css">
67 body {
68 font: Helvetica, Arial, sans-serif;
69 }
70 p {
71 font: Helvetica, Arial, sans-serif;
72 }
73 .standout {
74 font-family: verdana,
75 arial,
76 sans-serif;
77 font-size: 12px;
78 color: #993333;
79 line-height: 13px;
80 font-weight: bold;
81 margin-bottom: 10px;
82 }
83 .code {
84 border-top: 1px solid #ddd;
85 border-left: 1px solid #ddd;
86 border-right: 2px solid #000;
87 border-bottom: 2px solid #000;
88 padding: 10px;
89 margin-top: 5px;
90 margin-left: 5%;
91 margin-right: 5%;
92 background: #ffffea;
93 color: black;
94 font-family: courier;
95 white-space: pre;
96 -moz-border-radius: 10px;
97 }
98 .terminal {
99 border-top: 10px solid #03f;
100 border-left: 1px solid #ddd;
101 border-right: 2px solid grey;
102 border-bottom: 2px solid grey;
103 padding: 10px;
104 margin-top: 5px;
105 margin-left: 5%;
106 margin-right: 5%;
107 background: black;
108 color: white;
109 font-family: courier;
110 white-space: pre;
111 -moz-border-radius: 10px;
112 }
113 a:link {
114 color: blue;
115 }
116 a:visited {
117 color: darkblue;
118 }
119 a:hover {
120 color: black;
121 background-color: #ffffcc;
122 text-decoration: underline;
123 }
124 a:active {
125 color: red;
126 }
127 </style>
128 </head><body>I was asked to test the difference in speed between network reads and network writes. Now, of course, a lot of this is highly tuneable and depends on various things like protocol used (NFS vs SMB), whether you are writing over a LAN or a WAN, the rated speed of those links (1G vs 100M vs 10M or less), as well as the options used (for NFS things like rsize, wsize to name a few). However as currently configured the following test was done:<br><br>I created a file of some size (336M) which I will copied between local and remote file systems using a push strategy and a pull strategy. Lacking having root capability needed to mount filesystems via NFS between say San Jose and Irvine or playing around with SMB I decided to use my home directory, which is NFS mounted, and the local file system of /tmp.&nbsp; By push I mean that cp copying the file from /tmp to my home directory which is NFS mounted thus over the network. By pull I mean that cp was copying the file from my NFS mounted home directory and writing it to /tmp. Therefore push = local reads with network writes and pull = network reads and local writes. Here are the results...<br><br>First I did a little loop:<br><blockquote><tt>Xl-irv-05:i=0; while [ $i -lt 100 ]; do<br>/usr/bin/time -f %E -a -o pull.csv cp ~/336megfile /tmp/336megfile<br>let i=i+1<br>done</tt><br></blockquote>This pulls this 336megfile 100 times from my home directory to the local /tmp directory. The GNU time command is used to capture the time each of these takes. Network conditions and system workloads can cause this to vary so I take 100 samples.<br><br>Similarly this loop does the push:<br><blockquote><tt>Xl-irv-05:i=0; while [ $i -lt 100 ]; do<br>/usr/bin/time -f %E -a -o push.csv cp /tmp/336megfile ~/336megfile<br>let i=i+1<br>done<br></tt></blockquote>Doing a little Excel yields:<br><br><img src="" alt=""><br><br>Bottom line: <br><blockquote>
129 <table style="width: 192pt;" bgcolor="#000000" border="0" cellpadding="2" cellspacing="1" width="256"><colgroup><col style="width:48pt" span="4" width="64">
130 </colgroup><tbody><tr style="height:15.0pt" height="20">
131 <th style="height:15.0pt;width:48pt" bgcolor="#ffffcc" height="20" width="64"><br></th>
132 <th class="xl68" style="width:48pt" bgcolor="#ffffcc" width="64">Pull</th>
133 <th class="xl68" style="width:48pt" bgcolor="#ffffcc" width="64">Push</th>
134 <th class="xl69" style="width:48pt" bgcolor="#ffffcc" width="64">Diff</th>
135 </tr>
136 <tr style="height:15.0pt" height="20">
137 <th class="xl66" style="height:15.0pt" bgcolor="#ffffcc" height="20">Average</th>
138 <td class="xl67" align="right" bgcolor="#ffffff">0.79</td>
139 <td class="xl67" align="right" bgcolor="#ffffff">4.29</td>
140 <td class="xl65" align="right" bgcolor="#ffffff">5.45<br></td>
141 </tr>
142 </tbody></table></blockquote>
143 Pulling data where the writes are local took on average 0.79 seconds and is 5.45 times quicker than pushing data where the writes are over the network which took, on average, 4.29 seconds.<br><br><b>Moral</b>: If you have to work over a LAN or WAN, try to make your writes local...
144                               
145                               <p class="entry-footer">
146                                  <span class="post-footers">Posted by  at  2:06 PM</span> <span class="separator">|</span> <a class="permalink" href="http://defaria.com/blogs/Status/archives/000757.html">Permalink</a>
147                                  
148                                  | <a href="http://defaria.com/blogs/Status/archives/000757.html#trackback">TrackBacks (0)</a>
149                               </p>
150                            </div>
151                         </div>
152                      </div>
153                      
154                      <!--
155 <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
156          xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/"
157          xmlns:dc="http://purl.org/dc/elements/1.1/">
158 <rdf:Description
159     rdf:about="http://defaria.com/blogs/Status/archives/2012_09.html#entry-000756"
160     trackback:ping="http://defaria.com/mt/mt-tb.cgi/120"
161     dc:title="Shebang and script interpreters"
162     dc:identifier="http://defaria.com/blogs/Status/archives/2012_09.html#entry-000756"
163     dc:subject="Broadcom"
164     dc:description="Turns out that you cannot put a script as the interpreter for your #! line. It must be a binary. Also, many IT departments forced with supporting various Unix/Linux&apos;s often have a set of scripts that &quot;do the right thing(tm)&quot;..."
165     dc:creator=""
166     dc:date="2012-09-14T17:48:31-06:00" />
167 </rdf:RDF>
168 -->
169
170
171                      <h2 class="date-header">September 14, 2012</h2>
172                      <a id="a000756"></a>
173                      <div class="entry" id="entry-756">
174                         <h3 class="entry-header">Shebang and script interpreters</h3>
175                         <div class="entry-content">
176                            <div class="entry-body">
177                               <p>Turns out that you cannot put a script as the interpreter for your #! line. It must be a binary. Also, many IT departments forced with supporting various Unix/Linux's often have a set of scripts that "do the right thing(tm)" to set up an environment for the target architecture then execute the architecturally appropriate binary. I did this way back with /app server.</p>
178
179 <p>So what do you do when you are say writing an expect script and wish to use #!/app/expect? The trick is to use something like #!/usr/bin/env /app/expect. Most people are familiar with using env(1) to print out the environment and it turns out it does - if you don't give it any other parameter. But it's real main purpose is "run a program in a modified environment". So if you wish to use an interpreter that is a script use #!/usr/bin/env /path/to/script as your shebang line.</p>
180                               
181                               <p class="entry-footer">
182                                  <span class="post-footers">Posted by  at  5:48 PM</span> <span class="separator">|</span> <a class="permalink" href="http://defaria.com/blogs/Status/archives/000756.html">Permalink</a>
183                                  
184                                  | <a href="http://defaria.com/blogs/Status/archives/000756.html#trackback">TrackBacks (0)</a>
185                               </p>
186                            </div>
187                         </div>
188                      </div>
189                      
190                   </div>
191                </div>
192             </div>
193          </div>
194       </div>
195    </div>
196 </body>
197 </html>