Merge remote-tracking branch 'origin' into 1495-crunch-documentation
[arvados.git] / doc / user / tutorial-firstscript.textile
1 ---
2 layout: default
3 navsection: userguide
4 title: "Tutorial: Writing a Crunch script"
5 navorder: 13
6 ---
7
8 h1. Tutorial: Writing a Crunch script
9
10 In this tutorial, we will write the "hash" script demonstrated in the first tutorial.
11
12 *This tutorial assumes that you are "logged into an Arvados VM instance":ssh-access.html#login, and have a "working environment.":check-environment.html*
13
14 This tutorial uses _you_ to denote your username.  Replace _you_ with your user name in all the following examples.
15
16 h2. Setting up Git
17
18 As discussed in the previous tutorial, all Crunch scripts are managed through the @git@ revision control system.
19
20 First, you should do some basic configuration for git (you only need to do this the first time):
21
22 <notextile>
23 <pre><code>$ <span class="userinput">git config --global user.name "Your Name"</span>
24 $ <span class="userinput">git config --global user.email you@example.com</span></code></pre>
25 </notextile>
26
27 On the Arvados Workbench, navigate to _Access %(rarr)&rarr;% Repositories._  You should see two repositories, one named "arvados" (under the *name* column) and a second with your user name.  Next to *name* is the column *push_url*.  Copy the *push_url* cell associated with your repository.  This should look like <code>git@git.{{ site.arvados_api_host }}:you.git</code>.
28
29 Next, on the Arvados virtual machine, clone your git repository:
30
31 <notextile>
32 <pre><code>$ <span class="userinput">git clone git://git.{{ site.arvados_api_host }}:you.git</span>
33 Cloning into 'you'...</code></pre>
34 </notextile>
35
36 This will create an git checkout in the directory called @you@.
37
38 {% include notebox-begin.html %}
39 For more information about using @git@, try
40
41 notextile. <pre><code>$ <span class="userinput">man gittutoral</span></code></pre>
42
43 or "click here search Google for git tutorials":http://google.com/#q=git+tutorial
44 {% include notebox-end.html %}
45
46 h2. Creating a Crunch script
47
48 Start by entering the @you@ directory, creating a subdirectory called @crunch_scripts@ and changing to that directory:
49
50 <notextile>
51 <pre><code>$ <span class="userinput">cd you</span>
52 $ <span class="userinput">mkdir crunch_scripts</span>
53 $ <span class="userinput">cd crunch_scripts</span></code></pre>
54 </notextile>
55
56 Next, create a new file called @hash@ in the @crunch_scripts@ directory.  Add the following code to compute the md5 hash of each file in a collection:
57
58 <pre><code class="userinput">{% include tutorial_hash_script.py %}</code></pre>
59
60 Make the file executable:
61
62 notextile. <pre><code>$ <span class="userinput">chmod +x hash</span></code></pre>
63
64 Next, add the file to @git@ staging.  This tells @git@ that the file should be included on the next commit.
65
66 notextile. <pre><code>$ <span class="userinput">git add hash</span></code></pre>
67
68 Next, commit your changes to git.  All staged changes are recorded into the local @git@ repository:
69
70 <notextile>
71 <pre><code>$ <span class="userinput">git commit -m"my first script"</span>
72 [master (root-commit) 27fd88b] my first script
73  1 file changed, 33 insertions(+)
74  create mode 100755 crunch_scripts/hash</code></pre>
75 </notextile>
76
77 Finally, upload your changes to the Arvados server:
78
79 <notextile>
80 <pre><code>$ <span class="userinput">git push origin master</span>
81 Counting objects: 4, done.
82 Compressing objects: 100% (2/2), done.
83 Writing objects: 100% (4/4), 682 bytes, done.
84 Total 4 (delta 0), reused 0 (delta 0)
85 To git@git.qr1hi.arvadosapi.com:you.git
86  * [new branch]      master -> master</code></pre>
87 </notextile>
88
89 You should now be able to run your script using Crunch, similar to how we did it in the "first tutorial.":tutorial-job1.html  The field @"script_version"@ should be @you:master@ to tell Crunch to run the script that you just uploaded.
90
91 <notextile>
92 <pre><code>$ <span class="userinput">read -d $'\000' the_job &lt;&lt;EOF
93 {
94  "script": "hash",
95  "script_version": "you:master",
96  "script_parameters":
97  {
98   "input": "33a9f3842b01ea3fdf27cc582f5ea2af"
99  }
100 }
101 EOF</span>
102 $ <span class="userinput">arv job create --job "$the_job"</span>
103 {
104  ...
105 }</code></pre>
106 </notextile>
107