Friday, September 4, 2009

Modifying Tomcat admin port in xampp control panel

After suffering through several hours of pulling hair and gnashing teeth while trying to figure out how to change the port location for Tomcat, I finally found a solution.

For those of you who work with xampp, the following image should be familiar:




In my installation, I already have a Glassfish server listening on port 8080, so I changed Tomcat to listen on 8082. That works fine, but if I click on the xampp admin button for Tomcat, it sends the browser to the default port (8080) instead of the actual port in use.

I hunted through php.ini files and Googled the heck out of things, but only found references to go to the application's conf/ directory and change the value there. But, alas, xampp control panel knows nothing about these changes. A colleageue at work said he thought he saw a xampp.ini file a long time ago, but it no longer exists, so I thought I would try it, since nothing else in the help, FAQ, or other documentation seems to work.

In the /xampp directory I created a file named xampp.ini and placed the following in it and restarted xampp control panel:


[PORTS]
tomcat = 8082

Then I tried clicking on the Tomcat admin button on xampp control panel, and the browser came up with the correct URL.

Sweet!

oh, yeah, this is on a Windows 2003 Server system in case anyone is curious...

Saturday, August 15, 2009

OpenSSO woes...

We have been using OpenSSO (Fam80b1) in combination with Glasffish and OpenDS v1b008/OpenDSv1.0GA and all has been working fine. Now that we want to upgrade to openSSO 8.0 Enterprise Edition, we have found that all our custom code that works to retrieve user data with a custom schema via both the Sun IDM and our custom IDM are now broken.

The problem lies with the deprecation of AMConfig.properties file, where much vital information is stored and read by OpenSSO on system startup. The API calls that return the information from this file still exist and are not marked as deprecated, and we cannot find alternative API calls to return the same information. The properties we need are com.iplanet.am.directory.host, com.iplanet.am.directory.port, com.sun.identity.authentication.special.users

For now, it appears we cannot upgrade due to the inconsistent deprecation of features + API...

Friday, June 26, 2009

Been to busy...

Been too busy trying to juggle work and an interview schedule that just won't quit... Hopefully, I'll get back on track again later this week.

Friday, May 8, 2009

Amazon.com phone interview

Well, today I had a phone interview for a SDE position at Amazon.com. Unfortunately, I have been putting out fires at work for the past 2 days and really wasn't in a good frame of mind to think about data structures and algorithms and Big O notation. A sample of questions...

Q1. In Java write a function that will scan an array of int for a value that occurs an odd number of times, specifically once, and return the value. Only 1 number in the array will occur an odd number of times, the rest will occur an even number of times. What would be the runtime order of magnitude of this solution?

Q2. Design a set of classes organizing a bank of elevators and to manage and control them.
Use case1: on floor X, a person presses the down button. How do your class designs handle this?
Use case2: a person enters an elevator on 8th floor and presses the button for 2nd floor, but the elevator is still going up. How do your class designs respond to this?

Q3: Given a table that contains company names and revenue columns, with more than one row for each company name. Design a SQL statement that will return only 1 company name and the corresponding total revenue?

Since I wasted too much time on the first question, thinking about what are some elegant ways to solve that problem, but coming up blank - I was still thinking about how to get one of my teams' Dev servers back up on the network and functioning again. I started to come up with a brute-force solution, but we had to move on to other questions. I got through the others fairly well. Of course, after the interview was over and while getting the server to stand up again, I came up with a solution. But by this time, it's an hour too late since the interview was over. Major screw up on my part, but the real world got in the way of preparing for a great opportunity. Amazon will probably never want to talk to me again...

Hopefully, I'll get another chance to speak with them...

Wednesday, April 29, 2009

Starting/stopping Windows services from a script

Ever had a situation where you needed to stop at least one Windows service that also is dependent on other services? I've got one now, where Oracle WCI and BPM Enterprise are running on a box with other more critical services, but eventually, one of the Oracle processes starts running out of control and takes up 100% of CPU and memory. If you can get to the console and eventually login (it take 5 minutes, literally), you see a message box telling you the server has run out of virtual memory.

