The Well House Newsletter - Tuesday, 1st November 2011
About us and this newsletter [link] ...
Previous editions: September 2011July 2011May 2011March 2011January 2011November 2010September 2010July 2010May 2010 • or current edition

Public Transport Training from Well House Consultants And also ... Tcl, Tcl/Tk and Expect Programming in Lua Python Programming Well House Manor - Hotel and Training Centre Apache HTTP and Tomcat Servers The Perl Programming Language and its use Ruby and Ruby on Rails PHP - the language and its application C and C++ Programming Linux and Shell Programming Melksham SQL and MySQL For the Webmaster, Postmaster and moderator Java and the Java Environment Fun and Flames Running a training and hotel company Around, about and nearby to Wiltshire Client Side Languages (HTML, CSS, Javascript) Keynote Articles General Programming Topics
Keynote article ...

Clustering on Tomcat

Subject: Clustering, using Apache http server (version 2.2.14 in my example) with mod_proxy_balancer as the front load splitter and Apache Tomcat 6.0.20 as the replicated application engine. [[Tip should also work for other recent 2.2.x and 6.0.x versions]]

Background

This is a follow on article from Load balancing with sticky sessions (httpd / Tomcat), where I looked at sharing out the application work between a number instances of Tomcat from an Apache http server (httpd) that did the bookkeeping. In a nutshell, the Apache http server sent new arrivals to a 'random' Tomcat, and then used sticky sessions so that - when a visitor came back for their subsequent visit in the same series of accesses - they would always talk to the same Tomcat and could continue their conversation with the server having full knowledge of the position to date.

The balancer alone is a good solution as far as it goes but:
• What happens if the Tomcat that has been stuck to goes out of service?
• What happens if you have such a lot of traffic that you need to replicate your httpd front end?
• What happens if your httpd fails?
• What is you don't actually want to use sessions, but still need what appears to be a single Tomcat?

One possible option to addressing some of these is to use the clustering capability of Tomcat, which I'll describe below. But you should first consider if you really need the extra step:
(a) can I accept that a session will be lost on the rare occasions that a Tomcat goes offline?
(b) is writing to a backend database going to preserve sufficient information anyway?
and if the answer to either is "yes", you probably do NOT need to cluster.

How does clustering work?

You run your web application on a series of identical (or rather "near identical" - the IP address will differ!) servers. With clustering turned on, each of the servers in the cluster is broadcasting (via multicast) any changes made in sessions, cookies, etc to any other listening cluster members on that same multicast address. So that when a visitor comes back for his / her next access, all the machines know what's been going on and can knowledgeably handle the request, even if the original machine isn't available.

You can turn clustering on in Apache Tomcat 6.0.20 simply by uncommenting the line in the default server.xml file that relates to it:
  <Cluster className = "org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
and restating your Tomcat. Older versions of Tomcat (such as 5.5) had a long configuration section listing the ports, replication time, IP addresses to use, trigger files all of which are important but none of which actually needs to be changed from default in the current release that's the target of this article.

