Using Linux as a Cheap Development System

Linux / Open Source
Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

For many years, having the title AS/400 Software Developer implied that you worked on site with your development machine, since you had to have a terminal to program in CL, RPG, or COBOL. If your equipment was slightly more advanced, you might have had (or may still have) a blazingly fast 9,600 bits per second (bps) dial-up connection available with which you could do your programming from home. That option lost its luster after its third or fourth use because it was too darned slow. Dial-up connectivity quickly became an alternative to driving back to the office after hours to answer job halts or make quick fixes, but it was not used for serious programming.

Even the higher speeds obtainable through Internet connections do little to change the fact that, for traditional AS/400 programming, a connection to the AS/400 is required. And not just any old AS/400 will do: You need one that has the necessary development software loaded on it, such as the Application Development ToolSet/400 (for SEU, SDA, and DFU), the ILE language compilers (you are using the ILE languages, aren’t you?), and possibly SQL tools.

The ultimate solution for working away from the office may be to purchase your own personal AS/400 (PA instead of PC?) loaded with the development tools you
need—or maybe not. A more likely solution may be to reconsider your selection of programming languages and the platform upon which you develop. The people at IBM have made it quite clear in both word and deed that their vision of the AS/400’s future centers around the Java programming language. Numerous articles touting the many benefits of Java as a language have been written already, so I won’t do any (well, much) evangelizing on that topic. Instead, I’ll discuss some of the collateral advantages you’ll derive once you make the switch, not the least of which is the ability to cut the (development) cord to your AS/400 once and for all and give your personal schedule flexibility previously unattainable.

Recent Improvements

Before I get to the heart of the matter, let me review—in no particular order—some of the things that IBM has done to create the “new and improved” AS/400. First, the database has been upgraded from the nameless entity of earlier versions of OS/400 to the DB2 Universal Database (UDB) for AS/400. Along the way, the database has picked up some extremely


powerful capabilities, including the ability to handle binary large objects (BLOBs) such as audio and video data—the stuff of the Internet. You can still access the database via traditional programming languages, but now access is possible via ODBC and Java Database Connectivity (JDBC). Thus, DB2 UDB can serve data to clients running from the same AS/400, a different AS/400, or a completely different platform.

Second, IBM has made a big investment in both the Java language and the AS/400’s Java Virtual Machine (JVM). As a result, the AS/400 has become arguably one of the best Java platforms in existence. So all of the benefits of Java (which I promised not to preach) are available for your development efforts.

Last but not least, IBM recognized early on that TCP/IP was becoming the standard networking protocol, so it acted on that knowledge and added TCP/IP to the AS/400’s arsenal. Successive versions of OS/400 have included an ever-improving TCP/IP suite that is now quite complete. The IBM HTTP Server for AS/400 allows you to deliver Web pages from your AS/400, and the IBM WebSphere Application Server for AS/400 allows you to use Java servlets, JavaServer Pages (JSPs), and Enterprise JavaBeans (EJBs). Together, all of these updates and capabilities have made the AS/400 a reputable Internet server.

I realize that this information regarding AS/400 Web-enablement is old news to most people reading this article, but I mention it to make a point: IBM made these changes to keep the AS/400 viable. The AS/400 isn’t unique in its capacity as an Internet server, and it wasn’t the first one. Many other platforms are quite capable of doing the same job. As an admitted AS/400 bigot, I think you can hardly go wrong using the AS/400 as an Internet server—for production. But for development, I think there are probably better choices, if for no other reason than physical portability.

Development System Requirements

The requirements for a development system, then, are simply that it duplicates the functionality of the AS/400 and, for me (because I buy my own hardware and software), that it’s inexpensive. Because there presumably will be only one client attached to the server at one time, horsepower isn’t a major consideration. So, instead of purchasing a system loaded with the fastest processor(s), biggest small computer system interface (SCSI) hard drives, and more memory than a human has, I use a reconditioned IBM ThinkPad 770 with a whopping 128 MB of RAM; a zippy, 200 MHz Pentium MMX processor; and a 5 GB hard drive. I certainly don’t have any bragging rights with this modest (by today’s standards) laptop computer, but I am very satisfied with it.

To get a reasonable level of performance from this machine, I had to choose for it an operating system that has a reputation for making the best use of resources. If you’ve read any of my other articles, then you already know where I’m heading: Linux. As with Java, I’ll avoid evangelizing on the benefits of this operating system, except to mention the extremely low cost (free). I don’t need to evangelize, because now you can pick up almost any trade magazine (except those emanating from Redmond) and read articles in which someone else does it for me.

Once the basic Linux installation has been completed (in my case, Red Hat Version
6.0), you can concentrate on collecting the other software pieces required to duplicate the functionality of your production system. You’ll need a JVM, a database manager, the JDBC drivers for your database manager, and a Web server. Until recently, your choices for these items were somewhat limited. But as the Linux bandwagon has picked up speed, more options have become available. Surprisingly, IBM has become one of the biggest proponents of Linux and has ported its e-business tools to it. But I’ll get to IBM’s contributions.

Some Assembly Required


To start assembling the development system, you’re going to need a database manager. There are many to choose from. Most distributions of Linux include an open source (read free) database management system (DBMS): PostgreSQL. This DBMS is a good choice because it has most of the features you’d expect in a DBMS and because there is a JDBC driver available for it. Commercial support also is available for those who are interested. For further information on PostgreSQL, including info on the associated JDBC driver, visit the PostgreSQL Global Development Group’s Web site at www.postgresql.org.

If you are developing a Web site and are interested in an extremely fast and lightweight DBMS, then you’d be interested in MySQL. MySQL lacks some of the more sophisticated features you’d expect in a modern DBMS, such as transactions and commitment control, but, in the right application, their absence isn’t a problem. You can find information about MySQL at www.mysql.com; you can get information about the JDBC drivers at the MM MYSQL JDBC DRIVERS site at www.worldserver.com/mm.mysql.

Oracle was the first commercial database to be ported to Linux. There’s not much I can add to what everyone already knows about it, except that, if your company already uses it on one or more of its servers, you can’t go wrong using it on your Linux development platform. Oracle offers an entire suite of e-business software products for the platform that may be of interest. For further information, visit Oracle’s Web site at www.oracle.com.

Saving the best for last (at least in my opinion), I’ll mention IBM’s beloved DB2 UDB for Linux. If you’re planning on emulating the DB2 environment you have on your AS/400, you certainly will want to check out IBM’s offering. This DBMS has the features that you’ve come to associate with its bigger brother, so any software you write should be transplantable to the AS/400 with little or no change.

While I’m on the topics of IBM, DB2, and Linux, I’ll digress a moment and mention that WebSphere, the product you’ll need if you plan on writing any Java servlets, is available too. The combination of WebSphere and DB2 UDB for Linux on your development platform will make you feel right at home if you’re already doing development on your AS/400. At the time of this writing, IBM is offering the free Application Developer’s Kit for Linux, which includes both of these products. For further information, check out the Linux at IBM Web site at www.ibm.com/linux.

All of the databases listed here include command line interfaces, so, once you have your chosen DBMS installed, you can access it just as you would on the AS/400 if you used the the Start SQL (STRSQL) command.

Coffee, Anyone?

All of this cross-platform development would be much more difficult if it were done in any language other than Java. So, assuming that’s the language you plan on using, you’ll need to acquire a JVM and install it on your development machine. There are a few options available to you, but the most likely candidates for your machine come from Sun Microsystems and IBM.

Until recently, Sun, owner of Java, had never produced a JVM for Linux. Instead, it has delegated the job of porting its existing source to the Linux platform to the Blackdown project, a group of programmers who, as they put it, “serve as a bridge between the open source movement and commercial software vendors.” With version
1.2.2, Sun is now producing the JVM for the Intel platform. Blackdown is still producing the non-Intel and older versions of it. The home of the Blackdown project is www.blackdown.org. There, you’ll find the various versions of the JVM as well as links to various Java tools for Linux, which I’ll discuss. Sun’s Java home page is www.java.sun.com.

Once IBM caught Java fever, it produced a JVM of its own. You can find complete information on this JVM at the Java 1.1.8 for Linux Web site at


www.ibm.com/developer/linux/papers/java-118.html. This is an industrial-strength JVM with excellent performance.

In the Java version race, Blackdown is out in front, with Version 1.2.2 available for download; IBM’s latest and greatest is Version 1.1.8. But either would serve well for the type of programming you’d normally be doing away from—but for—your AS/400 server. I have both of these JVMs loaded on my laptop and switch between them as the mood strikes me.

