The Well House Newsletter - Saturday, 1st May 2010
About us and this newsletter [link] ...
Previous editions: March 2010January 2010November 2009September 2009July 2009May 2009March 2009January 2009November 2008 • 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 ...

Apache HTTP and Tomcat Servers
[2728] Redirecting a home page using mod_rewrite - (new - 2010-04-17)
[2596] Http protocol - what does a web server send
[2552] Web site traffic - real users, or just noise?
[2482] Load balancing with sticky sessions (httpd / Tomcat)
[2355] See this page in French
Top or Show all for Apache HTTP and Tomcat Servers

C and C++ Programming
[2674] Make and makefiles - a commented example to help you learn - (new - 2010-03-12)
[2673] Multiple Inheritance in C++ - a complete example - (new - 2010-03-12)
[2670] Pointers to Pointers to Pointers - what is the point? - (new - 2010-03-10)
[2669] Efficient use of dynamic memory - C and realloc - (new - 2010-03-10)
[2579] Creating, setting up and using objects in C++
Top or Show all for C and C++ Programming

Melksham
[2739] Melksham Scouts - (new - 2010-04-25)
[2725] How do our tactics help us meet the strategy, for the greater good? - (new - 2010-04-16)
[2716] Melksham in Pictures - (new - 2010-04-10)
[2708] The bull on the footpath - (new - 2010-04-04)
[2691] New brochures for the Melksham area - (new - 2010-03-24)
[2683] Car Parking in Melksham - (new - 2010-03-18)
[2666] Random thoughts on Melksham Town Planning and development - (new - 2010-03-08)
[2665] Early Spring walk in Melksham - (new - 2010-03-07)
[2664] Oliver Cromwell at Bristol Temple Meads - (new - 2010-03-06)
Top or Show all for Melksham

Training from Well House Consultants
[2732] Asking about Jesus - (new - 2010-04-20)
[2731] Training Courses - time of change - (new - 2010-04-19)
[2726] Every cloud has a silver lining - (new - 2010-04-16)
[2661] Current Public Courses - (new - 2010-03-05)
[2637] Courses - Melksham and elsewhere - until the end of April
Top or Show all for Training from Well House Consultants

Running a training and hotel company
[2724] Escapee Grandparents welcome - Henfield and Melksham - (new - 2010-04-15)
[2650] Getting a phone line changed ...
[2598] An excuse for making a sales call
[2593] Food and drink launch
[2530] Taking a knock over Santa
Top or Show all for Running a training and hotel company

Well House Manor - Hotel and Training Centre
[2705] Hotel booking in Melksham made easy! - (new - 2010-04-03)
[2663] Improve your PHP on a weekend away - (new - 2010-03-05)
[2660] One number for Well House - 01225 708225 - (new - 2010-03-04)
[2659] New numbers, as 01225 707126 and 01225 709638 are being retired - (new - 2010-03-04)
[2590] A healthy, local breakfast in Melksham
Top or Show all for Well House Manor - Hotel and Training Centre

For the Webmaster, Postmaster and moderator
[2743] Public Open Source Training Courses running this summer and autumn in Melksham - (new - 2010-04-27)
[2697] Email metrics and filtering - (new - 2010-03-28)
[2690] The World Company Register - is it another scam? - (new - 2010-03-23)
[2686] Freedom of Information - consideration for web site designers - (new - 2010-03-20)
[2668] Is it worth it? - (new - 2010-03-09)
Top or Show all for For the Webmaster, Postmaster and moderator

General Programming Topics
[2747] Containment, Associative Objects, Inheritance, packages and modules - (new - 2010-04-30)
[2741] What is a factory? - (new - 2010-04-26)
[2737] Improving your function calls (APIs) - General and PHP - (new - 2010-04-24)
[2715] Uploading an image, document or pdf via a browser (php) - (new - 2010-04-10)
[2700] The same very simple program in many different programming languages - (new - 2010-03-31)
Top or Show all for General Programming Topics