Once you have turned clustering on (yes, it's now that simple), your machines will be communicating ... it's rather like starting a rumor in an office - before you know it, EVERYONE who's around has heard the rumor.

Clustering with the balancer

If you have already implemented balancing with sticky sessions (as covered in the preceeding article), turning on clustering will cause the data to be shared around. Most of the time the data passed around will not be used - it will ONLY form a backup of the session, to be used if the balancer is unable to reach the sticky machine because it has done down or been taken out of service.

With sticky sessions activated, even a second front-end Apache http server won't cause a switch from one Tomcat to another unless a fail-over occurs, as the jvmroute is a part of the cookie so either (any) of the httpd front ends will correctly forward to the original Tomcat. And if you have an intelligent hardware load balancer, that too will be able to forward consistently and the the clustering will remain merely as a backup.

If you disable sticky sessions on your balancer, the metrics will change. Forwarding will now be at shared to each of the Tomcats in the balanced group / cluster group (take care that all members of the balance group are included in the cluster!) and so the visitor will get to a differnt back end box each time. But that's now perfectly fine, as they're sharing the data between them so will all know about the originator.

Testing if your cluster is working

Ironically, clustering and balancing is designed to be transparent, so how do you test whether it's working?

My first simple 'trick' is to change the background colour of the pages returned from each cluster member so that "if it's orange it must be Holt" and "if it's blue it must be Chippenham" (our servers are names after local towns and villages!). Going a little further, you can edit your servlet / JSP to return the name of the current host. In Java, the following line:
  String myname = InetAddress.getLocalHost().getHostName();
will return you the local name of your computer, so that you can then echo the name.

On last Tuesday's course, I took our sample "Barman" script that remembers how many drinks you've had in a session (visit counter!) and extended it into a "Pub Watch" script, where each of the barman communicates with his colleagues in neighboring pubs to keep track of who's out on the town, and how much they have had to drink in each establishment.

If you click on the links in the previous paragraph, you can download the source code for "Barman" and "PubWatch" and try the code out for yourself. Using the balancer manage that I introduced at the end of yesterday's article, you can open and close individual pubs and see how their customers go elsewhere for their next drink, and you can turn sticky sessions off in the balancer and see how faithful customers will then hit the road and go to a different pub each time for their next drink.

Some notes on clustering

1. The machines in the cluster communicate through multicast, so must be on the same subnet.

2. It's a good idea for the subnet you use to have plenty of capacity if your environment is busy, and for it to be firmly behind a strong firewall from your own company's general user traffic, let alone the Internet

3. If you have multiple Tomcat clusters on the same subnet, you'll need to configure one of the clusters away from the default settings - otherwise they'll end up as being one big cluster (you'll find the word 'tribe' creaping in here!)

At present, we mention clustering on our public deploying apache httpd and Tomcat course. Only a small proportion of our delegate want to go 'that far', and for newcomers who hadn't done any web server work when they first came along a couple of days earlier, it would be just too much for the one session.

An extra day on the end of a Tomcat course, coverage in a private course, or a special session set up for the purpose ... all are possible to help you learn how clustering and balancing work. We'll have a network of computers set aside at our training centre for the purpose of setting up a test case, experimenting with configurations, seeing what happens when machines are switched on and off. Something you wouldn't dare so with your own production environment, and might be reluctant to do even on your development of test networks (that's even assuming that you do HAVE multiple machines at the development or test level).
(this article written on 2009-10-30)

Other articles ...

Linux and Shell Programming
[3256] Displaying a directory or file system tree - Linux
[2896] LAMP - Linux, Apache, MySQL, PHP - install, configure, administer
[2831] Recording (a macro) in vi
[2639] su or su - ... what is the difference?
[2638] Finding what has changed - Linux / Unix
Top or Show all for Linux and Shell Programming

Apache HTTP and Tomcat Servers
[3443] Getting more log information from the Apache http web server - (new - 2011-09-16)
[3339] Simplest ever proxy configuration?
[3019] Apache httpd Server Status - monitoring your server
[3018] Tuning Apache httpd and Tomcat to work well together
[3015] Logging the performance of the Apache httpd web server
Top or Show all for Apache HTTP and Tomcat Servers

C and C++ Programming
[3390] Printing objects in C++
[3388] Templates in C++ - defining a family pattern of methods / functions
[3386] Adding the pieces together to make a complete language - C
[3384] Loops - a comparison of goto, while and for
[3252] C++ - unknown array size, unknown object type. Help!
Top or Show all for C and C++ Programming

Melksham
[3503] Melksham House - a community facility - (new - 2011-10-31)
[3502] Sunday Evening ... newest and oldest Melksham pictures - (new - 2011-10-30)
[3500] Campus Shadow - a great responsibility - (new - 2011-10-30)
[3499] Images of Melksham - (new - 2011-10-29)
[3496] Melksham - Business to Business Speed Networking - build ahead for 2012 - (new - 2011-10-26)
[3495] Looking forward - Chamber of Commerce has 2012 and beyond on the agenda - (new - 2011-10-26)
[3492] Upcoming events in and about Melksham - more dates for your diary - (new - 2011-10-22)
[3481] Some thoughts in answer to some Melksham Campus questions - (new - 2011-10-14)
[3475] Havant - Shop Frontages. - (new - 2011-10-12)
[3470] Currently pictured in Melksham - (new - 2011-10-09)
[3438] Melksham to become a part of Trowbridge? - (new - 2011-09-13)
[3427] What is on the Melksham Agenda? - (new - 2011-09-09)
[3423] 1 + 1 + 1 + 1 = 12? - (new - 2011-09-07)
[3420] Making best use of the new enthusiasm for Melksham - (new - 2011-09-05)
Top or Show all for Melksham

Training from Well House Consultants
[3460] Flying Colours! - (new - 2011-09-28)
[3419] Data that we use during our training courses, and other training resources - (new - 2011-09-04)
[3401] Open Source Training Schedule - learn a programming language - in Autumn 2011 or 2012
[3391] For programmers who use Internet Explorer as their browser
[3387] Eating out in Melksham - where we like for lunch.
Top or Show all for Training from Well House Consultants

Running a training and hotel company
[3490] How not to call when job seeking ... - (new - 2011-10-20)
[3440] Research is exciting. But should routine be automated? - (new - 2011-09-14)
[3425] Our National Autograss Champion, from Melksham - (new - 2011-09-08)
[3368] Well House Manor hotel, Melksham - recommended to you by our customers
[3354] Sales and Marketing - adding advertising to the product
Top or Show all for Running a training and hotel company

Well House Manor - Hotel and Training Centre
[3437] Light bulbs - (new - 2011-09-13)
[3373] Another busy Week at Well House Manor ... pictures from the midweek
[3359] Cash and Cheque policy - UK Hotel
[3314] Garden Seating, Well House Manor
[3308] Behind the scenes - setting up a cafe
Top or Show all for Well House Manor - Hotel and Training Centre

For the Webmaster, Postmaster and moderator
[3491] Who is knocking at your web site door? Are you well set up to deal with allcomers? - (new - 2011-10-21)
[3480] Direct Message: Really horrible blog about you ... a clever phishing trip, said to be from an MP - (new - 2011-10-14)
[3457] Away to train - but still around by video for Melksham meetings - (new - 2011-09-25)
[3402] That spec is a kingfisher ...
[3367] Google +1 - what is it?
Top or Show all for For the Webmaster, Postmaster and moderator

General Programming Topics
[3461] From flowchart to program - code design for the newcomer - (new - 2011-09-29)
[3456] Stepping stones - early coding, and writing re-usable code quickly - (new - 2011-09-24)
[3454] Your PHP website - how to factor and refactor to reduce growing pains - (new - 2011-09-24)
[3451] Why would you want to use a Perl hash? - (new - 2011-09-20)
[3366] Specification, Design, Implementation, Testing and Documentation - stages of a (Java) programming project
Top or Show all for General Programming Topics

PHP - the language and its application
[3458] On this day ... one PHP script with three uses - (new - 2011-09-26)
[3453] Reading and using emails including enclosures on your web server. - (new - 2011-09-23)
[3379] Sorting data the way YOU want it sorted
[3210] Catchable fatal error in PHP ... How to catch, and alternative solutions such as JSON
[3197] Finding and diverting image requests from rogue domains
Top or Show all for PHP - the language and its application

Java and the Java Environment
[3497] Not the same language - but based on the same constructs - (new - 2011-10-27)
[3365] Turning bright delegates into bright and knowledgable ones
[3293] Distributing the server load - yet ensuring that each user return to the same system (Apache httpd and Tomcat)
[3048] String handling - from first steps to practical examples
[3047] What is a universal superclass? Java / Perl / Python / Other OO languages
Top or Show all for Java and the Java Environment

Around, about and nearby to Wiltshire
[3498] Which West Wilts Town? A picture quiz for you - (new - 2011-10-28)
[3382] What is the picture?
[3341] Farewell to the Hercules?
[3284] What to do in the evening during a Tcl course
[3267] Reybridge, Easter Monday
Top or Show all for Around, about and nearby to Wiltshire

The Perl Programming Language and its use
[3485] Perl - retrieving and caching web resources - (new - 2011-10-18)
[3449] Apache Internal Dummy Connection - what is it and what should I do with it? - (new - 2011-09-19)
[3446] Awk v Perl - (new - 2011-09-18)
[3445] Perl and CGI - simple form, and monitoring script. - (new - 2011-09-17)
[3444] Take the dog on a lead - do not carry her. Perl references. - (new - 2011-09-17)
[3412] Handling binary data in Perl is easy! - (new - 2011-08-30)
[3411] Single and double quotes strings in Perl - what is the difference? - (new - 2011-08-30)
Top or Show all for The Perl Programming Language and its use

Client Side Languages (HTML, CSS, Javascript)
[3133] An image from a website that occasionally comes out as hyroglyphics
[3128] How does your browser find out about itself?
[2913] Six languages in one file - an HTML++ web page
[2675] Redirecting to your main domain for correct security keys
[2628] An example of an injection attack using Javascript
Top or Show all for Client Side Languages (HTML, CSS, Javascript)

Ruby and Ruby on Rails
[3435] Sorta sorting a hash, and what if an exception is NOT thrown - Ruby - (new - 2011-09-12)
[3432] 3 digit HTTP status codes - what are they, which are most common, which should be a concern? - (new - 2011-09-11)
[3431] Ruby at both extremes of your website - (new - 2011-09-10)
[3430] Sigils - the characters on the start of variable names in Perl, Ruby and Fortran - (new - 2011-09-10)
[3428] How many days to Christmas? - (new - 2011-09-09)
[3426] Automed web site testing scripted in Ruby using watir-webdriver - (new - 2011-09-09)
[3424] Divide 10000 by 17. Do you get 588.235294117647, 588.24 or 588? - Ruby and PHP - (new - 2011-09-08)
[3422] Assigning values to variables within other statements - Ruby - (new - 2011-09-07)
[3421] Ruby off the Rails? - (new - 2011-09-06)
Top or Show all for Ruby and Ruby on Rails

SQL and MySQL
[3494] Databases - when to treat the rules as guidelines - (new - 2011-10-23)
[3455] MySQL, MySQLi, PDO or something else - how best to talk to databases from PHP - (new - 2011-09-24)
[3447] Needle in a haystack - finding the web server overload - (new - 2011-09-18)
[3361] Blowing our own trumpet - MySQL resources
[3270] SQL - Data v Metadata, and the various stages of data selection
Top or Show all for SQL and MySQL

Tcl, Tcl/Tk and Expect
[3448] Checking all the systems on a subnet, using Expect and Tk - (new - 2011-09-18)
[3429] Searching through all the files in or below a directory - Ruby, Tcl, Perl - (new - 2011-09-09)
[3418] Tcl packages, pkg_mkIndex, pkgIndex.tcl -what are they and why use them. - (new - 2011-09-03)
[3417] What is a namespace and why do we need them? - (new - 2011-09-03)
[3416] Storing Tcl source code encoded, and running via your own C program - (new - 2011-09-02)
[3415] User defined sorting and other uses of callbacks in Tcl and Tk - (new - 2011-09-02)
[3414] Passing back multiple results in Tcl - upvar and uplevel - (new - 2011-09-01)
Top or Show all for Tcl, Tcl/Tk and Expect

Programming in Lua
[3396] Tables as Objects in Lua - a gentle introduction to data driven programming
[3395] Parallel but not really parallel. Moving game characters. Coroutines in Lua.
[3142] Private and Public - and things between
[2951] Lots of way of converting 3 letter month abbreviations to numbers
[2949] Lua - variable function arguments and select
Top or Show all for Programming in Lua

Python Programming
[3489] Python courses and Private courses - gently updating our product to keep it ahead of the game - (new - 2011-10-20)
[3488] Python sets and frozensets - what are they? - (new - 2011-10-20)
[3479] Practical Extraction and Reporting - using Python and Extreme Programming - (new - 2011-10-14)
[3478] Testing your Python classes with the unittest package - how to - (new - 2011-10-14)
[3477] Choosing your Python GUI - wx, Qt, Tk or GTK? - (new - 2011-10-13)
[3476] Tkinter - an easy to use Python Graphic User Interface - introductory examples - (new - 2011-10-13)
[3474] Python Packages - groupings of modules. An introduction - (new - 2011-10-11)
[3472] Static variables in functions - and better ways using objects - (new - 2011-10-10)
[3469] Teaching dilemma - old tricks and techniques, or recent enhancements? - (new - 2011-10-08)
[3468] Python string formatting - the move from % to str.format - (new - 2011-10-08)
[3465] How can I do an FTP transfer in Python? - (new - 2011-10-05)
[3464] Passing optional and named parameters to python methods - (new - 2011-10-04)
[3459] Catching the fishes first? - (new - 2011-09-27)
[3442] A demonstration of how many Python facilities work together - (new - 2011-09-16)
[3441] Pressing ^C in a Python program. Also Progress Bar. - (new - 2011-09-15)
[3439] Python for loops - applying a temporary second name to the same object - (new - 2011-09-14)
[3436] Moving from scripting to Object Orientation in Python - (new - 2011-09-13)
[3433] Exceptions - a fail-safe way of trapping things that may go wrong - (new - 2011-09-11)
Top or Show all for Python Programming

And also ...
[3484] A Melksham Timeline - Domesday to present day - (new - 2011-10-17)
[3473] Picture - Havant Station at Dusk - (new - 2011-10-11)
[3467] Charities v Charitable. The cost of collecting your donation. - (new - 2011-10-06)
[3466] Passing of Steve Jobs - R.I.P. - (new - 2011-10-06)
[3463] Busy weekend of contrasts. - (new - 2011-10-03)
[3450] A threat in the post? Poor marketing practise from Smiletrain? - (new - 2011-09-19)
[3413] If its Sunday, must it be Weymouth? - (new - 2011-08-30)
Top or Show all for And also ...

Public Transport
[3501] Santa Claus - on the train from Melksham on 4th December 2011 - (new - 2011-10-30)
[3493] West Wilts Rail User Group - Walk yesterday from Bradford-on-Avon to Trowbridge - (new - 2011-10-23)
[3487] Public transport - road and rail - (new - 2011-10-19)
[3486] How important is public transport to people in the Melksham area? - (new - 2011-10-19)
[3483] Canals, watererways in the Melksham area - (new - 2011-10-16)
[3482] Taking a boat down Caen Hill Locks - (new - 2011-10-15)
[3471] Vintage Bus Running Day in Warminster. An example of good bus practise. - (new - 2011-10-09)
[3452] Which or ATOC - who reads train fares right? - (new - 2011-09-22)
[3434] Sundays - and over eating - (new - 2011-09-11)
[3410] A review of the Summer Sunday extra trains on the TransWilts line
[3408] Journey home by public transport for a Bank Holiday
[3404] Buses on the Cambridge Guided Busway
[3403] Last chance this summer - Swindon and North Wiltshire to Weymouth by through train
[3392] What costs 8.20 from Melksham, or 22.30 via Chippenham?
[3378] New product - ensuring that supply matches demand
[3376] Kennet and Avon - Walk from Bedwyn to Pewsey. TransWilts day out.
[3371] From Wiltshire to Weymouth on Sundays
[3370] Standing Challenge
[3364] Dogs Legs on the Dogleg
[3362] Swindon, Chippenham and Melksham to Weymouth - Sunday Train Service Starts
[3345] Cruising
[3336] Efficient travel - from Melsksham to Edinburgh by Sleeper Train
[3331] Comparing Alloa and Melksham - stations and services
[3328] Summer Sundays - days out by train from Swindon on the TransWilts
[3318] Summer Sunday Trains - outings from Swindon, Chippenham, Melksham, Trowbridge and Westbury
[3301] Using public transport - USA style
[3290] Changes (and no changes) at Melksham bus stops
[3282] The future of canal management and charities - Kennet and Avon Canal bias
[3274] Small scale improvement - big scale gain. And they CAN be done with local knowledge
[3273] Wanted - a look to the future
[3266] Easter on the Canal - near Melksham, Wiltshire
[3231] Footpath, Bridleway, Byway, Road used as Public Path
[3228] What can you take on a public footpath? Pram? Wheelbarrow? Dog? Shopping Trolley? Horse? Cycle?
[3216] Images of a Spring Walk
[3198] TransWilts rail - coming together, wanted and needed
[3187] Past and Present - Melksham Station
[3183] Redevelopment on the banks of the Avon in Melksham
[3178] The cost of roadworks on the economy of our town - 1800 pounds per hour?
[3176] Comparing German, Dutch and British Railways
[3171] Train and boat journey - the passenger accommodation
[3167] Can I take my dog by train? And other questions
[3161] TransWilts rail - what picture represents us
[3157] A new monopoly on the ferry to Northern Ireland
[3141] Wiltshire Rail services - a golden opportunity
[3135] A time to be brave? We should ask for what is best for our area.
[3126] Car Parking in Melksham - thoughts on the proposed scheme, and wider thoughts too
[3119] TransWilts - some things to see and do
[3114] Transwilts Link - both Wiltshire and beyond
[3113] Trowbridge and Melksham to Chippenham - more roadworks, even slower journey over the winter
[3111] TransWilts Link - Days out from Swindon to Weymouth?
[3080] Santa Special - rather more special than usual - December 2010
[3079] TransWilts Rail News ... Melksham (Santa Special) Edition ... 5th December 2010
[3033] Rail services back to Radstock?
[3031] Get all your ducks in a row ... and they may turn into swans
[3023] Autumn walk from Bowerhill
[3017] Seventh day traveller on the six day railway
[3006] Santa announcement, 5th December 2010, Melksham
[2983] Strong arm tactics in the bus industry? Poor result for the customer!
[2958] What do these road markings mean? Could Confusion Kill?
[2955] Melksham Railway Station - new information point
[2950] Camilla, Duchess of Cornwall, turns first sod in Melksham Link Canal
[2933] Bath - Melksham - Devizes buses from September
[2931] Syncronise - software, trains, and buses. Please!
[2930] Walk - Tilehurst to Pangborne
[2919] London to Calne, Corsham, Melksham, Bradford-on-Avon, Chippenham by public Transport
[2908] How Green is my train?
[2903] Bath to Devizes bus via Melksham - changing again in September
[2901] Ambassador or Anorak?
[2858] The healthy option - away from the private car
[2857] Park and Ride at Batheaston - will it solve Wiltshires Ills?
[2855] Train Services - Melksham to Bath and Bristol (and airport)
[2808] From home to Nurnberg - journey pictures
[2796] Sunday - waiting for the ferry.
[2791] Bath to Melksham buses - times
[2789] Melksham to London (Heathrow, and Central London)
[2771] Melksham to Calne by public transport
[2730] Bird Watching on the Melksham Avon
[2709] Old trackways and routes near Melksham
[2707] A walk on the Kennet and Avon
[2704] A walk within without - Melksham Without
[2696] Garlic bread without garlic
[2678] Reaching out to the community - a good case for support
[2672] Dear Planners, please provide viable alternatives
[2662] Is Melksham public transport actually used?
[2658] Save the Train - a significant change in approach
[2634] London to and from Melksham by public transport
[2627] Saturdays out from Melksham - to Oxford, to Didcot or to Swindon
[2588] Freddies Wood and the K and A Canal
[2568] Forums for your Melksham and open source discussions
[2557] Rail Campaign - response to core consultation
[2556] Railway Station Survey - please complete today or tomorrow
[2533] Five guests, three groups, one car
[2529] Santa Special, 2009
[2522] Integrated public Transport - what could be done for Melksham
[2515] Why we have two buses an hour - but not a half hourly service
[2513] Wiltshire Council purchases Melksham Station Land
[2511] The story of the railway land at Melksham Station
[2490] Friendly Hotel in Melksham, near Bath
[2486] Santa Special - Trowbridge and Melksham to Swindon
[2477] By train ...
[2473] Exploring Old Railways
[2457] Railway Arithmetic
[2431] Moving busstop!
[2395] From Lymington by train - last of the slammers
[2391] Great Western Route Utilisation Strategy - Draft for Consultation
[2372] Public Transport from (and to) Melksham on Sundays
[2328] Melksham - no trains, no southbound buses through the town
[2318] For Lua Programmers AND for Town Planners
[2268] Westbury Bypass Refused - looking forward
[2253] Walks in and around Melksham, Wiltshire
[2133] Bigger and better this year!
[2083] Do you support a decent train service? Please sign up!
[2075] Supporting Parkinsons and Trains
[2057] Train and Coach fares from London (and airports) to Melksham
[2042] Wiltshire Rail Service Update
[2026] Melksham Climate Friendly Group
[2024] Carry on Training - in spite of the weather
[1999] How low can you sink?
[1986] Walk to Bowerhill
[1965] How much does a train service actually cost
[1964] Why hasnt the fiasco been put right
[1905] A Gold Star for First Great Western Customer Service
[1858] Camera with night vision, youth with no vision
[1848] 30th November - Santa Trip from Melksham
[1802] Motorcycles welcome at Well House Manor
[1777] The Rise and Rise of First Bus Fares
[1757] Preserved railways - struggling to the future?
[1729] Back from the future
[1723] Bath - Melksham - Devizes. Bus route changes, new timetable
[1708] A Train Service Update for Melksham Party in the Park
[1668] Talk on TransWilts train service to Green Party
[1657] Farewell, Newcastle to Stavanger, Haugsund and Bergen
[1640] Walking on The Wiltshire Downs
[1616] Not daring to be an anorak
[1567] Melksham - Swindon. Train v Bus v Car
[1558] Getting somewhere with the train service
[1530] Railway Acronyms and Abbreviations
[1511] Buses from Well House Manor, Melksham, to Bath
[1452] Santa on the train to Melksham
[1428] Travel Across Wiltshire - the game
[1424] Closer than you think - the next step
[1382] First Great Western - information for customers
[1358] Look forward with a new broom - Wiltshire Train Service
[1315] Two years of campaigning for a train service
[1314] Business travel by train in the USA
[1291] Day trip to Weymouth
[1274] Radio coverage for railway issues
[1273] Melksham or Weymouth? Meal or day out?
[1254] Comparing bus stops
[1228] Some progress on the train campaign
[1139] Overcrowded trains around Bristol
[1125] Train service - petititon reply
[1097] Train and business balls all in the air!
[1093] Wiltshire Train - can YOU come on 5th March?
[1085] Lawrence Webb's Melksham Taxi service
[1076] Save the Train - an update
[1069] Rail trouble forced me to buy hotel
[1063] Bradford-on-Avon - 150 years of passenger trains
[1045] Bang! Train campaign hits home
[1044] Call for appropriate train services - Swindon, Bristol, Bath, West Wilts, Severn Beach etc
[1033] Empty at Easleigh, Missing at Melksham, Overflowing at Oldfield
[976] Santa at the station
[974] The last commuter train through Melksham
[952] Coming from London to Melksham by train for a course
[877] Yes, but what do we do now??
[818] Heard, yes. Considered, no. The case for the train.
[814] Melksham Railway Calendar 2007
[803] Not shouting
[793] The Wilts and Berks Canal
[790] Shadow Transport Minister to visit Melksham
[776] Naming Rooms
[764] Journey planning - Xephos v Transport Direct
[708] Linescapes of Mull
[697] For any North and West Wilts and Swindon Readers
[688] Are you free on Friday evening?
[648] West Wilts Railway Users Group and trains to Lacock
[634] Real chance to make a difference
[632] Moral dilemma
[598] Should we cruise around the world?
[527] Greater Western Franchise Awarded
[524] Santa comes to Melksham
[521] Proof needed? Please just use common sense!
[488] Looking for railway groups and users - Swindon, Salisbury, Southampton
[486] Rail services under threat - Swindon, Melksham ... and Newquay and Bicester too
[474] Vintage Bus Day
[459] Kiss and Ride
[447] Tomorrow's meeting.
[434] Through public transport connection, Chippenham to Salisbury, to cease
[428] Swindon - Chippenham - Melksham - Trowbridge - Westbury train service
[187] a popular bus number
[154] Railway train service, Melksham station
[119] PHP course. Come by train.
Top or Show all for Public Transport

Fun and Flames
[3462] Hangers, luggage and possessions - (new - 2011-10-01)
[3369] Local Council leads bans on many activities
[3302] Are you a half full or half empty person?
[3288] Random Questions ...
[3226] A busy morning for railway announcements
Top or Show all for Fun and Flames

Keynote Articles
[2483] Clustering on Tomcat
[2384] Looking ahead to the Autumn season of training and accommodation
[2144] Looking for a career change - Physician to Web Site Designer
[1955] How to avoid duplicating web page maintainance
[1857] November and December Public Course Schedule
Top or Show all for Keynote Articles

Unclassfied Articles
[3363] Should we take sponsored adverts on our site?
[3342] A Holiday
Top or Show all for unclassified

Public Transport Training from Well House Consultants And also ... Tcl, Tcl/Tk and Expect Programming in Lua Python Programming Well House Manor - Hotel and Training Centre Apache HTTP and Tomcat Servers The Perl Programming Language and its use Ruby and Ruby on Rails PHP - the language and its application C and C++ Programming Linux and Shell Programming Melksham SQL and MySQL For the Webmaster, Postmaster and moderator Java and the Java Environment Fun and Flames Running a training and hotel company Around, about and nearby to Wiltshire Client Side Languages (HTML, CSS, Javascript) Keynote Articles General Programming Topics

A little more about this newsletter ...

At Well House Consultants, we run niche IT training courses ... and we run a hotel for delegates on those courses and other visitors to Melksham too. And we make a lot of friends - have a lot of ambassadors with whom we want to keep in touch. So every day Graham (that's me, writing this piece) puts together an article or two which might include the latest sample programs that I've written during the current course, new information about Well House Manor - our business hotel, tips on search engine optimisation, announcements of upcoming public courses, pictures of local places, and even (on occasions) rants and whimsical pieces to keep those friends up to date and in touch. The feeds are available directlt via the Blog - "The Horse's Mouth", they're on our Twitter Feed and you can find me at my LinkedIn profile. But most people just want to look us up occasionally - every month or two, and then to catch up on the latest news just for their particular subjects of interest ... and that's what this newsletter is about

You'll find above the titles of ALL the new articles written in the last two months, listed by major subject area, and showing as (new) with their date of publication. You'll find additional articles in each category too - topping each category up to a minimum of five articles. And you'll find a link at the end of each section which lets you expand that section to show the titles of every article that's been published in that section. After all, "the old ones are often the best ones", aren't they?

go to Top or other editions September 2011July 2011May 2011March 2011January 2011November 2010September 2010July 2010May 2010 • or current edition


Training sample © 2025, WELL HOUSE CONSULTANTS LTD
This is http://www.wellho.net/demo/newsletter.php
Well House Manor • 48 Spa Road • Melksham, Wiltshire • United Kingdom • SN12 7NY
Phone: +44 (0) 1225 708 225 • EMAIL: info@wellho.net • WEB: http://www.wellho.net