The Well House Newsletter - Sunday, 1st November 2009
About us and this newsletter [link] ...
Previous editions: September 2009July 2009May 2009March 2009January 2009November 2008September 2008July 2008May 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
[2482] Load balancing with sticky sessions (httpd / Tomcat) - (new - 2009-10-29)
[2355] See this page in French
[2325] Apache, Tomcat, mod_proxy
[2273] Three recent questions on Tomcat Convertors
[2272] Monitoring and loading tools for testing Apache Tomcat
Top or Show all for Apache HTTP and Tomcat Servers

C and C++ Programming
[2086] C Programming v Learning to Program in C. Which course?
[2005] Variables and pointers and references - C and C++
[2004] Variable Scope in C++
[2002] New C Examples - pointers, realloc, structs and more
[1675] Comparing Objects in C++
Top or Show all for C and C++ Programming

Melksham
[2480] Pantomimes around Melksham - 2009/2010 season - (new - 2009-10-28)
[2465] Melksham Town - asleep or awake? - (new - 2009-10-21)
[2459] New Web Site for Melksham Chamber of Commerce - (new - 2009-10-18)
[2438] Listening to The Minister - (new - 2009-10-05)
[2437] Wiltshire Unitary News - Chamber of Commerce Intelligence - (new - 2009-10-04)
Top or Show all for Melksham

Training from Well House Consultants
[2366] At the end of the course
[2354] Training, Open Source computer languages
[2350] Ten years in Melksham - looking forward to ten more.
[2342] Training Classes in other tongues
[2278] First courses for 2010
Top or Show all for Training from Well House Consultants

Running a training and hotel company
[2441] Not your cup of tea? - (new - 2009-10-08)
[2413] Sanity checking the price, and selling up to increase income - (new - 2009-09-21)
[2396] Easing off in our 50s? - (new - 2009-09-06)
[2388] `Of Course` is back! - (new - 2009-08-31)
[2311] Floor to ceiling
Top or Show all for Running a training and hotel company

Well House Manor - Hotel and Training Centre
[2436] Melksham Hotel Rooms - pictures - (new - 2009-10-04)
[2425] Weekend and Christmas Promotion - Well House Manor Hotel, Melksham - (new - 2009-09-26)
[2424] A Winter Weekend Special at Well House Manor - (new - 2009-09-26)
[2403] Hotel Booking Scam / Cost of calls to 070 numbers - (new - 2009-09-12)
[2377] Wiltshire / Melksham Weddings - guest accommodation
Top or Show all for Well House Manor - Hotel and Training Centre

For the Webmaster, Postmaster and moderator
[2470] Windows 7 and Open Source Programming - (new - 2009-10-22)
[2449] Four aspects - Chamber, Transport, Courses and Hotel - (new - 2009-10-11)
[2428] Diluting History - (new - 2009-09-27)
[2410] Removal of technical resources from this site - (new - 2009-09-19)
[2398] Websitemediasolution and a goldfish called Carl Johnson - (new - 2009-09-06)
[2389] Writing with our customers words - (new - 2009-09-01)
Top or Show all for For the Webmaster, Postmaster and moderator

General Programming Topics
[2415] Variable names like i and j - why? - (new - 2009-09-22)
[2393] A first demonstration of OO, including polymorphism - (new - 2009-09-04)
[2380] Object Oriented programming - a practical design example
[2364] Getting it right from the start - new programmers
[2327] Planning!
Top or Show all for General Programming Topics

PHP - the language and its application
[2478] How did I do THAT? - (new - 2009-10-26)
[2433] Controlling, supressing, enabling PHP error messages - (new - 2009-10-02)
[2432] Using print_r in PHP to explore mysql database requests - (new - 2009-10-01)
[2430] Not just a PHP program - a good web application - (new - 2009-09-29)
[2400] Are you wanting to learn PHP? - (new - 2009-09-08)
Top or Show all for PHP - the language and its application

Java and the Java Environment
[2434] Abstract classes, Interfaces, PHP and Java - (new - 2009-10-03)
[2423] What is a JVM, a JRE, a JDK - components of the core Java Environment - (new - 2009-09-26)
[2422] Looking inside Java classes - javap and javadoc - (new - 2009-09-25)
[2421] Sorting Collections of Objects in Java - (new - 2009-09-25)
[2420] Exceptions in Java - why and how - (new - 2009-09-24)
[2419] Where is my Java class? - (new - 2009-09-24)
[2418] Viv.java uses unchecked or unsafe operations - explanation and cure - (new - 2009-09-24)
[2417] Java Programming Fundamentals - (new - 2009-09-24)
[2414] Hello World - a good traditional start to a Java course - (new - 2009-09-22)
Top or Show all for Java and the Java Environment