PHP - the language and its application
[2742] A simple server benchmark script - (new - 2010-04-27)
[2738] What is all this SESSION stuff about? (PHP) - (new - 2010-04-25)
[2729] Uploading a document or image to its own URL via a browser - (new - 2010-04-18)
[2684] Exception handling in PHP - (new - 2010-03-18)
[2682] Adding extensions to PHP Open Source applications - callbacks - (new - 2010-03-17)
[2680] Static class members in PHP - a documented example - (new - 2010-03-16)
[2679] How to build a test harness into your PHP - (new - 2010-03-16)
[2667] Web page to telephone calls / links using an iPhone - (new - 2010-03-08)
Top or Show all for PHP - the language and its application

Java and the Java Environment
[2735] Type checking, Java arrays and collections - (new - 2010-04-23)
[2734] for and foreach in Java - (new - 2010-04-22)
[2654] Java - from applets to servlets. JSPs and more - (new - 2010-02-27)
[2653] Java Server Pages - putting it all together
[2652] Reading and writing cookies in Java Servlets and JSPs
Top or Show all for Java and the Java Environment

Around, about and nearby to Wiltshire
[2713] History is all around us - (new - 2010-04-09)
[2687] A lovely spring afternoon - (new - 2010-03-21)
[2685] Stairs - (new - 2010-03-19)
[2453] Dark to dark
[2443] Contrasting Cambridge, Bristol and Wiltshire
Top or Show all for Around, about and nearby to Wiltshire

The Perl Programming Language and its use
[2736] Perl Course FAQ - (new - 2010-04-23)
[2688] Security considerations in programming - what do we teach? - (new - 2010-03-22)
[2657] Want to do a big batch edit? Nothing beats Perl! - (new - 2010-03-01)
[2551] Perl and the Common Gateway Interface - out of fashion but still very useful?
[2532] Analysing Google arrivals by country of origin
Top or Show all for The Perl Programming Language and its use

Client Side Languages (HTML, CSS, Javascript)
[2675] Redirecting to your main domain for correct security keys - (new - 2010-03-13)
[2628] An example of an injection attack using Javascript
[2554] Adding retrospective ALT attributes to IMG
[2390] Dynamic / changing images on your web page
[2223] CSS Style Diagrams - working out where attributes come from
Top or Show all for Client Side Languages (HTML, CSS, Javascript)

Ruby and Ruby on Rails
[2714] A simple example - XML from a Ruby program - (new - 2010-04-10)
[2711] For loop - checked once, or evety time? Ruby v Perl comparison and contrast - (new - 2010-04-07)
[2651] Calculation within objects - early, last minute, or cached?
[2623] Object Oriented Ruby - new examples
[2621] Ruby collections and strings - some new examples
Top or Show all for Ruby and Ruby on Rails

SQL and MySQL
[2647] Removing duplicates from a MySQL table
[2645] Optimising and caching your MySQL enquiries
[2644] Counting rows in joined MySQL tables
[2643] Relating tables with joins in MySQL
[2567] Extra MySQL course dates (2 day course, UK)
Top or Show all for SQL and MySQL

Tcl, Tcl/Tk and Expect
[2681] Tcl - a great engineering language - (new - 2010-03-17)
[2476] Tcl - uplevel to run code at calling level
[2475] Quick easy and dangerous - automated logins via Tcl / Expect
[2474] Using Tcl and Expect to automate repetitive jobs
[2472] split and join in tcl and expect
Top or Show all for Tcl, Tcl/Tk and Expect

Programming in Lua
[2727] Making a Lua program run more than 10 times faster - (new - 2010-04-16)
[2723] Returning multiple values from a function - Lua - (new - 2010-04-15)
[2710] __index and __newindex in Lua - metatable methods - (new - 2010-04-05)
[2706] Error trapping in Lua - no exceptions. - (new - 2010-04-04)
[2703] Lua Metatables - (new - 2010-04-02)
[2702] First and last match with Regular Expressions - (new - 2010-04-02)
[2701] Is Lua an Object Oriented language? - (new - 2010-04-01)
[2699] Lua tables - they are everything - (new - 2010-03-30)
Top or Show all for Programming in Lua

