summaryrefslogtreecommitdiff
path: root/docs/development/jvm.txt
blob: 2f8085a972766ea575a015389cda1c7238581c7f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
Java Virtual Machine
====================


This document gathers technical informations about the Java VM to help
Java/Scala developers tuning their runtime settings on the Java VM.


Java VM Options
----------------

* -Xmx option (maximum heap size)

  Heaps larger than 2GB are available starting with J2SE 1.3.1

  Default:
    -client:  64M (32-bit UNIX and Windows, MacOS X)
    -server: 128M (MacOS X, see [vm11])

* -Xms option (initial heap size)

  Minimum: 1025K (Linux-i586, Solaris-i586), etc.. (see [vm08])
  Default:
    -client:  2M (32-bit UNIX and Windows, MacOS X)
    -server: 32M (MacOS X, see [vm11])

* -Xss option (thread stack size)

  Minimum: 48K (Linux-i586), 64K (Solaris-i586), etc.. (see [vm08])
  Default: 256K (32-bit UNIX and Windows)

  NB. Stack size under Windows is a link-time setting, so the executable
      (java.exe) as created by Sun has this 256K limit built in. Windows
      however, has a simple utility to modify the stack space of an
      executable (see [vm03]).
      In a command window (or Cygwin shell), use the EDITBIN command to
      permanently modify the executable (WARNING! Do not reduce the stack
      size below 32K, see [vm04])

      EDITBIN /STACK:16000000 C:\Path\To\java.exe


Scala Environment Options
-------------------------

* JAVACMD variable (Java command)

  Scala default: java (v2.x)

* JAVA_OPTS variable (Java options)

  Scala default: -Xmx256M -Xms16M (v2.x)


In the following example, simply replace <jdk> by
"java-1.5", "java-1.6", "java-1.7" or
"java-ibm-1.5" to experiment with different Java VMs:

> env JAVACMD=/home/linuxsoft/apps/<jdk>/bin/java \
      JAVA_OPTS="-Xmx256M -Xms16M -Xss128k" \
      test/scalatest test/files/shootout/message.scala



Resources
=========


VM Options and Tools
--------------------

[vm01] Some useful -XX options
       http://java.sun.com/javase/technologies/hotspot/vmoptions.jsp

[vm02] jvmstat 3.0
       http://java.sun.com/performance/jvmstat/

[vm03] Modify the actual java.exe executable on Windows
       http://www.eyesopen.com/docs/html/javaprog/node7.html

[vm04] Configuring server stack size
       https://ssa.usyd.edu.au/docs/eassag/eassag20.htm

[vm06] Tuning the Java Runtime System
       http://docs.sun.com/source/817-2180-10/pt_chap5.html

[vm07] JVM Tuning
       http://www.caucho.com/resin-3.0/performance/jvm-tuning.xtp

[vm08] Java HotSpot: load the VM from a non-primordial thread and effects
       on stack and heap limits.
       http://blogs.sun.com/ksrini/entry/hotspot_primordial_thread_jni_stack

[vm09] A Collection of JVM Options (13-Dec-2005)
       http://blogs.sun.com/watt/resource/jvm-options-list.html

[vm10] The Java VM for Mac OS X (Apple Developer Connection, 2006-05-23)
       http://developer.apple.com/documentation/Java/Conceptual/Java14Development/06-JavaVM/JavaVM.html#//apple_ref/doc/uid/TP40001903-211276-TPXREF107

[vm11] Java Virtual Machine Options (Apple Developer Connection, 2006-05-23)
       http://developer.apple.com/documentation/Java/Conceptual/JavaPropVMInfoRef/Articles/JavaVirtualMachineOptions.html#//apple_ref/doc/uid/TP40001974-SW1

[vm12] Running your Java application on AIX, Part 2: JVM memory models (22 Oct 2003)
       http://www-128.ibm.com/developerworks/aix/library/au-JavaPart2.html

[vm13] Options in JVM profiles (IBM)
       http://publib.boulder.ibm.com/infocenter/cicsts/v3r1/index.jsp?topic=/com.ibm.cics.ts31.doc/dfha2/dfha2jb.htm


Garbage Collection
------------------

[gc01] Tuning Garbage Collection with the 5.0 Java[tm] Virtual Machine
       http://java.sun.com/docs/hotspot/gc5.0/gc_tuning_5.html

[gc02] Tuning Garbage Collection with the 1.4.2 Java[tm] Virtual Machine
       http://java.sun.com/docs/hotspot/gc1.4.2/

[gc03] Tuning Garbage Collection with the 1.3.1 Java[tm] Virtual Machine
       http://java.sun.com/docs/hotspot/gc/

[gc04] Garbage Collector Ergonomics
       http://java.sun.com/j2se/1.5.0/docs/guide/vm/gc-ergonomics.html