Around, about and nearby to Wiltshire
[2453] Dark to dark - (new - 2009-10-13)
[2443] Contrasting Cambridge, Bristol and Wiltshire - (new - 2009-10-08)
[2362] Thornham Farm Shop, Seend Cleeve, nr Melksham
[2305] Hot Tap at West Wilts Show
[2302] See us at the West Wilts Show
Top or Show all for Around, about and nearby to Wiltshire

The Perl Programming Language and its use
[2484] Finding text and what surrounds it - contextual grep - (new - 2009-10-30)
[2427] Operator overloading - redefining addition and other Perl tricks - (new - 2009-09-27)
[2416] Automating access to a page obscured behind a holding page - (new - 2009-09-23)
[2405] But I am reading from a file - no need to prompt (Perl) - (new - 2009-09-14)
[2402] Automated Browsing in Perl - (new - 2009-09-11)
[2399] Firefighting with Perl - (new - 2009-09-07)
[2382] Giving up on user input - keyboard timeout in Perl
[2379] Making variables persistant, pretending a database is a variable and other Perl tricks
[2376] Long job - progress bar techniques (Perl)
[2375] Designing your data structures for a robust Perl application
[2374] Lead characters on Perl variable names
[2321] Uploading and Downloading files - changing names (Perl and PHP)
[2243] Changing a variable behaviour in Perl - tieing
[2242] So what is this thing called Perl that I keep harping on about?
[2241] Perl references - $$var and \$var notations
[2235] Sending awkward characters by email in Perl
[2234] Loading external code into Perl from a nonstandard directory
[2233] Transforming data in Perl using lists of lists and hashes of hashes
[2232] Why sendmail one way, and pop3 the other?
[2231] What is CGI.pm / A dozen new examples
[2230] Running a piece of code is like drinking a pint of beer
[2229] Do not re-invent the wheel - use a Perl module
[2226] Revision / Summary of lists - Perl
[2219] Configuring httpd, or Tomcat, to run CGI scripts in Perl
[2213] Keyboard reading in Perl - character by character not line by line
[2129] Nothing beats Perl to solve a data manipulation requirement quickly
[2070] Converting to Perl - the sort of programs you will write
[2069] Efficient calls to subs in Perl - avoid duplication, gain speed
[2067] Perl - lists do so much more than arrays
[2047] Small Web Server in Perl
[2045] Does robots.txt actually work?
[1951] Whisky - Setting and reading cookies from Perl
[1947] Perl substitute - the e modifier
[1946] Variable Types in Perl
[1924] Preventing ^C stopping / killing a program - Perl
[1922] Flurinci knows Raby Lae PHP and Jeve
[1921] Romeo and Julie
[1920] Progress Bar Techniques - Perl
[1918] Perl Socket Programming Examples
[1917] Out of memory during array extend - Perl
[1897] Keeping on an even keel
[1865] Debugging and Data::Dumper in Perl
[1863] About dieing and exiting in Perl
[1861] Reactive (dynamic) formatting in Perl
[1856] A few of my favourite things
[1852] Perl and Blackberries
[1832] Processing all files in a directory - Perl
[1829] Dont bother to write a Perl program
[1828] Perl - map to process every member of a list (array)
[1826] Perl - Subs, Chop v Chomp, => v ,
[1825] Question Mark - Colon operator (Perl and PHP)
[1753] Perl v PHP, choosing the right language
[1750] Glorious (?) 12th August - what a Pe(a)rl!
[1728] A short Perl example
[1727] Equality and looks like tests - Perl
[1726] Hot Courses - Perl
[1721] Perl 6 - When will we have a production release?
[1717] Q - Should I use Perl or Python?
[1709] There is more that one way - Perl
[1705] Environment variables in Perl / use Env
[1704] Finding operating system settings in Perl
[1703] Perl ... adding to a list - end, middle, start
[1702] Running operating system commands in Perl
[1665] Factory method example - Perl
[1664] Example of OO in Perl
[1581] What is an lvalue? (Perl, C)
[1514] Autovivification - the magic appearance of variables in Perl
[1510] Handling Binary data (.gif file example) in Perl
[1509] Extracting information from a file of records
[1508] How not to write Perl?
[1468] Lexical v Arithemetic testing, Bash and Perl
[1444] Using English can slow you right down!
[1416] Good, steady, simple example - Perl file handling
[1397] Perl - progress bar, supressing ^C and coping with huge data flows
[1395] Dont just convert to Perl - re-engineer!
[1320] Perl for Larger Projects - Object Oriented Perl
[1316] Filtering and altering Perl lists with grep and map
[1312] Some one line Perl tips and techniques
[1289] Pure Perl
[1251] Substitute operator / modifiers in Perl
[1232] Bathtub example
[1225] Perl - functions for directory handling
[1222] Perl, the substitute operator s
[1221] Bathtubs and pecking birds
[1219] Judging the quality of contributed Perl code
[1215] An update on Perl - where is it going?
[1191] Smart English Output - via PHP and Perl ? : operator
[1183] Improving searches - from OR to AND?
[1073] Heartbeat script in Perl
[1009] Passing GET parameters through Apache mod_rewrite
[975] Answering ALL the delegate's Perl questions
[969] Perl - $_ and @_
[968] Perl - a list or a hash?
[965] KISS - one action per statement please - Perl
[930] -> , >= and => in Perl
[928] C++ and Perl - why did they do it THAT way?
[872] Email metrics
[867] Being sure to be positive in Perl
[839] Reporting on the 10 largest files or 10 top scores
[765] Perl - turning seconds into days, hours, minutes and seconds
[762] Huge data files - what happened earlier?
[760] Self help in Perl
[743] How to debug a Perl program
[738] (Perl) Callbacks - what are they?
[737] Coloured text in a terminal from Perl
[733] Perl for Systems Admin - suid scripts
[702] Iterators - expressions tha change each time you call them
[662] An unhelpful error message from Apache httpd
[641] Simple but rugged form handling demo
[639] Progress bars and other dynamic reports
[622] Queues and barrel rolls in Perl
[618] Perl - its up to YOU to check your file opened
[616] printf - a flawed but useful function
[608] Don't expose your regular expressions
[604] Perl - multiprocess applications
[599] Perl/Tk real time display
[597] Storing a regular expression in a perl variable
[594] Twice is a co-incidence and three times is a pattern
[590] Danny and Donna are getting married
[588] Changing @INC - where Perl loads its modules
[586] Perl Regular Expressions - finding the position and length of the match
[583] Remember to process blank lines
[582] DWIM and AWWO
[577] Learning to program in Perl or PHP
[531] Packages in packages in Perl
[493] Running a Perl script within a PHP page
[454] Time conversions in Perl
[400] New in the shops
[358] Use standard Perl modules
[357] Where do Perl modules load from
[355] Context in Perl
[314] What language is this written in?
[293] Course follow-ups
[263] Harmony
[262] A little bit of fun - the new Perl Quiz
[255] STDIN, STDOUT, STDERR and DATA - Perl file handles
[254] x operator in Perl
[246] When to bless a Perl variable
[243] new 'Perl on the Web' example
[242] Satisfaction of training
[240] Conventional restraints removed
[230] Course sizes - beware of marketing statistics
[140] Comparison Chart for Perl programmers - list functions
[138] Perl - redo and last without a loop
[113] A Parallel for Perl 6
[112] Avoid the wheel being re-invented by using Perl modules
[89] When will Perl 6 be available
[86] Talk review - Idiomatic Perl, David Cross
[45] CGI v mod_perl
[43] Hash of lists in Perl
[31] Here documents
[28] Perl for breakfast
[25] Release numbers
[12] How many people in a room?
Top or Show all for The Perl Programming Language and its use