Making It Easy

Everyone knows that real programmers use a command line for interaction with the machine and a context mode editor (such as SEU on the AS/400 or a Vi editor on a Linux/UNIX box) for editing source code. Those mortals who feel that productivity takes precedence over machismo should obtain some type of integrated development environment (IDE). There are many available. If you point your browser once again to the Blackdown site at www.blackdown.org/java-linux/products/javatools.html, you’ll see an extensive list of tools to help you along with development.

Figure 1 shows one of my favorite IDEs. It’s called AnyJ and can be found at the NetComputing home page (www.netcomputing.de). It provides all of the standard features you’d expect in an IDE for an excellent price (again, free).

Another slick IDE comes from TogetherSoft (www. togethersoft.com), which takes the concept of an IDE further. With the Together IDE, you create your Java program and Unified Modeling Language (UML) diagrams simultaneously. A change in the source window updates the UML window and vice versa. Figure 2 shows the Together IDE in action. Together is available in a free “whiteboard” edition that is useful for a single developer. It’s also available in a chargeable edition that lets you print the UML diagrams you’ve created, as well as work collaboratively with your colleagues. It is one handy tool.

IBM has ported its flagship product, VisualAge for Java (VAJ), to the Linux platform. I like the tool, but the visual method of programming does take some getting used to. VisualAge differs from some of the other products in that it keeps your code in a repository (really a glorified .zip file), but you can tell VisualAge to export the code to individual code modules. VisualAge comes in a variety of flavors—from a standard edition to an enterprise edition—each with its own capabilities. The enterprise edition is the most sophisticated and provides the ability to work with Enterprise JavaBeans (EJBs).

What a Tangled Web We Serve

To complete your development system, you’ll need a Web server. There is one clear choice: the Apache Web server (www.apache.org). Apache is currently the most widely used HTTP server on the Internet and is included with every distribution of Linux. In fact, many distributions will install it by default. IBM’s WebSphere for Linux product works with Apache, so you’ll be able to tie the two together on your development machine. Better still, you can replace the stock Apache installation with IBM’s HTTP server, which is also included in IBM’s development kit. IBM’s server is based on Apache but has some performance enhancements and extensions, such as SSL.

Close Your Windows but Open Your Doors to Free Software

Building a development platform that you can take with you makes a lot of sense. It enables you to work away from the office (that’s a good thing?) and apart from your AS/400. The openness of the AS/400 and the Internet protocols has made it possible to develop software on disparate platforms—something that’s been the Holy Grail of computing for years.

By selecting Linux as your operating system, you can take advantage of all of the open source tools available. If you take the time to examine the license on a lot of open source software, you’ll note that the products are typically free for most uses—if you’re running Linux. The license is frequently more restrictive, and chargeable, if you choose to


run the software on the “other” operating system. A case in point is the MySQL database. You are basically welcome to use the database for any purpose for yourself or your company. A registration fee is required only if you are going to make money by selling services to someone else. Of course, a registration fee is always required if you’re going to run the database on Windows. The guys from MySQL have explained this disparity in the MySQL mailing list, and their reasoning is simple: They like programming in the Linux environment; they don’t like programming for Windows. Customers asked for a Windows port, so the MySQL people provided it—for a fee.

Admission to the Linux world is cheap, and the results are rewarding. You ought to give it a try!

REFERENCES AND RELATED MATERIALS

• Blackdown Project Java Linux Web site: www.blackdown.org
• Java 1.1.8 for Linux Web site: www.ibm.com/developer/linux/papers/java-118.html
• Linux at IBM Web site: www.ibm.com/linux
• MM MYSQL JDBC DRIVERS Web site: www.worldserver.com/mm.mysql
• MySQL Web site: www.mysql.com
• NetComputing home page: www.netcomputing.de
• PostgreSQL Global Development Group Web site: www.postgresql.org
• TogetherSoft home page: www.togethersoft.com

Using_Linux_as_a_Cheap_Development_System05-00.png 397x397

Figure 1: AnyJ includes the standard features you need in an IDE, and it’s free.


Using_Linux_as_a_Cheap_Development_System06-00.png 395x395

Figure 2: The Together IDE creates Java code and UML diagrams simultaneously.


BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$0.00 Raised:
$