File: installation.xml

package info (click to toggle)
libjgroups-java 2.12.2.Final-5
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, buster
  • size: 8,724 kB
  • sloc: java: 109,098; xml: 9,423; sh: 174; makefile: 4
file content (222 lines) | stat: -rw-r--r-- 9,389 bytes parent folder | download | duplicates (4)
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
<chapter>
    <title>Installation</title>

    <section>
        <title>Download</title>
        <para>
            JGroups can be downloaded <ulink url="http://sourceforge.net/project/showfiles.php?group_id=6081">here</ulink>.
            For this tutorial, I'm using the binary version of JGroups 2.5, so the ZIP file to download is
            JGroups-2.5.0.bin.zip. <emphasis>Note that JGroups 2.5 requires JDK 1.5 or higher</emphasis>.
        </para>

        <para>
            Unzip JGroups-2.5.0.bin.zip into a directory JGroups-2.5.0.bin. The contents of the directory are
            <figure id="BinaryContents">
                <title>Screenshot of the JGroups binary distribution</title>
                <graphic fileref="images/BinaryContents.png" format="PNG" align="center"/>
            </figure>
        </para>

        <para>
            The most important files are:
            <itemizedlist>
                <listitem>
                    jgroups.bat and jgroups.sh: scripts to run a JGroups application (including the correct JARs and
                    XML files)
                </listitem>
                <listitem>
                    INSTALL.html: detailed configuration instructions plus trouble shooting
                </listitem>
                <listitem>
                    jgroups-all.jar (<emphasis>required</emphasis>): JGroups functionality, including demo and junit
                    apps. If a smaller JAR is required, this can be done by downloading the source distribution and
                    invoking the "jar" target, which creates a jgroups-core.jar file (ca 1MB).
                </listitem>
                <listitem>
                    log4j.jar (optional): commons-logging can also use JDK logging
                </listitem>
                <listitem>
                    Various XML file: different JGroups configurations, e.g.
                    <itemizedlist>
                        <listitem>
                            mping.xml: TCP based stack with dynamic discovery
                        </listitem>
                        <listitem>
                            sfc.xml: UDP (using IP multicasting) based stack with simple flow control
                        </listitem>
                        <listitem>
                            tcp-nio.xml: TCP based stack with fixed configuration (list of nodes) using NIO (thread
                            pool for all TCP connections)
                        </listitem>
                        <listitem>
                            tcp-nio.xml: TCP based stack with fixed configuration (list of nodes) using plain TCP
                            (1 thread / TCP connection)
                        </listitem>
                        <listitem>
                            tcpgossip.xml: tunnel based configuration which routes messages to a remote
                            GossipRouter, used to tunnel firewalls
                        </listitem>
                        <listitem>
                            udp.xml: default IP multicast based configuration
                        </listitem>
                    </itemizedlist>
                </listitem>
                <listitem>
                    config.txt: configuration file for performance tests
                </listitem>
            </itemizedlist>
        </para>
    </section>


    <section>
        <title>Configuration</title>
        <para>
            Add jgroups-all.jar to your CLASSPATH. If you use the log4j logging system, you also
            have to add log4j.jar (this is not necessary if you use the JDK logging system).
        </para>
        <para>
            As an alternative, you can also use jgroups.bat. Note that jgroups.sh requires work, as it uses backslashes
            (developed under Cygwin/Windows), so it is currently not usable under UNIX as is.
        </para>
    </section>

    <section>
        <title>Testing your Setup</title>

        <para>To see whether your system can find the JGroups classes, execute the following command:</para>

        <screen>
            java org.jgroups.Version
        </screen>

        <para>or</para>

        <screen>
            java -jar jgroups-all.jar
        </screen>

        <para>You should see the following output (more or less) if the
            class is found:</para>

        <screen>
            $ java -jar jgroups-all.jar

            Version:        2.5.0
            CVS:            $Id: installation.xml,v 1.4 2009/05/13 13:22:09 belaban Exp $
            History:        (see doc/history.txt for details)
        </screen>

    </section>

    <section>
        <title>Running a Demo Program</title>

        <para>To test whether JGroups works okay on your machine, run the following command twice:
        </para>

        <screen>
            java org.jgroups.demos.Draw
        </screen>

        <para>2 whiteboard windows should appear as shown in <xref linkend="DrawScreenshotFig"/>.

            <figure id="DrawScreenshotFig"><title>Screenshot of 2 Draw instances</title>
                <graphic fileref="images/DrawScreenshot.png" format="PNG" align="center"  />
            </figure>

            If you started them simultaneously, they could initially show a membership of 1 in
            their title bars. After some time, both windows should show 2. This means that the two instances found
            each other and formed a group.</para>

        <para>When drawing in one window, the second instance should also
            be updated. As the default group transport uses IP multicast, make
            sure that - if you want start the 2 instances in different subnets
            - IP multicast is enabled. If this is not the case, the 2
            instances won't 'find' each other and the sample won't work.
        </para>

        <para>
            If the 2 instances find each other and form a cluster, you can skip ahead to the next chapter ("Writing
            a simple application").
        </para>

    </section>

    <section>
        <title>Using JGroups without a network</title>

        <para>
            (You may skip this section if the 2 instances found each other correctly in the previous section).
        </para>

        <para>Sometimes there isn't a network connection (e.g. DSL modem
            is down), or we want to multicast only on the local machine. To do
            this, we can use the loopback device (127.0.0.1):
        </para>
        <screen>
            java -Djgroups.bind_addr=127.0.0.1 org.jgroups.demos.Draw
        </screen>

        <para>
            You should again see 2 instances of Draw which form a cluster. If this is not the case, you may
            have to add a multicast route to the loopback device (this requires superuser or admin privileges):
        </para>

        <screen>
            route add -net 224.0.0.0 netmask 240.0.0.0 dev lo
        </screen>

        <para>This means that all traffic directed to the 224.0.0.0
            network will be sent to the loopback interface, which means it
            doesn't need any network to be running.
        </para>

        <para>Typical home networks have a gateway/firewall with 2 NICs:
            the first (eth0) is connected to the outside world (Internet
            Service Provider), the second (eth1) to the internal network, with
            the gateway firewalling/masquerading traffic between the internal
            and external networks. If no route for multicast traffic is added,
            the default will be to use the fdefault gateway, which will
            typically direct the multicast traffic towards the ISP. To prevent
            this (e.g. ISP drops multicast traffic, or latency is too high),
            we recommend to add a route for multicast traffic which goes to
            the internal network (e.g. eth1).
        </para>

    </section>

    <section>
        <title>Trouble shooting</title>
        <para>
            If the 2 Draw instances don't find each other, read INSTALL.html, which comes with JGroups and has more
            detailed trouble shooting information. In a nutshell, there are multiple possible reasons the cluster
            doesn't form:
            <itemizedlist>
                <listitem>
                    A firewall discards packets. To verify this, turn the firewall off. If the cluster forms, then turn
                    the firewall back on and selectively add rules to let JGroups traffic pass.
                </listitem>
                <listitem>
                    Use of IPv6. JGroups does work with IPv6, but some JDK implementations still have issues with it, so
                    you can turn IPv6 off by passing the "-Djava.net.preferIPv4Stack=true" system property to the JVM.
                </listitem>
                <listitem>
                    You don't use the right network interface (NIC): define the NIC with the jgroups.bind_addr system
                    property:
                    <screen>
                        java -Djgroups.bind_addr=192.168.5.2 java.org.jgroups.demos.Draw
                    </screen>
                </listitem>
                <listitem>
                    There is no multicast route for the chosen NIC.
                </listitem>
            </itemizedlist>
        </para>
    </section>


</chapter>