Client Side Languages (HTML, CSS, Javascript)
[2390] Dynamic / changing images on your web page - (new - 2009-09-01)
[2223] CSS Style Diagrams - working out where attributes come from
[2135] What features does this visitors browser support? (PHP)
[1998] Text on a background image
[1926] Flash (client) to PHP (server) - example
Top or Show all for Client Side Languages (HTML, CSS, Javascript)

Ruby and Ruby on Rails
[2296] Variable scope - what is it, and how does it Ruby?
[2293] Regular Expressions in Ruby
[2292] Object Orientation in Ruby - intermediate examples
[2291] Collection objects (array and hash) in Ruby
[2290] Opening and reading files - the ruby fundamentals
Top or Show all for Ruby and Ruby on Rails

SQL and MySQL
[2458] Cant connect to local MySQL server through socket /tmp/mysql.sock - (new - 2009-10-17)
[2448] MySQL - efficiency and other topics - (new - 2009-10-10)
[2447] MySQL stored procedures / their use on the web from PHP - (new - 2009-10-10)
[2446] Learn about MySQL stored procedures - (new - 2009-10-09)
[2445] Securing MySQL on a production server - (new - 2009-10-09)
[2444] Potted MySQL installation - (new - 2009-10-09)
[2426] Which version of MySQL am I running? - (new - 2009-09-26)
Top or Show all for SQL and MySQL

