Project

General

Profile

Actions

How to run a sample » History » Revision 26

« Previous | Revision 26/39 (diff) | Next »
Henning Blohm, 21.09.2012 18:08


How to run a sample

Various z2-based sample system configurations have been prepared as Git repositories.

Assuming you know the repository URL these three steps (with or without Eclipse) are all there is to do.

While these instructions are for Git users, they can be applied to the Subversion case quite similarly as described below.

Eclipse users (recommended)

Most likely you will want to look at code or configuration files of a sample. That is why we recommend to start from within the Eclipse IDE. If you prefer the command line or another IDE, please proceed to From the command line.

Open Eclipse with a new workspace in a new folder, say sample. Note: We will clone repositories as siblings to your workspace. So let's assume your workspace is sample/workspace.

1. Prepare a z2-base installation

As the location where repositories are cloned to matters, it is simplest you open the Git tab in the Eclipse preferences and enter "${workspace_loc}/.." as default repository location.

Open the Git Perspective and clone the z2-base.core repository from this URL http://git.z2-environment.net/z2-base.core. For convenience choose to import all projects into the workspace or do so after cloning has completed. You should end up having a project core in your workspace. That project is the z2 core that will fetch dependency resources as needed later on.

2. Clone the sample repository

Now repeat the same with the repository for the specific sample. It is important that the repository is cloned as a sibling to the core, So that the core can pick up modules defined in the sample.

3. Start and introspect

You can launch Z2 from Eclipse by the launcher file in the root of the core project (or by navigating to Run / External Tools / External Tools Configurations... and pick the launcher). A GUI wrapping the console should open up and you are ready to go.

Once it is running, import the projects from the sample repository into your workspace, so that you can have a look at them. If you have previously installed the Eclipsoid plugin (see Step_3_-_First_steps_with_Z2_on_Git) you can conveniently resolve all compilation dependencies with one click from within Eclipse.

From the command line

All you need is Java Runtime Environment (JRE) of at least version 6. Other pre-requisites, for example some database setup may be required based on the specific example, i.e. stuff that cannot be covered here.

1. Prepare a z2-base installation

Create a folder to hold the installation. We will assume that folder is called sample

In sample execute

git clone -b master http://git.z2-environment.net/z2-base.core

Go into sample/z2-base.core/run/bin and run

./gui.sh

or

gui.bat

depending on your operating system. A simple graphical console should open up that displays the console log output of the z2 <home> and worker processes - as explained in http://www.z2-environment.eu/check_it_out.

At the first start, the environment will download required resources, which may take a few minutes - depending on your network bandwidth. Subsequent starts will be much quicker. Eventually the server should be up and you can go to the basic admin view at http://localhost:8080/adm (use z* with password z) to verify everything is cool. You do actually not need to start before completing step 3. But checking things are working doesn't hurt either.

Stop the environment again by either pressing Ctrl+C on the console where you started the GUI or by clicking the Exit button on the GUI.

2. Clone the specific sample repository

Given the sample repository is called z2-samples.sampleX, go into sample once more and run

git clone -b master http://git.z2-environment.net/z2-samples.sampleX

3. Start

Now start the environment again as described above. The environment will now run with the sample configuration and all required dependencies.

In other words: That's it.

Why does that actually work?

If you care, here is how everything falls into place:

The z2-base.core repository contains a z2 core installation that is bound to a remote "system repository" at http://git.z2-environment.net/z2-base.base. As it is by now best practice with z2, that repository contains an environment module that describes system specific settings such as other repositories.

By cloning the sample repository you put an override of environment module into view of the dev repository. That is, the local server will take your local definitions with preference over the remote definitions. These may include other remote component repositories such as z2-addons.spring.

In addition the sample repository contains all the modules holding code and other resources that implement the actual sample.

If you already understand how the dev repository works, you will not be surprised to find files called LOCAL in the module folders of cloned repository's workspace.

Subversion support

Please see Repositories for the mapping of Git repositories to Subversion repositories. Samples are generally provided just the same - but throughout configured for Subversion - in the respective Subversion repositories.

When you are using Eclipse, instead of cloning the whole repository to get the modules of the sample however, you do instead check out all modules in the repository to your workspace or in some folder. All the rest is just the same.

So, for example, given the z2-samples.spring-basic sample, from the command line run

mkdir sample
cd sample
svn co http://z2-environment.net/svn/z2-master/trunk/z2-base.core
svn co http://z2-environment.net/svn/z2-master/trunk/z2-samples.spring-basic
cd z2-base.core/run/bin
./gui.sh

(use the Subversion user "z2-master" with password "z2-master").

Similarly, in Eclipse, in some workspace, first check out http://z2-environment.net/svn/trunk/z2-base.core (should get your a project named "core") and then check out all projects underneath http://z2-environment.net/svn/trunk/z2-base.spring-basic. Use the z2 start launcher to start Z2.

References

Updated by Henning Blohm over 11 years ago · 26 revisions