1 / 33

CONNECT 4.0 Technical Deep Dive

CONNECT 4.0 Technical Deep Dive. February 19, 2013. Introduction. Brian Humphrey CONNECT Architect Matt Weaver CONNECT Lead Developer. Webinar Technical Details. During discussion time, “raise hand” to speak. What is the largest file size I can stream using CONNECT 4.0?.

iren
Download Presentation

CONNECT 4.0 Technical Deep Dive

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. CONNECT 4.0Technical Deep Dive February 19, 2013

  2. Introduction Brian Humphrey CONNECT Architect Matt Weaver CONNECT Lead Developer

  3. Webinar Technical Details During discussion time, “raise hand” to speak What is the largest file size I can stream usingCONNECT 4.0? Type questions in advance; click send Questions + answers appear in chat window

  4. CONNECT 4.0New Features • Increased throughput targeting increased numbers of PD, QD, RD, AD, and DS transactions • Exchange and process large payload sizes of up to 1 GB • Run CONNECT on additional application servers such as IBM WebSphere and Oracle WebLogic to meet their environment needs • More comprehensive event logging and metric data • Ability to determine the state of a transaction across messages in order to better review and analyze the operation of CONNECT and adopters’ trading partners • Minimize deployment load by supporting a lightweight gateway which allows smaller server footprint and use of system resources • Support Direct messages to allow for greater adoption and exchange

  5. Agenda • Updated tech stack • Enables: • increased throughput, • large payload sizes, and • multi-app support • Improved performance • Large payloads • Event logging • How it works and how you can use it • Transaction logging • “Lightweight gateway” • Current users – changes to be noted • Direct

  6. Updated Tech Stack • Support for WebLogic, WebSphere, and GlassFish application servers • Deploy via an Enterprise Archive • Web service stack introduced to expand CONNECT’s capabilities • Apache CXF replaces Metro • Source code now at GitHub • Simplified code contribution process • Build with maven • Better dependency management • Replaces ant • Easier project setup

  7. Start developing • Get the CONNECT 4 Source • Checkout source: gitclone https://github.com/CONNECT-Solution/CONNECT.git. • Alternatively, create a fork of our repo and clone your fork: gitclone https://github.com/<your_git_hub_username>/CONNECT.git. • git checkout 4.0.0 • Compile Source • Mvn clean install • Request Enhancements or Log Issues • https://issues.connectopensource.org • Submit Code • https://codereview.connectopensource.org/ Follow the “how to contribute code” wiki page:https://developer.connectopensource.org/x/DwBcB

  8. Increased Throughput CONNECT 4.0 CONNECT 3.3 CONNECT 3.2.1 CONNECT 3.1 Achieved through: • Reduction in memory usage • ApacheCXF & OpenSAML • Reduced number of static classes • Fewer number of web services running • Removed redundant and duplicative code flows Document Submission PatientDiscovery Document Retrieve *These numbers are based on the same testing methodology performed during the CONNECT benchmark testing for release 3.3. Document Query 0 5 10 15 20 25 30 35 40 45 50 Messages per Second

  9. Large Payloads • Using Streaming Web Services using HTTP “Chunking” • Minor wsdl file change – does not affect interoperability. • “Over the wire” message is unchanged • File size limited only by network and server capabilities • No longer limited by memory available to the server • Backwards compatible • Up to limitations of partner gateway.

  10. Event Logging Goals and Data Points Two formal high level business goals: CONNECT provides the ability to count and produce durations for the following values: • Number of a given transaction type (PD, QD, RD, etc.) • Number of a given transaction group • Number of transactions from a specific gateway • Total duration for given transaction type • Total duration for a given transaction group CONNECT can track and report on the following data points: • Error • Performance • Transaction Type • Payload • Error Messages log (without PHI data)

  11. Event Logging • CONNECT captures lifecycle events for inbound and outbound messages • Event logging framework can be extended to: • Add new event types • Record events in different manners • Customized what details are recorded

  12. State Diagram for Inbound Message

  13. State Diagram for Outbound Messages

  14. Event Class Diagram

  15. EventLogger Class Diagram

  16. Event Configuration

  17. EventFactoryConfig.xml <bean name="eventmanager" class="gov.hhs.fha.nhinc.event.EventManager" factory-method="getInstance" /> <alias alias="eventfactory" name="baseeventfactory"/> <bean name="baseeventfactory" class="gov.hhs.fha.nhinc.event.EventFactory"/>

  18. Transaction Logging Transaction Logging Example Database and log output for a related transaction chain (Patient Discovery, Document Query, and Document Retrieve messages as a single transaction) Note that there are two transaction entries logged for each service The response Nhin message ID was logged based on its RelatesTo message ID

  19. “Lightweight Gateway” • Reduction of endpoints • “Entity” now called “Standard” (“Pass-through” remains) • Configurable

  20. Document Query Provided Interfaces

  21. applicationContext.xml <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer”> <property name="ignoreResourceNotFound" value="true"/> <property name="locations”> <list> <value>classpath:documentquery.properties</value> <value>file:///${nhinc.properties.dir}/gateway.properties</value> <value>classpath:documentquery-test.properties</value> </list> </property> </bean>

  22. applicationContext.xml (continued) <bean id="nhinDQ” class="gov.hhs.fha.nhinc.docquery._20.nhin.DocQuery”> <property name="inboundDocQuery"> <bean class=“{docquery.inboundDocQuery}" /> </property> </bean>

  23. Property files • gateway.properties: # docquery.inboundDocQuery=\ gov.hhs.fha.nhinc.docquery.inbound.PassthroughInboundDocQuery • src/main/resources/docquery.properties: docquery.inboundDocQuery=\ gov.hhs.fha.nhinc.docquery.inbound.StandardInboundDocQuery

  24. Direct SMTP message transaction CONNECT leveraged Direct Project RI How to use CONNECT Direct: • Configure your own organization’s mail server • Use your regular mail client • Or your EMR’s mail client • Or, use SOAP+XDR Tool for Stage 2 Meaningful Use

  25. Direct Deployment

  26. Join Us for Sprint Review + Planning Join us for sprint review and planning sessions, every other Monday, 10am-noon ET. The CONNECT product team will share the work of the last sprint for community review and feedback. We’ll then transition into a high-level planning session to set the themes for the coming sprint, in the context of the product roadmap. Community input and insights are welcome, so please join us! The meeting will start with a review of the work accomplished during the past sprint which leads into a planning discussion for the upcoming sprint, we flow from one topic to another based on content, questions and conversation. Sprint Review + Planning: Every other Monday 10am-12pm ET (next one: Feb 24)Tel: 646-216-4772 866-946-0485 Participant Code: 922 914 63Web: https://arkadin.webex.com/arkadin/j.php?J=703876882 (meeting id 703 876 882)

  27. Upcoming Events February 11, 2013CONNECT Release 4.0 February 25, 2013 (10am ET)Next Sprint Review + Planning meeting March 4 - 7, 2013 HIMSS Interoperability Showcase demo Spring 2013 (date to come, D.C. area)CONNECT User Group Meeting 4.0

  28. More Details on CONNECT https://developer.connectopensource.org/display/CONNECT40 https://github.com/CONNECT-Solution/CONNECT/tree/4.0.0 http://issues.connectopensource.org http://www.connectopensource.org/developer-resources/forums/developer-forum Release info: GitHub: JIRA: Forums:

  29. Discussion Questions? Comments?

  30. Webinar Technical Details During discussion time, “raise hand” to speak What is the largest file size I can stream usingCONNECT 4.0? Type questions in advance; click send Questions + answers appear in chat window

  31. Contact Information Please post questions on the CONNECT Release Webinars Forum: http://www.connectopensource.org/developer-resources/forums CONNECT Inbox connect@hhs.gov

  32. Important Links Webinar Recording, Q & A, Slides: http://www.connectopensource.org/about/events/connect-webinar-v4-021913 CONNECT Forums: http://www.connectopensource.org/developer-resources/forums

  33. Thank you for participating.

More Related