Tcl, Tcl/Tk and Expect
[2476] Tcl - uplevel to run code at calling level - (new - 2009-10-24)
[2475] Quick easy and dangerous - automated logins via Tcl / Expect - (new - 2009-10-24)
[2474] Using Tcl and Expect to automate repetitive jobs - (new - 2009-10-24)
[2472] split and join in tcl and expect - (new - 2009-10-23)
[2471] A short form of if ... then ... else - (new - 2009-10-23)
[2468] What are Tcl lists? - (new - 2009-10-22)
[2467] Tcl - catching an error before your program crashes - (new - 2009-10-22)
[2466] Tcl - passing arrays and strings in and back out of procs - (new - 2009-10-22)
[2463] Tcl - a true interpretive, command based language - (new - 2009-10-20)
[2429] Tcl scripts / processes on a web server via CGI - (new - 2009-09-27)
Top or Show all for Tcl, Tcl/Tk and Expect

Programming in Lua
[2461] Luac - getting lua to start fast by precompiling - (new - 2009-10-20)
[2455] Lua examples - coroutines, error handling, objects, etc - (new - 2009-10-15)
[2454] For loops in Lua - (new - 2009-10-14)
[2383] Lua Regular Expressions
[2360] Error Handling in Lua with assert and pcall
Top or Show all for Programming in Lua

Python Programming
[2485] How do I set up a constant in Python? - (new - 2009-10-31)
[2481] Sample code with errors in it on our web site - (new - 2009-10-29)
[2462] Python - how it saves on compile time - (new - 2009-10-20)
[2452] Making executable binaries in Python (or Perl) - (new - 2009-10-12)
[2442] Variable storage - Perl, Tcl and Python compared - (new - 2009-10-08)
[2440] Optional parameters to Python functions - (new - 2009-10-07)
[2439] Multiple returns from a function in Python - (new - 2009-10-06)
[2435] Serialization - storing and reloading objects - (new - 2009-10-04)
[2409] TypeError: super() argument 1 must be type, not classobj (Python) - (new - 2009-09-18)
[2408] Robust user input (exception handling) example in Python - (new - 2009-09-17)
[2407] Testing code in Python - doctest, unittest and others - (new - 2009-09-16)
[2406] Pound Sign in Python Program - (new - 2009-09-15)
[2394] Two days of demonstration scripts in Python - (new - 2009-09-05)
Top or Show all for Python Programming

And also ...
[2469] Beyond the Pale - (new - 2009-10-22)
[2464] Beauty in pictures - (new - 2009-10-20)
[2460] Mothers Day or Mothering Sunday? - (new - 2009-10-19)
[2456] Bright Eyes - (new - 2009-10-16)
[2451] Gypsy says - (new - 2009-10-12)
[2450] Family Gathering at 404, The Spa - (new - 2009-10-11)
[2412] Autumn Fruits and Bristol Old Station - (new - 2009-09-20)
[2411] Further North - long summer days and lovely countryside - (new - 2009-09-19)
[2404] Low Sun - Autumn is here - (new - 2009-09-13)
[2401] Back Tomorrow - (new - 2009-09-10)
[2392] Lymington, New Forest - some pictures - (new - 2009-09-03)
[2387] to Clifton Down and Avonmouth - (new - 2009-08-30)
Top or Show all for And also ...

Public Transport
[2486] Santa Special - Trowbridge and Melksham to Swindon - (new - 2009-10-31)
[2477] By train ... - (new - 2009-10-25)
[2473] Exploring Old Railways - (new - 2009-10-24)
[2457] Railway Arithmetic - (new - 2009-10-16)
[2431] Moving busstop! - (new - 2009-09-30)
[2395] From Lymington by train - last of the slammers - (new - 2009-09-05)
[2391] Great Western Route Utilisation Strategy - Draft for Consultation - (new - 2009-09-02)
Top or Show all for Public Transport

Fun and Flames
[2397] Signwriting is dead. Long live the sign. - (new - 2009-09-06)
[2256] Is it Python past cheetah already?
[2251] Over a third of numbers start with the digit 1
[2250] Bluegrass comes to Melksham
[2193] Excellent product, excruciating customer service. 3 Mobile Broadband
Top or Show all for Fun and Flames

Keynote Articles
[2483] Clustering on Tomcat - (new - 2009-10-30)
[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
[2479] Accidentally typed ci rather than vi? - (new - 2009-10-27)
[2301] Mistaken identity?
[2300] What does x on a linux directory mean?
[2299] How much space does my directory take - Linux
[2203] Always use su with minus. And where do programs come from?
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 September 2009July 2009May 2009March 2009January 2009November 2008September 2008July 2008May 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