This Post is in continuation with my Previous post
SOA Interview Questions : Service Oriented Architecture Interview Questions Part 1
http://osb-dheeraj.blogspot.in/2016/02/soa-interview-questions-service.html
Can you Explain loose coupling, and How to achieve it ?
Loose coupling is an approach to interconnecting the components in a system or network so that those components, also called elements, depend on each other to the least extent practicable.
The Mediation pattern, using an enterprise service bus (ESB/OSB), will help in achieving
loose coupling to the highest level. It will establish independence between consumers and providers on all levels, including message formats (including SOAP, REST, XML, binary) and transport protocols (including HTTP, FTP, JMS, File, MQ, JCA Adapter, DB etc).
Architecturally speaking this means the separation of concerns between consumers and providers on the transport, message type, and message format levels.
How do I integrate my Legacy applications with SOA ?
Legacy applications are frequently at the core of your IT enterprise. With the right skills and tools, you need to identify discrete elements within your legacy applications and “wrap” them in standards-based interfaces and use them as services within your SOA. It is possible to integrate your legacy system with other system using SOA applications.
SOA and ESB technology provides support to most available message formats (including SOAP, REST, XML, binary, CSV, Text etc) and transport protocols (including HTTP, FTP, JMS, File, MQ, JCA Adapter, DB etc).
The Service of a SOA should be engineered as stateless or stateful ?
Service should be stateless. It may have a context within its stateless execution, but it will not have an intermediary state waiting for an event or a call-back. The retention of state-related data must not extend beyond a request/response on a service. This is because state management consumes a lot of resources, and this can affect the scalability and availability that are required for a reusable service.
How does the ESB/OSB fits in an Enterprise IT system ?
The Enterprise Service Bus is a core element of any SOA. ESBs provide the “any to any” connectivity between services within your own company, and beyond your business to connect to your trading partners and External service provoders. But SOA does not stop at just implementing an ESB. Depending on what your goals are, you may want to use an ESB to connect other services within your SOA such as information services, interaction services and business process management services. Additionally, you will need to consider development services and IT service management services. The SOA reference architecture can help you lay out an SOA environment that meets your needs and priorities. The ESB is part of this reference architecture and provides the backbone of an SOA but it should not be considered an SOA by itself.
Challenges faced in SOA adoption
While implementing a service-oriented architecture, a company faces below challenges :
- Service identification. What is a service? What is the business functionality to be provided by a given service? What is the optimal granularity of the service?
- Service location. Where should a service be located within the enterprise or outside Enterprise Firewall over Internet ?
- Service packaging. How is existing functionality within legacy mainframe systems to be re-engineered or wrapped into reusable services?
- Service orchestration. How are composite services to be orchestrated?
- Service routing. How are requests from service consumers to be routed to the appropriate service and/or service domain?
- Service governance. How will the enterprise exercise governance processes to administer and maintain services?
- Service messaging standards adoption. How will the enterprise adopt a given standard consistently?
What is Web Service ?
A Web service has an interface described in a machine-processable format (specifically WSDL). Other systems interact with the Web service in a manner prescribed by its description using SOAP (Simple Object Access Protocol) messages, typically conveyed using HTTP with an XML serialization in conjunction with other Web-related standards.
We can identify two major classes of Web services:
1. REST-compliant Web services, in which the primary purpose of the service is to manipulate representations of Web resources using a uniform set of stateless operations.
2. Arbitrary Web services, in which the service may expose an arbitrary set of operations.
A Web service has an interface described in a machine-processable format (specifically WSDL). Other systems interact with the Web service in a manner prescribed by its description using SOAP (Simple Object Access Protocol) messages, typically conveyed using HTTP with an XML serialization in conjunction with other Web-related standards.
We can identify two major classes of Web services:
1. REST-compliant Web services, in which the primary purpose of the service is to manipulate representations of Web resources using a uniform set of stateless operations.
2. Arbitrary Web services, in which the service may expose an arbitrary set of operations.
While identifying services which one is better – top-down and bottom-up methodologies encourages re-use and maintenance?
Since the top-down approach is business-driven it can be practical to separate the different concerns of business and IT on different plans, providing a common ground in between. So in most situations it the most appropriate if you want to improve reuse and ROI in the medium/longterm.
What do you mean by SOA governance? What are the functions of governance?
SOA governance is a concept used for activities related to exercising control over services in service-oriented architecture (SOA) solutions. One viewpoint, from IBM and others, is that SOA governance is an extension (subset) of IT governance which itself is an extension of corporate governance.
Some key activities that are often mentioned as being part of SOA governance are:
11. Managing the portfolio of services: This includes planning development of new services and updating current services.
22. Managing the service lifecycle: This is meant to ensure that updates of services do not disturb current services to the consumers.
33. Using policies to restrict behavior: Consistency of services can be ensured by having the rules applied to all the created services.
44. Monitoring performance of services: The consequences of service downtime or underperformance can be severe because of service composition. Therefore action can be taken instantly when a problem occurs by monitoring service performance and availability.
1. SOA Interview Questions : Service Oriented Architecture Interview Questions Part 3
http://osb-dheeraj.blogspot.com/2016/02/soa-interview-questions-service_21.html
2. SOA Interview Questions : Service Oriented Architecture Interview Questions Part 4
http://osb-dheeraj.blogspot.com/2016/02/soa-interview-questions-service_77.html
http://osb-dheeraj.blogspot.in/2016/02/soa-interview-questions-service_15.html