Normally, we administer the server via remote desktop/terminal server from our desktop or VPN if we happen to be remote. But in this case, the box does not have enough free CPU or memory to even respond to remote connections and someone has to physically go into the server room and shutdown the box (it takes 30 minutes for the box to shutdown) or kill the power (if they don't have a login). Not very good options in any case...

So, I poked around the Microsoft site and thought, "hey, I've created Windows services before with sc.exe, I should be able to stop them from a command window." A great idea, until you try sc.exe to stop a service that depends on other services. You get the dreaded


[SC] ControlService FAILED 1051:

A stop control has been sent to a service that other running services are dependent on.


error message. Worst of all, you won't even see the error if you have written this in a batch script - it'll just fly on by.

I thought, ok, so I have to specify each service in reverse order of dependency in my script. There are 7 services to stop, so I had a line calling sc.exe for each one.


sc.exe stop Tomcat6
sc.exe stop ptautomationservices
sc.exe stop "Ldap server"
sc.exe stop wsserver
sc.exe stop OracleBPMWebApplications
sc.exe stop SQLBrowser
sc.exe stop MSSQL$SQLEXPRESS


Well, only the first service stopped and none of the others. Eventually I found that sc.exe returns immediately, and any dependent services probably haven't even begun to stop, so they fail the stop command. So we have to wait until each service completes stopping.

After Googling around for a while, I eventually came upon sites that pointed out that you have to prepend with "start" like velocityreviews or tek-tips.com suggests:

start /wait sc \\server_name stop service_name1
start /wait sc \\server_name stop service_name2

Great! every call to sc.exe will wait until the command finishes stopping the service befre executing the next one. So I happily went on to modify my script to:


start /wait sc.exe stop Tomcat6
start /wait sc.exe stop ptautomationservices
start /wait sc.exe stop "Ldap server"
start /wait sc.exe stop wsserver
start /wait sc.exe stop OracleBPMWebApplications
start /wait sc.exe stop SQLBrowser
start /wait sc.exe stop MSSQL$SQLEXPRESS


and then executed the batch script, expecting all the services to shutdown gracefully in order.

Wrong! On Windows 2003 Server, it doesn't wait. :-( WTF!!

Again, Tomcat stopped and sometimes the automation services, but I didn't see anything on the screen appear to wait or pause. The script still just flies by. So I Googled around a bunch more... There must be a solution and I can't be the only one trying to do something like this. I found similar issues with the same answers, but no resolution. One suggested, write a WMI script, another suggested write a VB program. What? Just to shutdown services? There has to be a better way.

Then I thought, you can use net \\servername stop servicename from the command line to stop a service on another box over the network, what happens when I do it on the same box? So I tried:

c:\net stop MSSQL$SQLEXPRESS

in a DOS window, and waited...


The following services are dependent on the SQL Server (SQLEXPRESS) service.
Stopping the SQL Server (SQLEXPRESS) service will also stop these services.

Apache Tomcat
BEA ALI Automation Service
BEA ALI LDAP Directory
BEA ALI API Service
Oracle BPM Web Applications
SQL Server Browser

Do you want to continue this operation? (Y/N) [N]:


hmm.... at least it asks me if I really want to do it, so I enter "Y" and cross my fingers:

The Apache Tomcat service was stopped successfully.

The BEA ALI Automation Service service is stopping.......
The BEA ALI Automation Service service was stopped successfully.

The BEA ALI LDAP Directory service is stopping........
The BEA ALI LDAP Directory service was stopped successfully.

The BEA ALI API Service service is stopping.......
The BEA ALI API Service service was stopped successfully.

The Oracle BPM Web Applications service is stopping.......
The Oracle BPM Web Applications service was stopped successfully.

The SQL Server Browser service is stopping.
The SQL Server Browser service was stopped successfully.

The SQL Server (SQLEXPRESS) service is stopping.
The SQL Server (SQLEXPRESS) service was stopped successfully.


it actually works! But what if I don't want the user to have a choice and just force the "y" answer? In my case, the machine is usually not responsive enough for the user to sit around for minutes before being prompted for a "Y" or "N", it just has to work. Is that possible inside a batch script? I still haven't found the answer to that yet, but this is a start...

Update... ( Wed 29 Apr 2009 10:09:20 PM PDT )
to force net stop to not prompt for user input you append /YES, e.g.:


c:\net stop MSSQL$SQLEXPRESS /YES


But, I still have the problem if the server is too busy, it may not be able to keep track of the dependent services to shutdown or the stop command may time out before the service even receives the event. So, I'm probably back to sending each service the shutdown signal:

net stop Tomcat6 /YES
net stop ptautomationservices /YES
net stop "Ldap server" /YES
net stop wsserver /YES
net stop OracleBPMWebApplications /YES
net stop SQLBrowser /YES
net stop MSSQL$SQLEXPRESS /YES

at least my user will be able to see the progress (or lack thereof) while the server attempts to stand itself back up.

Tuesday, April 21, 2009

Flying a dream

Wow, sounds like the Boeing 787 Dreamliner might actually fly before the end of the month! Finally, some great news after all the production delays.

Oracle BPM and WebCenter Interaction install saga

A short rant about installation and configuration documentation...


One of my projects requires Oracle BPM Enterprise 10g Standalone (used to be BEA ALBM, AquaLogic BPM before that, and Fuego BPM originally) integrated with the Portal, Oracle WebCenter Interaction 10g. Being in more of an Application Architect role rather than a Sys Admin, I don't normally get hands-on installing software on servers, unless it is for a proof-of-concept. The team needed a development instance to work against, so I volunteered to configure the server with an Oracle consultant's assistance.


Sometimes installation instructions are really good and other times they really suck. Usually, its one or the other, but the Oracle installation instructions were both at the same time. BPM Enterprise had references to software versions 6.5, 10g, and 10.3.1 – please try to get at least your version numbers in your documentation that you provide to your users consistent! Come to think of it, so did WebCenter Interaction...


The consultant and I spent a week trying to get WebCenter Interaction 10g and BPM Enterprise 10g Standalone to 1) install correctly, and 2)integrate with each other, without success. During the second week, I managed to find some obscure documentation that just happened to be the key to solving our issue, but it was so late at night and I was so tired, I still can't figure out how I found this jewel of information on the Oracle site. All I know is Google is a wonderful search tool.