Python Programming
[2746] Model - View - Controller demo, Sqlite - Python 3 - Qt4 - (new - 2010-04-29)
[2745] Connecting Python to sqlite and MySQL databases - (new - 2010-04-28)
[2744] PyQt (Python and Qt) and wxPython - GUI comparison - (new - 2010-04-28)
[2722] Mixins example in Python - (new - 2010-04-14)
[2721] Regular Expressions in Python - (new - 2010-04-14)
[2720] Multiple inheritance in Python - complete working example - (new - 2010-04-14)
[2719] Traffic lights in Python - (new - 2010-04-13)
[2718] Python - access to variables in the outer scope - (new - 2010-04-12)
[2717] The Multiple Inheritance Conundrum, interfaces and mixins - (new - 2010-04-11)
[2695] TCP v UDP / Client v Server - Python examples - (new - 2010-03-25)
[2694] Multiple processes (forking) in Python - (new - 2010-03-25)
[2693] Methods that run on classes (static methods) in Python - (new - 2010-03-25)
[2692] Flexible search and replace in Python - (new - 2010-03-25)
[2655] Python - what is going on around me? - (new - 2010-02-28)
Top or Show all for Python Programming

And also ...
[2740] Melksham Hustings at George Ward School - (new - 2010-04-26)
[2733] Travel Troubles and Jesus again - (new - 2010-04-21)
[2712] A more informed decision than ever before - (new - 2010-04-08)
[2698] Ruth Davis, 1916 - 2010 - (new - 2010-03-28)
[2689] Can my dog eat potatoes? Doggie Dietary Research, and political sleaze! - (new - 2010-03-23)
[2677] Blowing out the winter cobwebs - (new - 2010-03-14)
[2671] Melksham - Carnival, Party in the Park, and Spot the Oddity - (new - 2010-03-11)
[2656] Melksham Carnival - (new - 2010-02-28)
[2624] Skyline and looking up in London
[2611] Sunday Evening, City of London
[2602] East of Melksham - Building Work Starts
[2587] Bowerhill as a cycling community
[2582] Starting to arrange the picture library
[2580] C course inspires new teaching examples
[2555] Bookkeeping
[2553] On a short walk from home
[2549] Christmas Day ...
[2547] The great thing about snow ....
[2543] Day and night at Christmas
[2528] Melksham Christmas Lights
[2518] Through the arches
[2503] Melksham manslaughter case concludes - sort of
[2499] ourdog is Greyhound, Staffie and Ginger Cake
[2498] Remembrance Sunday 2009, Melksham
[2469] Beyond the Pale
[2464] Beauty in pictures
[2460] Mothers Day or Mothering Sunday?
[2456] Bright Eyes
[2451] Gypsy says
[2450] Family Gathering at 404, The Spa
[2412] Autumn Fruits and Bristol Old Station
[2411] Further North - long summer days and lovely countryside
[2404] Low Sun - Autumn is here
[2401] Back Tomorrow
[2392] Lymington, New Forest - some pictures
[2387] to Clifton Down and Avonmouth
[2371] Quiet summer days? I think not!
[2353] All change - Wiltshire Parliamentary
[2316] Guadalajara - a special tour of a lovely city
[2313] Seeing Guadalajara - a first glimpse downtown
[2306] Melksham to Mexico for the week
[2298] Melksham Carnival Parade - the people
[2297] Standing on the corner, Melksham Carnival
[2295] The dog is not in trouble
[2279] Understanding the new local government structure in Wiltshire
[2270] Wiltshire - a chance to improve life for everybody
[2269] Sipping at York
[2266] Travelling
[2265] A chance to do the tourist thing
[2264] Learning about others private lives
[2257] Ramblings on church and state linkage in Melksham
[2252] Leaping dog, Leaping horse, copyright of old masters
[2217] Enjoying the summer weather
[2208] A beautiful coastline
[2207] North Antrim Coast - a jewel thats well worth a visit
[2206] Spot the odd one out
[2205] An evening walk in Carrickfergus
[2202] Bright Colours
[2200] England, Scotland, Northern Ireland
[2198] On the road, at a Service area thats a cut above the others
[2195] A two day gap - first time in five years?
[2178] Melksham Candidates for Wiltshire Unitary Election
[2168] In honour of the photograph, I present ... a walk from Reybridge to Lacock
[2167] Watching the tele
[2164] Updating my public profile - Graham Ellis
[2159] A long day to guess where
[2146] An evening excursion to Devizes and Avebury
[2141] Town Crier competiton
[2140] Beware - giving copyright away when you upload a picture - Dogs Trust
[2132] Learning about Lurchers
[2121] Out in the Vale of Pewsey
[2118] Spring Sprung
[2113] Answering a question with a question
[2112] Whatever next ... the joys of being an employer
[2106] Learning to Twitter / what is Twitter?
[2105] Hire Car, from Atlanta Airport
[2101] A B C D of GA and TN
[2100] Visiting Family
[2098] A room without a view
[2093] Leading Lines
[2090] Melksham to Georgia
[2078] A lot has changed - but the memory lingers on
[2068] Playing Catchup
[2064] East of Melksham Countryside
[2037] The Interview and The Lift
[2034] Through Snow and Flood to Linux and Tomcat
[2030] The final step to being British
[2029] Also for the eyes of the cat
[2027] Who sticks by you in the snow?
[2008] The Month Ahead - What is happening in Melksham
[2006] Contrast
[2000] 2000th article - Remember the background and basics
[1992] A good time to travel
[1981] Bitter cold
[1960] Christmas Survivors
[1959] -
[1953] End of Training, 2008
[1942] Christmas scenes and events
[1931] Frosty Morning, foggy evening
[1919] Transition
[1916] Why I remember East Grafton
[1914] It must be nearly Christmas
[1882] Wiltshire Council says - part 2
[1872] Barack Obama wins US Predidency
[1868] Liverpool - a friendly city
[1854] Three Seasonal Pictures
[1838] Oxford in Pictures
[1837] Alfred the Great
[1818] Icelandic Badge
[1810] Middle aged subsidise young and old
[1807] A sad town in the sunlight
[1804] Colvin and Carlisle
[1776] Does fruit and veg drag on?
[1775] Easterholic
[1770] 3 hours from Milton Keynes
[1769] July child ponders on August children
[1755] Istanbul
[1746] London for the visitor, for free
[1740] Vertical London
[1730] Punting on the Cam
[1715] Pictures from South Hampshire
[1714] Hillier Gardens, Hampshire
[1652] Old Sarum airfield brings back fond memories
[1643] A lack of technical content
[1639] Minehead Marauder
[1638] Pictures far apart
[1631] Looking back through some photos
[1627] Amazing family members
[1624] From Freddie the fallow
[1620] Norwich and London
[1617] Steam Engines at Bressingham
[1591] Easter Sunday at 404, The Spa
[1590] All Change, Portsmouth Harbour
[1579] Rome, and the faith of Rome
[1573] Budget tax increases hit vehicle market
[1570] London Midland ... Merrymaker ... Percy Danks
[1546] The geometry of East London
[1540] Chinese New Year
[1537] To Wales - where theres still a toll on the bridge
[1536] A Weekend in Liverpool
[1526] Carers at work - court case changes
[1524] Nottingham - just text!
[1522] Paging Martin Noke, who petitions for more trains from Trowbridge to Swindon
[1489] Pictures of December
[1484] A christmas message
[1483] What have hotels and bananas got in common?
[1481] The Christmas Letter
[1462] 10 training days to Christmas.
[1460] Christmas fare in Ljubljana
[1457] A day in Ljubljana
[1456] Right up to the top of the City
[1454] From Sunday to Monday, from Melksham to the Balkans
[1425] Melksham v Ely
[1400] Dark Dawn
[1398] Someone else's wedding
[1392] Autumnal lighting on a London trip
[1386] New software product for warmblooded programmers
[1385] Delegates of all shapes and sizes
[1309] Dates for Easter - 2008 to 2015
[1308] Good to be home
[1307] Troy, up state New York
[1303] Heading Upstate New York
[1299] In the USA for a few days
[1298] From Leeds
[1293] Weymouth - Sunny Summer Sunday afternoon
[1279] The Gdansk fireball
[1275] Incident in Melksham
[1272] Behind closed doors?
[1269] Party in the Park - review
[1260] An inspirational business talk from one of our prospective MPs
[1247] An afternoon at a public enquiry
[1244] FolksFest Bristol - German beer, Bratwurst and music
[1238] The kind spirit of Melksham
[1234] A review of a week and a trip to Brugge
[1233] Horses of Brugge
[1231] Sur le Continent
[1229] Where am I?
[1216] Five of the best - pictures from London
[1214] New Serieses for the summer on TV
[1209] Where did the Bank Holiday go?
[1204] Spot the difference
[1197] Back off home with our best wishes
[1189] Meet, greet and welcome
[1178] Ducking stool for Melksham?
[1175] Local elections - choosing who to vote for
[1172] May day 2007 in pictures
[1162] Cheddleton, Staffordshire
[1152] Course, right place, right time
[1151] Gordon Dodge, R.I.P.
[1150] Helsinki - what comes naturally
[1147] A picture (mostly in words) of Helsinki
[1143] A course in Helsinki
[1138] The Holiday - unlikely romantic comedy?
[1135] Government pressure on me to shut up after I make the papers
[1120] 1200 miles in 3 days
[1119] The Last Word on the road
[1109] False imprisonment - a contrast from the news
[1107] Weekend Visitors
[1100] Wondering where I have been
[1099] Passenger flows
[1065] Graham Ellis - an Introduction
[1064] Light and shadows at Beach
[1061] Take vehicles off the road - put all the passengers into one
[1060] What a relief from the tax office.
[1057] Selling by phone and Skype - our policy
[1056] Another frantic posting!
[1051] Too busy to blog it - but it's great (mostly)
[1032] Chronic fatigue help - a new discussion forum
[1025] Tomorrow's keywords - London, Training, Course, PHP, Ruby.
[1014] Christmas Season Piccies
[1005] Stirling at night
[1004] Old dog, old tricks
[1003] Room at the Inn, Guy at the station
[992] Enthusiastic, but ....
[980] Street Scene
[978] Wellhouse Manor, Hotel, Melksham
[967] Realistic on line shoot'em up
[958] Plain Ole nice pictures
[953] Christmas in November
[921] French Exchange
[911] Letter Home
[908] And so to Inverness
[905] Not proud to be British
[897] Too much for the National Trust
[886] Signs of Leek
[882] Rocks, hard places, trains and funerals.
[878] Easy criteria to meet
[875] Wilfred Emmanuel-Jones
[870] Autumn comes to Wiltshire.
[843] To join an organisation?
[820] Robert and William Whitworth
[817] Working on Weekend in Wiltshire and others
[810] A bad place for security firms
[794] Perl delegate - much more than just a delegate
[786] First Light, Bootle Docks, Liverpool
[780] Separation and Integration
[778] Weekend in Ireland
[777] On Crosby sands
[772] Training in Liverpool
[771] From cat breeder to Cobol to Perl
[763] Much more that the world cup
[752] Over zealous police activity?
[750] Almost everyone loses
[744] We can offer a room, but we can't operate on a dog
[740] Finishing up in Dhahran
[730] Reading the newspaper and working with other restrictions
[727] A journey, an arrival, a people
[724] Helping mental health through diet, exercise and other lifestyle matters
[713] Pictures from my travels
[706] May day away
[704] Erin Brent - rest in peace
[700] As I walked in to Oxford
[698] Catch up weekend
[696] Is than an uphill or downhill task?
[692] Healthier eating
[685] A couple of days away
[684] Staying in the country
[682] Iran has enriched uranium ...
[678] Why are maps rarely to scale?
[674] Wiltshire to get an extra MP
[671] Both ends of the animal
[670] Architectural Heritage - Devizes
[655] Can some food be TOO different?
[654] Making use of disabled facilities
[650] A person of few words
[645] Lost Camel
[637] Carnival
[635] Odd one out.
[625] February pictures
[623] Behind every face is a person and a story
[620] Familiar names, close to home
[614] News in Ireland
[613] Greetings from Dublin
[612] Coming or going?
[611] Look out for the motor cyclist
[607] On being British
[605] Design your day with a walk
[602] MP face to face
[601] A fond memory of Sir Freddie
[584] Loosing breath with Gerald
[580] What to do with milk
[573] Giving an excuse for Christmas
[557] A new sign
[548] San Francisco
[543] The world didn't stop for Christmas
[541] Christmas is for everyone
[540] Christmas Party
[539] rich and famous
[530] Perl course during the week, getting married at the weekend
[518] Passport office - a much improved system
[516] Open source questions? Anyone can ask.
[505] Would you steal ... petrol? ... a training course?
[473] Looking different in town
[469] Yesterday was Kiss and Ride
[455] A Stengthening day
[446] Up early
[429] Charlie on Monday
[423] A Victorian Lady
[420] Towards Tebay
[416] Mixing up swallows and martins
[415] Campaign Drift and efficiency.
[412] Bristol Balloon Festival
[403] Full circle - made it back to an old haunt
[392] No Smoking
[388] BBQ Season
[384] Managing conflict and disappointment
[377] A Strengthened City
[374] Instant availability
[373] Vik, Iceland to Melksham, England
[370] From Iceland
[368] Vacation Week
[365] Letterbox Pictures
[363] Greetings from Edinburgh
[360] Spring turns to Summer
[335] Sad priorities
[330] An O level comes in handy
[326] UK Tax payment totals and where the money is spent
[313] Making bona fide international marriages more difficult
[301] General Election day, UK
[298] Sharing pictures of Wiltshire
[289] MP for Devizes, Wiltshire
[283] Natural or man-made?
[280] Spotted - the local MP
[275] See 8 but buy 6. See 6 but you can buy 8.
[271] Different course every day
[258] Easter at Well House Consultants
[257] Politics gets nasty. Must be an election coming up.
[238] Difficulties with a trolley
[232] Diverse activities
[228] Beard Justification
[218] Golden Nugget
[216] Cheap purchase - votes paid for with selfish promises
[214] Futility of war?
[207] Canteen Dragon
[206] Fox and Python
[186] Lull
[178] Calling a spade a spade
[169] A pleasure to train
[162] A Change is as good as a rest
[161] Christmas break
[149] Fish stocks
[147] Recent technical articles
[131] Thanksgiving dinner
[110] Friday, busy week!
[106] Far from the sea, but close to the heart
[102] The Romans got it right
[100] Life is frail
[97] What makes a professional photographer?
[96] Variable Scope
[92] Hard work, Hard sell
[81] Caf[83][c2]á keyboards
[70] Red Luas - early life and times
[66] A Taste of Ireland
[65] Ireland
[62] Technical Open House
[60] Birth Notice
[35] Autumn arrives right on time
[33] 10 Years of experience
[30] Bank Holiday
[26] Matching Cat
[21] two plus two equals seven
[20] Not two the same
[19] interesting products and subjects
[14] London - Most expensive city??
[8] How much does fuel cost for an airline flight?
Top or Show all for And also ...

Public Transport
[2730] Bird Watching on the Melksham Avon - (new - 2010-04-18)
[2709] Old trackways and routes near Melksham - (new - 2010-04-05)
[2707] A walk on the Kennet and Avon - (new - 2010-04-04)
[2704] A walk within without - Melksham Without - (new - 2010-04-02)
[2696] Garlic bread without garlic - (new - 2010-03-27)
[2678] Reaching out to the community - a good case for support - (new - 2010-03-15)
[2672] Dear Planners, please provide viable alternatives - (new - 2010-03-11)
[2662] Is Melksham public transport actually used? - (new - 2010-03-05)
[2658] Save the Train - a significant change in approach - (new - 2010-03-03)
Top or Show all for Public Transport

Fun and Flames
[2676] Changing Times - (new - 2010-03-13)
[2626] On Malachite Green
[2625] Both feet on the same pavement
[2542] My armpit was like a zebra crossing
[2496] A better design of mouth
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

Linux and Shell Programming
[2639] su or su - ... what is the difference?
[2638] Finding what has changed - Linux / Unix
[2636] Linux - useful tips including history and file name completion
[2599] Telling Apache web servers apart / notes for the non-technical
[2595] Twelve skills / knowledges needed for the design of a web site
Top or Show all for Linux and Shell Programming

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 March 2010January 2010November 2009September 2009July 2009May 2009March 2009January 2009November 2008 • 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