TechTip: Vive la Diff

General
Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times


Sometimes we need to compare two files quickly. What if your "test" Web site works perfectly, but the production site won't start? You should compare the two Apache configurations to find the glitch.

Fortunately, comparing files is simple with the UNIX command diff, available on iSeries through Portable Application Solutions Environment (PASE), a no-charge option in OS/400 releases since V5R2.

(Why use PASE instead of Qshell? Although PASE and Qshell both provide a UNIX-like command environment and share many commands and utilities, the diff command is specific to PASE. It's easier to run diffin PASE than in Qshell.)

Here's the command syntax for diff:
diff -b FirstFileName SecondFileName

The –b means our comparison will ignore much of the white space it finds. The arguments FirstFileName and SecondFileName represent the two files to compare.

Let's say our test Web server instance is called WEBTST. Our production server is called WEBPRD. WEBPRD has a problem. Let's compare the two servers.

Launch PASE's command line:
call qp2term

Compare our two configuration files using diff:
diff -b /www/webtst/conf/httpd.conf /www/webprd/conf/httpd.conf

The command produces the following (seemingly cryptic) output:

1c1
< Listen 10.11.12.13:80
---
> Listen 10.11.12.14:80

6c6
< ServerRoot /www/webtst
---
> ServerRoot /www/webprd

54c54
< RewriteRule ^/cgi-bin/cgiweb(.*) /qsys.lib/cgilib.lib/cgiweb.pgm$1 [PT,L]
---
> RewriteRule ^/cgi-bin/cgiweb(.*) /qsys.lib/cgilib/cgiweb.pgm$1 [PT,L]

Look at the first pair of lines above. The "1c1" means that line 1 of the second file differs from line 1 of the first file (it would need to change to make it match—hence the "c"). The differing configuration directives instruct the production and test servers to listen for (respond to) different IP addresses. This is fine.

Our next difference is also legitimate. The notation "6c6" means that line 6—in this case, the ServerRoot—differs between the files.

The third difference is the clinker. The "54c54" shows two different RewriteRule lines. (An Apache "rewrite rule" is a powerful directive, transforming browser requests into program calls that your software understands.) Look carefully at the two RewriteRule lines. While the first directive asks for a location called cgilib.lib, the second directive asks for cgilib, omitting the final .lib. That's not good!

The "diff" utility helped us find the error, a missing .lib on a RewriteRule.

Now, press F3 to exit the PASE session.

We're done! If this were a real emergency, we'd probably correct the Web configuration using the Web-based Web Administrator.
Our example only showed changes ("c") between the two files. Depending on how extensive the files' differences were, the letters "a" (added lines) and "d" (deleted lines) might also have appeared.

For more information, see the diff command reference.


Alan Seiden
  Alan Seiden founded Seiden Group to help IBM i shops design and implement high-performance web and mobile applications using PHP, DB2, RPG business logic and Zend Framework best practices. Alan and his team work closely with some of the best minds at both Zend and IBM on behalf of their clients.With a passion for open source and community, Alan co-developed the popular PHP Toolkit with IBM. He was one of the first Zend Framework certified engineers; co-founder of the NYC Zend Framework Meetup; charter member of IBM/COMMON's PHP Advisory Board; and a consultant for IBM's manual PHP: Zend Core for i5/OS. An award-winning speaker, Alan has been called "the performance guru of PHP on IBM i." He shares his expertise regularly at conferences and user groups such COMMON, ZendCon, the RPG & DB2 Summit, OMNI, the Northeast Users Group Conference, OCEAN and WMCPA. He also mentors other developers within the Club Seiden forum.In his spare time, Alan plays the trombone and studies and teaches the Feldenkrais Method® of Somatic Education.Subscribe to Alan’s monthly newsletter PHP on IBM i Tips.  Follow Alan on Twitter: @alanseiden and LinkedIn: www.linkedin.com/in/alanseidenMore on Alan
BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$

Book Reviews

Resource Center

  •  

  • LANSA Business users want new applications now. Market and regulatory pressures require faster application updates and delivery into production. Your IBM i developers may be approaching retirement, and you see no sure way to fill their positions with experienced developers. In addition, you may be caught between maintaining your existing applications and the uncertainty of moving to something new.

  • The MC Resource Centers bring you the widest selection of white papers, trial software, and on-demand webcasts for you to choose from. >> Review the list of White Papers, Trial Software or On-Demand Webcast at the MC Press Resource Center. >> Add the items to yru Cart and complet he checkout process and submit

  • SB Profound WC 5536Join us for this hour-long webcast that will explore:

  • Fortra IT managers hoping to find new IBM i talent are discovering that the pool of experienced RPG programmers and operators or administrators with intimate knowledge of the operating system and the applications that run on it is small. This begs the question: How will you manage the platform that supports such a big part of your business? This guide offers strategies and software suggestions to help you plan IT staffing and resources and smooth the transition after your AS/400 talent retires. Read on to learn: