Welcome!

Java IoT Authors: Pat Romanski, Elizabeth White, Liz McMillan, Yeshim Deniz, Frank Lupo

Related Topics: Java IoT

Java IoT: Article

Small Business Solutions

The only difference between my gas station and Wal-Mart is that they have more suppliers, more products, with more customers

Several years ago I was thinking about buying a small gas station in my local town. I went to my friend Gregory Z., a successful businessman in this field, and asked him, "How do I start a gasoline business?" He gave me simple but wise advice: "You know nothing about gas, but know a lot about computers. Keep doing what you're doing. Just be a little better than others".

I'm trying to follow his advice but I keep thinking how would I apply my software skills had I bought such a business. So here I am again asking for your help, advice, and experience: let's automate my virtual gas station.

The Setup
I've borrowed the money from a bank and now I have:

  • A four-car gas station
  • A small convenience store (coffee, cigarettes, milk, newspapers)
  • A repair shop that changes oil, brake pads, and tires
  • Six employees: one American, two from India, one from Russia, and two from Pakistan; one employee speaks English, and the others speak well in their native languages. I think they have work permits.
  • Three decent Wintel computers
  • $1,000 USD software budget
Service-Oriented Architecture
The only difference between my gas station and Wal-Mart is that they have more suppliers, sell more products, and have more customers. But I'm facing similar challenges: I need to deal with various suppliers of gas, food products, and car parts. I also need to have accounting and payroll systems. That's why I'm planning to architect a system that has different services communicating with each other. I need a service-oriented architecture (SOA).

In a perfect world, all service providers use the same protocol, which is as challenging as having all my employees use only the English language. My employees are trying hard, because for them it's a matter of surviving. Initially they are exposing just a minimal number of public services like fillItUp, getCash, processPlastic, marlboroLightsPlease, oilChange, and takeTip. Smarter employees quickly add more services to their vocabulary to become more competitive. Each of these coarse-grained services may consist of several smaller steps, but consumers don't need to know about them.

Service Coupling
When the guy who sold me the business gave me a pile of different forms to use with suppliers, I thought to myself, "Tight coupling in action." I need to know where these suppliers are located, their services, and how to request them. If a particular vendor changes its request form (the protocol), I'll need to get a new one, otherwise I may lose this service. I'd rather be sending a message to some destination saying, "Yakov needs 1,000 gallons of 93-octane gasoline." Expected response: several price quotes from different vendors. This would be an example of decoupled services. I don't know who they are and they don't know who I am, but we've dynamically discovered each other. I've heard that Jini could help me with this. Is this right? Anyway, in a loosely coupled system a service requestor needs to know the name of the service, what data to provide, and what to expect back, but it should be easy to switch from one provider to another.

Messaging and Transport
One of the best ways to request and receive services is by using asynchronous messaging. JMS is an excellent API, but you still need a transport to deliver your messages between the services, for example, message-oriented middleware (MOM). IBM and Tibco offer great MOM products, but I'd need to sell my gas station and get another loan just to pay for it. No, I need to find something for free.

Web Services
Web services seems to be a decent way to arrange my interaction with external suppliers using a free Internet-HTTP-WSDL-UDDI-SOAP combo. If my external vendors will start publishing their gasoline-tires-milk quotes, I'll write a program that will automatically be looking for the best deal in my neighborhood. Can Eclipse IDE help me with automatic generation of all supporting files for Web services?

OOP Plus AOP
It goes without saying that I'm thinking objects (thank you, Bruce). When I close my eyes, I clearly see the classes Product, Order, and Customer…but after reading about aspect-oriented programming (AOP) these objects become blurry. But AOP is a way to go and I'll dig more in this direction.

Storing My Data
I need a free DBMS. It doesn't have to be fancy and implement sophisticated SQL constructs. Inner and outer joins plus indexing will do. Coding business logic in stored procedures is not in fashion these days. Hibernate looks nice for object-relational mapping. Is this my best option?