The 2 Oracle consultants, installing the software in two different parts of the company I work at, were running into the same issues. Somehow, I had stumbled upon the solution even before the Oracle guys heard about it. In the configuration guide in docs65 for Oracle BPM 10.3, there is a section describing how to configure BPM to use the directory service provided by WebCenter Interaction. The guide says:

Principal Specifies the principal or ID used to connect to the ALI LDAP

provider. For example, uuid= ali_admin_user,ou=osers,dc=oracle,dc=com

We tried that and failed. We tried all sorts of Oracle/BEA/AquaLogic passwords and no soap. Each time resulting in an unusable BPM installation, so it's time to uninstall, reboot, reinstall, etc. Oh yeah, we are on Windows 2003 Server platform... other people who use that server are getting annoyed with all the reboots...

After all this going on for a whole week, in the middle of the second week, I VPN from home to try this little piece of information I found on the Oracle website. For the LDAP config, it's not “ou=osers,dc=oracle,dc=com”, but it is “ou=users,dc=bea,dc=com”. And like magic, BPM is able to integrate with the Directory Services provided by WebCenter Interaction. Hmm... I guess it's a BEA product after all.


Two days later, the other consultant lets me know he has found a way to install the products successfully, but tells me that it's not official, because its not documented anywhere. 10 guesses what the magic phrase is (and the first 10 don't count). Yup, exactly what I found 2 nights before. Now somebody tell me why I had to find this information?


Ok enough venting... I feel much better now...

Oracle Buys Sun - is this good for Java and Open Source?

After tap dancing with IBM for the past few months, now it looks like Oracle is about to purchase Sun Microsystems and some of my colleagues at work are wondering if this is a good thing or not. We work with some of the Java-based Open Source applications sponsored by Sun and bundle 3 of them - OpenDS, OpenSSO, and Glassfish, into a product offering for our customers who desire a non-commercial solution, free of up front/annual fees and restrictive licensing. We also use the NetBeans IDE in our work to customize and bundle the 3 applications into a single solution; and we use MySQL in other projects...

What happens to these and other Open Source products once Oracle closes the sale? We can only hope that Oracle will continue the Open Source initiatives sponsored by Sun and fully support the JCP process as well...