Front End
For thin Web clients I'm planning to learn AJAX. If Google did it, so can I. How about rich clients? Swing is not there yet; SWT looks better; .NET is the best but isn't free. Should I spend my money on VB.NET? But I don't know VB! Let me ask my Russian employee Alex if he knows it. He looks like a PhD (does he really have a work permit?).

Help
I'd love to hear your input to this new column. You don't need to write any code, but rather suggest some affordable tools and architectural solutions for my small business. Just provide your feedback to the online version of this article at http://jdj.sys-con.com/read/108260.htm.

More Stories By Yakov Fain

Yakov Fain is a Java Champion and a co-founder of the IT consultancy Farata Systems and the product company SuranceBay. He wrote a thousand blogs (http://yakovfain.com) and several books about software development. Yakov authored and co-authored such books as "Angular 2 Development with TypeScript", "Java 24-Hour Trainer", and "Enterprise Web Development". His Twitter tag is @yfain

Comments (19) View Comments

Share your thoughts on this story.

Add your comment
You must be signed in to add a comment. Sign-in | Register

In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.


Most Recent Comments
Tamizhan 07/16/07 02:49:46 AM EDT

Hi Yakov,

It may be a very late mail to suggest your small business solutions.I believe that the following open source softwares can be used to create cross platform multitiered application for any small business.

OS : Linux

Fron End : JSPs,Struts,Ajax.
Swing(For Stand alone Machines)

Back End : MySQL or DBMaker

Middleware : Stateless Session Bean,MDB,Java Webservice

Server : JBoss

Object Relational Mapping : Hibernate

Logging : Log4J

IDE : Eclipse,Netbeans

Build tool : Ant

Version Control : CVS

Bug Reporting tool : Bugzilla

Many Systems running successfully using the above mentioned tools.I don't know the Free MOM tools and Content Management tools.

Developers : Free Lance Programmers!. If you make BIG MONEY after successful Launch of Business or Application,You can PAY money to Free Lance Programmers.

Gabriel 12/21/05 03:34:53 PM EST

Many people here didn't get the point quite right. 1st, there is no gas station. 2nd, this article is about trying to find ways to build an IT infrastructure for small business, which are low on budget. What development tools and technologies best fit in this scenario? Based on this, what is the best way to acomplish the needed tasks? Remember, this article is about how to develop software for the small business, using open source software¹, based on the same technologies used by the big guys.

¹ I think open standards are more important than open sourse, but none of them are problems for Java.

nick patel 12/13/05 03:49:44 PM EST

plese let me know how much cost to build new gas station plese email or call 865 690 4670

nick patel 12/13/05 03:49:39 PM EST

plese let me know how much cost to build new gas station plese email or call 865 690 4670

nick patel 12/13/05 03:49:38 PM EST

plese let me know how much cost to build new gas station plese email or call 865 690 4670

Ted Weismann 09/14/05 05:26:14 PM EDT

Hi Yakov,

For the front end, have you considered using Sun's Java Studio Creator? It combines 100% Java standards with visual programming, e.g. JavaServer Faces for visual UI design and simplified coding, JDBC Rowsets for drag-and-drop data access and visual query building, and Java API for XML Web services, for simplified access to WSDL based services. It includes drag-and-drop UI design and access to databases and Web services, as well as visual page flow design - all for $99.

Jay 09/07/05 09:05:21 PM EDT

Hi Yakov,

Try using ServiceMix which is an open source Enterprise service bus product by Apache. Its very nice tool for integration and they use JBI (Java Business Integration) and JSR 208 and EDA (Event Driven Architecture) which makes it best ESB framework for SOA i.e SOA + EDA. You can deploy this on JBOSS which is also open source application server.

Thanks
Jay Poldiya

moshe sheleg 08/29/05 06:08:05 AM EDT

Shalom Yakov,

Regarding you gas station software needs, i would be happy to offer our services.

Please visit http://www.siteron.com for more information.

Do what you do best, outsource the rest...
Moshe

Yakov 08/05/05 01:53:20 PM EDT

Greg,

Having done both Java Swing and .Net, why you do not recommend .Net? What's wront with it?

Also, what's so good about JBoss in terms of monitoring? JMX is available in any J2EE compliant server. I wonder what kind of monitoring JBoss provides off the shelf that does not require additional programming?

Best,
Yakov
http://www.weekendwithexperts.com

Greg 08/04/05 02:29:14 PM EDT

Interesting way to write an article. It will be fun to see how it turns out.

Looks like you are trying to determine some tools to use first. You should probably define your business needs first. Anyway, here are some suggestions for tools...

For the front end, you asked about using either .Net or Java. I'm currently using both Java and .Net. I have a lot of Java Swing experience and some (<6mo) experience with .Net. From what I've seen of .Net 1.1, I would go with Java unless you find a Windows specific need that you cant solve in Java. If you don't need a super-rich front end, you should just make it a web-based client.

If you are looking for free databases consider MySQL or Cloudscape. However, those are only relational databases. Why not consider using a OO DB?

Another thing you will need is a good way to run, configure and monitor your system. Since you are looking for free open source stuff, you should look at JBoss. It makes a great micro-kernal for running Java as Managed Beans. JBoss lets you control and monitor the beans with JMX.

Bill McCuistion 07/29/05 09:19:02 AM EDT

1. You won't be the same as the others, as you'll use your JAVA skills to integrate your unique twists into the QB framework, such as your SOAP service for scouting lowest-cost / best value suppliers. JAVA works just fine with the QBSDK, which is XML-based. Included in the QBSDK is a SOAP-to-COM bridge, so your JAVA code can run anywhere.

2. When you sell the station next year, you'll likely retain a consulting contract to maintain the custom apps you developed. You'll also likely be able to negotiate a higher sales price due to the increased profitability due to your "special" integratons with QB for general accounting, purchaing, point-of-sale, credit card processing, payroll processing and customer relationship managment.

3. Run QB on Linux using Cross-Over Office. Use LAMP/J for apps. OpenBooks, the open-source alternative to Quicken is not really (yet) an alternative to QB, and you've now got a gas station to run. You'll have enough to keep you busy with the add-in modules to not have to worry about how the system calculates sales taxes, payroll taxes and on-line banking using OFX. In other words, use Open Source where it makes sense, and use the classic "Make or Buy" decision to guide that decision. $800 for the QB/POS package license gets you a lot of functionality in an accounting system.

As for your need to mix purposes with the magizine articles, the other stakeholders in the gas station might not be happy with sub-optimization of the gas-station business for your side-line businesses.

4. The decision to use QB is not at all different from using SAP (or Lawson or whatever) and needing to integrate with it, except that the little guy usually can not take the risk of custom development in the same way the the big guy does.

Look for the competitive advantage where you can get it. Make the other guys *think* you're running a stock version of QB. Make them wonder how you keep finding the best purchasing deals. Make them wonder why you have customer loyalty and are able to charge a premium for regular gas. Make them wonder why this and that. Let them make mistakes, while you take baby-steps learning to run a gas-station. Join a local gas-station owners support group, so you can pick-up tricks. Listen to their pain-points, which will give you ideas on how technology might help you prevent / address them before they become your pain points.

You will have a hard time being a consultant to yourself. Get your chart-of-accounts in order. Get your item master set-up. Get your vendor list set-up and get manilla files going too. Get your bar-coder and credit card reader working. You're in retail and need to at least last a year.

BTW -- Reportedly, the largest concentration of bootleg QB software is in the former Soviet countries. It's very likely that your help already knows how to use QB. It was an easy switch from Communism to Capitalism for most of those guys. If the CIA had dropped QB into the Soviet Union 20-years ago, the cold war might have ended a lot sooner.

Yakov Fain 07/29/05 08:46:56 AM EDT

I like Bill's comment!

Most likely QuickBooks can solve most of my needs, but...
1. I do not want to be the same as any other gas station owner on the block.
2. I do not want to cut my ties with the Java world. If my gas business won't become profitable in a year, I'll sell it to a QuickBooks user and return to coding in Java, and my skills will be up to date.
3. I want to understand the world of the open source software and the next column (JDJ, Sep '05) will have an interview with one of my famous customers who happen to be a best selling author in this field.
4. By having this column, we can discuss real world problems that small guys face as opposed to talking all the time from the perspective of large scale enterprises.

Bill McCuistion 07/28/05 01:01:19 PM EDT

Dude! Get a copy of QuickBooks and the QB Point-of-Sale system and be done with it!

Then, if you need to integrate applications, there's a great SDK that let's you do this.

If you need to get a programming fix once you have QB in place, see my website at http://qbopen.com or go to http://developer.intuit.com.

Now, I didn't write QuickBooks, and don't really wish to have to defend it, but if you've got to sell gas and need an immediate off-the-shelf solution in your price range, then go to Best Buy and get the QBPOS bundle, which also comes with a Dell computer.

Branden 07/26/05 06:56:18 PM EDT

Seems like a few assumptions in the article were a little.. off base.
-Web services: I prefer Netbeans, as from my experience its a lot farther ahead than Eclipse nowadays.
-Database: Mysql is free, quick and easy for this type of thing. Hibernate is also a good choice.
- Front end: Check out DWR for Ajax, www.getahead.ltd.uk/dwr/. Also, "Swing is not there yet, swt looks better". Have you actually looked at either of them, or are you just on crack? The only thing that SWT does well is Eclipse. Take a look at the SWT mailing lists, or the bug lists, and you'll notice there are all kinds of problems. Swing is mature, stable, and ready to go - use it. Also, why are you asking JDJ readers about .Net? I'm sure many of them have used it but really..

Using tomcat, hibernate, mysql, a free operating system, and OS jms products you should be able to do this project with a minimal budget.

jay patel 07/25/05 10:27:56 PM EDT

jms: many open source products available (jboss,objectweb???,etc)
db: postgresql, firebird, mysql
if u r considering .net for anything, don't bother w/ vb.net if u r a java developer, use c#
vendors: get one gas vendor to publish in xml to encourage the others to do so as well. perhaps that is some side work in and of itself.
front end: if browser based provides the solution, why consider thick client?

Scott Fingerhut 07/21/05 12:27:00 AM EDT

AJAX? Check out InfoWorld's Jon Udell speaking to TIBCO and recording a live demo of the AJAX tool TIBCO General Interface -- something anyone can use (without a Google budget) to develop compelling rich internet applications.

Here's a link to the InfoWorld blog: http://weblog.infoworld.com/udell/2005/05/25.html

Interested in getting your hands on the priority preview version? Join the AJAX Accelerator Program: http://www.tibco.com/mk/2005/gi.jsp

James Brockman 07/20/05 09:27:07 AM EDT

>> For thin Web clients I'm planning to learn AJAX. If Google did it, so can I. How about rich clients? Swing is not there yet; SWT looks better; .NET is the best but isn't free. Should I spend my money on VB.NET? But I don't know VB! Let me ask my Russian employee Alex if he knows it. He looks like a PhD (does he really have a work permit?). <<

Actually, .NET is free, it's just Visual Studio.NET you pay for. Download the .NET SDK from MSDN, then for rich client development download SharpDevelop at http://sharpdevelop.com, or opt for ASP.NET WebMatrix at http://www.asp.net/webmatrix/ if you're thinking of browser front-ends to your apps. Then, enjoy.

SharpDevelop's support for VB is secondary to its C# support, but not only is SharpDevelop open source, but it is not limited to .NET projects.

JDJ News Desk 07/20/05 08:02:08 AM EDT

Small Business Solutions. Several years ago I was thinking about buying a small gas station in my local town. I went to my friend Gregory Z., a successful businessman in this field, and asked him, 'How do I start a gasoline business?' He gave me simple but wise advice: 'You know nothing about gas, but know a lot about computers. Keep doing what you're doing. Just be a little better than others'.

Mark 07/20/05 07:43:30 AM EDT

Having done plenty of Java and VB6(<) and .Net, I would say that Swing is more than there and .Net is definitely not better(overall). If decide you do want to do .Net DON'T do VB.Net. Do C#, if you have a Java background.

For doing AJAX, I would suggest looking Echo2.

@ThingsExpo Stories
Join IBM November 1 at 21st Cloud Expo at the Santa Clara Convention Center in Santa Clara, CA, and learn how IBM Watson can bring cognitive services and AI to intelligent, unmanned systems. Cognitive analysis impacts today’s systems with unparalleled ability that were previously available only to manned, back-end operations. Thanks to cloud processing, IBM Watson can bring cognitive services and AI to intelligent, unmanned systems. Imagine a robot vacuum that becomes your personal assistant tha...
SYS-CON Events announced today that TidalScale will exhibit at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. TidalScale is the leading provider of Software-Defined Servers that bring flexibility to modern data centers by right-sizing servers on the fly to fit any data set or workload. TidalScale’s award-winning inverse hypervisor technology combines multiple commodity servers (including their ass...
As hybrid cloud becomes the de-facto standard mode of operation for most enterprises, new challenges arise on how to efficiently and economically share data across environments. In his session at 21st Cloud Expo, Dr. Allon Cohen, VP of Product at Elastifile, will explore new techniques and best practices that help enterprise IT benefit from the advantages of hybrid cloud environments by enabling data availability for both legacy enterprise and cloud-native mission critical applications. By rev...
Infoblox delivers Actionable Network Intelligence to enterprise, government, and service provider customers around the world. They are the industry leader in DNS, DHCP, and IP address management, the category known as DDI. We empower thousands of organizations to control and secure their networks from the core-enabling them to increase efficiency and visibility, improve customer service, and meet compliance requirements.
With major technology companies and startups seriously embracing Cloud strategies, now is the perfect time to attend 21st Cloud Expo October 31 - November 2, 2017, at the Santa Clara Convention Center, CA, and June 12-14, 2018, at the Javits Center in New York City, NY, and learn what is going on, contribute to the discussions, and ensure that your enterprise is on the right path to Digital Transformation.
SYS-CON Events announced today that N3N will exhibit at SYS-CON's @ThingsExpo, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. N3N’s solutions increase the effectiveness of operations and control centers, increase the value of IoT investments, and facilitate real-time operational decision making. N3N enables operations teams with a four dimensional digital “big board” that consolidates real-time live video feeds alongside IoT sensor data a...
Amazon is pursuing new markets and disrupting industries at an incredible pace. Almost every industry seems to be in its crosshairs. Companies and industries that once thought they were safe are now worried about being “Amazoned.”. The new watch word should be “Be afraid. Be very afraid.” In his session 21st Cloud Expo, Chris Kocher, a co-founder of Grey Heron, will address questions such as: What new areas is Amazon disrupting? How are they doing this? Where are they likely to go? What are th...
In his Opening Keynote at 21st Cloud Expo, John Considine, General Manager of IBM Cloud Infrastructure, will lead you through the exciting evolution of the cloud. He'll look at this major disruption from the perspective of technology, business models, and what this means for enterprises of all sizes. John Considine is General Manager of Cloud Infrastructure Services at IBM. In that role he is responsible for leading IBM’s public cloud infrastructure including strategy, development, and offering ...
Digital transformation is changing the face of business. The IDC predicts that enterprises will commit to a massive new scale of digital transformation, to stake out leadership positions in the "digital transformation economy." Accordingly, attendees at the upcoming Cloud Expo | @ThingsExpo at the Santa Clara Convention Center in Santa Clara, CA, Oct 31-Nov 2, will find fresh new content in a new track called Enterprise Cloud & Digital Transformation.
SYS-CON Events announced today that NetApp has been named “Bronze Sponsor” of SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. NetApp is the data authority for hybrid cloud. NetApp provides a full range of hybrid cloud data services that simplify management of applications and data across cloud and on-premises environments to accelerate digital transformation. Together with their partners, NetApp emp...
Smart cities have the potential to change our lives at so many levels for citizens: less pollution, reduced parking obstacles, better health, education and more energy savings. Real-time data streaming and the Internet of Things (IoT) possess the power to turn this vision into a reality. However, most organizations today are building their data infrastructure to focus solely on addressing immediate business needs vs. a platform capable of quickly adapting emerging technologies to address future ...
Most technology leaders, contemporary and from the hardware era, are reshaping their businesses to do software. They hope to capture value from emerging technologies such as IoT, SDN, and AI. Ultimately, irrespective of the vertical, it is about deriving value from independent software applications participating in an ecosystem as one comprehensive solution. In his session at @ThingsExpo, Kausik Sridhar, founder and CTO of Pulzze Systems, will discuss how given the magnitude of today's applicati...
As popularity of the smart home is growing and continues to go mainstream, technological factors play a greater role. The IoT protocol houses the interoperability battery consumption, security, and configuration of a smart home device, and it can be difficult for companies to choose the right kind for their product. For both DIY and professionally installed smart homes, developers need to consider each of these elements for their product to be successful in the market and current smart homes.
SYS-CON Events announced today that Avere Systems, a leading provider of enterprise storage for the hybrid cloud, will exhibit at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 - Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Avere delivers a more modern architectural approach to storage that doesn't require the overprovisioning of storage capacity to achieve performance, overspending on expensive storage media for inactive data or the overbui...
Widespread fragmentation is stalling the growth of the IIoT and making it difficult for partners to work together. The number of software platforms, apps, hardware and connectivity standards is creating paralysis among businesses that are afraid of being locked into a solution. EdgeX Foundry is unifying the community around a common IoT edge framework and an ecosystem of interoperable components.
SYS-CON Events announced today that Avere Systems, a leading provider of hybrid cloud enablement solutions, will exhibit at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Avere Systems was created by file systems experts determined to reinvent storage by changing the way enterprises thought about and bought storage resources. With decades of experience behind the company’s founders, Avere got its ...
High-velocity engineering teams are applying not only continuous delivery processes, but also lessons in experimentation from established leaders like Amazon, Netflix, and Facebook. These companies have made experimentation a foundation for their release processes, allowing them to try out major feature releases and redesigns within smaller groups before making them broadly available. In his session at 21st Cloud Expo, Brian Lucas, Senior Staff Engineer at Optimizely, will discuss how by using...
In this strange new world where more and more power is drawn from business technology, companies are effectively straddling two paths on the road to innovation and transformation into digital enterprises. The first path is the heritage trail – with “legacy” technology forming the background. Here, extant technologies are transformed by core IT teams to provide more API-driven approaches. Legacy systems can restrict companies that are transitioning into digital enterprises. To truly become a lead...
SYS-CON Events announced today that CAST Software will exhibit at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 - Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. CAST was founded more than 25 years ago to make the invisible visible. Built around the idea that even the best analytics on the market still leave blind spots for technical teams looking to deliver better software and prevent outages, CAST provides the software intelligence that matter ...
SYS-CON Events announced today that Daiya Industry will exhibit at the Japanese Pavilion at SYS-CON's 21st International Cloud Expo®, which will take place on Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA. Ruby Development Inc. builds new services in short period of time and provides a continuous support of those services based on Ruby on Rails. For more information, please visit https://github.com/RubyDevInc.