Distributing Configuration with Apache Tamaya

Total Page:16

File Type:pdf, Size:1020Kb

Distributing Configuration with Apache Tamaya Configure Once, run everyhere! Configuration with Apache Tamaya BASEL BERN BRUGG DÜSSELDORF FRANKFURT A.M. FREIBURG I.BR. GENF HAMBURG KOPENHAGEN LAUSANNE MÜNCHEN STUTTGART WIEN ZÜRICH About Me Anatole Tresch Principal Consultant, Trivadis AG (Switzerland) Star Spec Lead Technical Architect, Lead Engineer PPMC Member Apache Tamaya @atsticks [email protected] [email protected] 6.09.16 Configure once, run everywhere 2 Agenda ● Motivation ● Requirements ● The API ● Configuration Backends ● Demo ● Extensions 6.09.16 Configure once, run everywhere 3 Motivation 6.09.16 Configure once, run everywhere 4 What is Configuration ? Simple Key/value pairs? Typed values? 6.09.16 Configure once, run everywhere 5 When is Configuration useful? Use Cases? 6.09.16 Configure once, run everywhere 6 How is it stored? Remotely or locally? Classpath, file or ...? Which format? All of the above (=multiple sources) ? 6.09.16 Configure once, run everywhere 7 When to configure? Develpment time ? Build/deployment time? Startup? Dynamic, anytime? 6.09.16 Configure once, run everywhere 8 Configuration Lifecycle ? Static ? Refreshing ? Changes triggered ? 6.09.16 Configure once, run everywhere 9 Do I need a runtime ? Java SE? Java EE? OSGI? 6.09.16 Configure once, run everywhere 10 Requirements 6.09.16 Bezeichnung Präsentation Requirements ● Developer‘s Perspective ● Architectural/Design Requirements ● Operational Aspects ● Other Aspects 6.09.16 Configure once, run everywhere 12 Developer‘s Requirements ● Easy to use. ● Developers want defaults. ● Developers don‘t care about the runtime (for configuration only). ● Developers are the ultimate source of truth ● Type Safety 6.09.16 Configure once, run everywhere 13 Architectural/Design Requirements Decouple code that consumes configuration from ● Backends Used ● Storage Format ● Distribution ● Lifecycle and versioning ● Security Aspects 6.09.16 Configure once, run everywhere 14 Operational‘s Requirements ● Enable Transparency: ● What configuration is available ? ● What are the current values and which sources provided the value ? ● Documentation ● Manageable: ● Configuration changes without redeployment or restart. ● Solution must integrate with existing environment 6.09.16 Configure once, run everywhere 15 Other Aspects ● Support Access Constraints and Views ● No accidential logging of secrets ● Dynamic changes ● Configuration Validation 6.09.16 Configure once, run everywhere 16 Accessing Configuration The API 6.09.16 Bezeichnung Präsentation API Requirements ● Leverage existing functionality where useful ● Only one uniform API for access on all platforms! ● Defaults provided by developer during development (no interaction with operations or external dependencies) 6.09.16 Configure once, run everywhere 18 Existing Mechanisms ● Environment Properties ● System Properties ● CLI arguments ● Properties, xml-Properties 6.09.16 Configure once, run everywhere 19 Dependencies - API & Core <dependency> <groupId>org.apache.tamaya</groupId> <artifactId>tamaya-api</artifactId> <version>0.2-SNAPSHOT</version> </dependency> <dependency> <groupId>org.apache.tamaya</groupId> <artifactId>tamaya-core</artifactId> <version>0.2-SNAPSHOT</version> </dependency> 6.09.16 Configure once, run everywhere 20 Programmatic API ● Configuration Add dependency config = org.apache.tamaya:core: ConfigurationProvider. 0.2-incubatinggetConfiguration(); ● // Add single Config property to META-INF/javaconfiguration.properties access String● name = config.getOrDefault("name", "John"); GO! int ChildNum = config.get("childNum", int.class); // Multi property access Map<String,String> properties = config.getProperties(); // Templates (provided by extension) MyConfig config = ConfigurationInjection.getConfigurationInjector() .getConfig(MyConfig.class); 6.09.16 Configure once, run everywhere 21 Dependencies – Injection SE <dependency> <groupId>org.apache.tamaya.ext</groupId> <artifactId>tamaya-injection-api</artifactId> <version>0.2-SNAPSHOT</version> </dependency> <dependency> <groupId>org.apache.tamaya.ext</groupId> <artifactId>tamaya-injection</artifactId> <version>0.2-SNAPSHOT</version> </dependency> 6.09.16 Configure once, run everywhere 22 @Config(value=¹admin.serverª, defaultValue=ª127.0.0.1ª) private String server; @Config(value=ªadmin.portª, defaultValue=ª8080ª) private int port; @Config(value=ªadmin.connectionsª) private int connections = 5; @Config(¹addressª) MyTenantMyTenant tt == newnew MyTenant();MyTenant(); ConfigurationInjectionConfigurationInjection private Address address; .getConfigurationInjector().getConfigurationInjector() .configure(t);.configure(t); 6.09.16 Configure once, run everywhere 23 Configuration Backends 6.09.16 Bezeichnung Präsentation Configuration Backends ● Support existing mechanisms OOTB ● Provide a simple SPI for (multiple) property sources ● Define a mechanism to prioritize different property sources ● Allow different strategies to combine values ● Support Filtering ● Support Type Conversion 6.09.16 Configure once, run everywhere 25 So what is a property source ? 6.09.16 Configure once, run everywhere 26 PropertySource public interface PropertySource { ● Add dependency org.apache.tamaya:core:PropertyValue get(String key); 0.2-incubating Map<String,String> getProperties(); ● Addboolean Config isScannable(); to META-INF/java StringMap<String,String> getName(); getProperties();configuration.properties int getOrdinal(); ● GO! } public final class PropertyValue{ public String getKey(); public String getValue(); public String get(String key); public Map<String,String> getConfigEntries(); ... } 6.09.16 Configure once, run everywhere 27 Are there predefined property sources ? 6.09.16 Configure once, run everywhere 28 Of course. 6.09.16 Configure once, run everywhere 29 ● System & Environment Properties ● (CLI Arguments) ● Files: ${configDir}/*.properties ● Classpath Resources: /META-INF/javaconfiguration.properties 6.09.16 Configure once, run everywhere 30 And how about remote configuration…? Especially with Containers? 6.09.16 Configure once, run everywhere 31 <dependency> <groupId>org.apache.tamaya.ext</groupId> <artifactId>tamaya-etcd</artifactId> Remote configuration <version>...</version> </dependency> ● Configuration is read from remote source, e.g. ● Etcd cluster ● Consul cluster ● Any Web URL Service Location Layer ● ... Configuration Cluster 6.09.16 Configure once, run everywhere 32 What kind of runtime I need ? ● In fact, it doesn‘t matter ! Configure once, run everywhere ! Java EE Vertx.io Spring Tamaya Tamaya Tamaya Java SE TomEE OSGI Tamaya Tamaya Tamaya Configuration Cluster 6.09.16 Configure once, run everywhere 33 Excourse: Configuring Containers ● Configuration on deployment by environment properties: docker run -e stage prod -d -n MyApp user/image ● or Dockerfile/Docker Image: FROM java:8-jre ... ENV stage prod 6.09.16 Configure once, run everywhere 34 How to add custom configuration ? 6.09.16 Configure once, run everywhere 35 Other files... 6.09.16 Configure once, run everywhere 36 Or resources... 6.09.16 Configure once, run everywhere 37 My self-written super fancy config database ? 6.09.16 Configure once, run everywhere 38 Whatever I like ? 6.09.16 Configure once, run everywhere 39 Use the SPI ! 6.09.16 Configure once, run everywhere 40 PropertySource Property sources ● Mostly map to exact one file, resource or backend ● Have a unique name ● Must be thread safe ● Can be dynamic ● Provide an ordinal ● Can be scannable 6.09.16 Configure once, run everywhere 41 PropertySource – Example public class MyPropertySource extends BasePropertySource{ ● Add private dependency Map<String,String> props = new HashMap<>(); public SimplePropertySource() throws IOException { URL url = getClass().getClassLoader().getResource( ª/META-INF/myFancyConfig.xmlª); // read config properties into props ... } @Override public String getName() { return ª/META-INF/myFancyConfig.xmlª; }; @Override public Map<String, String> getProperties() { return props; } } 6.09.16 Configure once, run everywhere 42 PropertySource - Registration ●● ByAdd default, dependency register it using the java.util.ServiceLoader → /META-INF/services/org.apache.tamaya.spi.PropertySource MyPropertySource 6.09.16 Configure once, run everywhere 43 PropertySource Provider Property source provider ● Allow dynamic registration of multiple property sources ● E.g. all files found in a config directory ● Are evaluated once and then discarded ● Are also registered using the ServiceLoader. 6.09.16 Configure once, run everywhere 44 PropertySourceProvider ● public Add interface dependency PropertySourceProvider{ public Collection<PropertySource> getPropertySources(); } 6.09.16 Configure once, run everywhere 45 More SPI artifacts Furthermore Tamaya uses ● Filters for filtering values evaluated (remove, map, change) ● Converters for converting String values to non-String types ● A ValueCombinationPolicy ● determines how values evaluated are combined to a final value (defaults to overriding) 6.09.16 Configure once, run everywhere 46 And how these pieces all fit together ? 6.09.16 Configure once, run everywhere 47 Apache Tamaya in 120 seconds... Configuration ConfigurationContext 1.Configuration = ordered list of PropertyConverter PropertySources 2.Properties found are combined using a PropertyFilters CombinationPolicy PropertyProviders y c i 3.Raw properties are filtered by PropertyFilter <provides> l o 4.For typed access PropertyConverters PropertySource P n o have to do work i t 5.Extensions add more features PropertySource a n i (discussed later) PropertySource
Recommended publications
  • Apache Tomcat 9
    Apache Tomcat 9 Preview Mark Thomas, September 2015 © 2015 Pivotal Software, Inc. All rights reserved. 2 Introduction Apache Tomcat committer since December 2003 – [email protected] Tomcat 8 release manager Member of the Servlet, WebSocket and EL expert groups Consultant Software Engineer @ Pivotal Currently focused on Apache Tomcat 9 © 2015 Pivotal Software, Inc. All rights reserved. 3 Agenda Specification mandated new features Tomcat specific new features Tomcat features removed Internal changes © 2015 Pivotal Software, Inc. All rights reserved. 4 Tomcat versions Minimum 1st Stable Tomcat JavaEE Servlet JSP EL WebSocket JASPIC EOL Java SE Release 5.x 4 1.4 2.4 2.0 N/A N/A N/A 08 2004 09 2012 6.x 5 5 2.5 2.1 2.1 N/A N/A 02 2007 12 2016 7.x 6 6 3.0 2.2 2.2 1.1 N/A 01 2011 TBD 8.x 7 7 3.1 2.3 3.0 1.1 N/A 02 2014 TBD 9.x 8 8 4.0 2.4? 3.1? 2.0? 1.1? Q4 2016? TBD © 2015 Pivotal Software, Inc. All rights reserved. 5 Specification changes © 2015 Pivotal Software, Inc. All rights reserved. 6 Specifications JavaEE 8 Key elements – HTML 5.0 – HTTP/2 – Simplification – Better integration for managed beans – Better infrastructure for the cloud © 2015 Pivotal Software, Inc. All rights reserved. 7 Specifications Servlet 4.0 Work started, stalled and is now starting again – Driven by JavaOne HTTP/2 Ease of use improvements – HttpFilter, default methods Clarifications – Starting to make progress © 2015 Pivotal Software, Inc.
    [Show full text]
  • Java EE 7 Overview and Status
    Java EE 7 Overview and Status Peter Doschkinow Senior Java Architect The following is intended to outline our general product direction. It is intended for information purposes only, and may not be incorporated into any contract. It is not a commitment to deliver any material, code, or functionality, and should not be relied upon in making purchasing decisions. The development, release, and timing of any features or functionality described for Oracle’s products remains at the sole discretion of Oracle. Agenda . Java EE 7 Revised Scope . HTML5 Technologies . Productivity Improvements . Status and Roadmap Productivity Java EE Past, Present, & Future & HTML5 Java EE 7 Lightweight JMS 2.0, Ease of Java EE 6 Batch, Development Caching, TX Interceptor, Web Java EE 5 Pruning, WebSocket, Services Extensibility JSON Ease of Dev, J2EE 1.4 CDI, JAX-RS JAX-RPC, Enterprise Robustness CMP/ BMP, Ease of JSR 88 Java Platform J2EE 1.3 Web Development, Services Annotations, Web J2EE 1.2 Mgmt, EJB 3.0, JPA, Web Profile Deployment, JSF, JAXB, Profile Servlet, JSP, CMP, Async JAX-WS, Servlet 3.0, JAX-RS 2.0 EJB, JMS, Connector Connector StAX, SAAJ EJB 3.1 Lite RMI/IIOP Architecture Dec 1999 Sep 2001 Nov 2003 May 2006 Dec 2009 Q2 2013 10 specs 13 specs 20 specs 23 specs 28 specs 32+ specs Java EE 7 Revised Scope . PaaS theme postponed for Java EE 8 . HTML5 Support – WebSocket, JSON – HTML5 forms and markup . Higher Productivity – Less Boilerplate – Richer Functionality – More Defaults Java EE 7 – Candidate JSRs PaaS Theme Postponed for Java EE 8 . Reasons – Not enough experience in tenants management, provisioning, deployment and elasticity implementation in Cloud environments – Not enough consensus and substance as of August 2012 .
    [Show full text]
  • Openjdk – the Future of Open Source Java on GNU/Linux
    OpenJDK – The Future of Open Source Java on GNU/Linux Dalibor Topić Java F/OSS Ambassador Blog aggregated on http://planetjdk.org Java Implementations Become Open Source Java ME, Java SE, and Java EE 2 Why now? Maturity Java is everywhere Adoption F/OSS growing globally Innovation Faster progress through participation 3 Why GNU/Linux? Values Freedom as a core value Stack Free Software above and below the JVM Demand Increasing demand for Java integration 4 Who profits? Developers New markets, new possibilities Customers More innovations, reduced risk Sun Mindshare, anchoring Java in GNU/Linux 5 License + Classpath GPL v2 Exception • No proprietary forks (for SE, EE) • Popular & trusted • Programs can have license any license • Compatible with • Improvements GNU/Linux remain in the community • Fostering adoption • FSFs license for GNU Classpath 6 A Little Bit Of History Jun 1996: Work on gcj starts Nov 1996: Work on Kaffe starts Feb 1998: First GNU Classpath Release Mar 2000: GNU Classpath and libgcj merge Dec 2002: Eclipse runs on gcj/Classpath Oct 2003: Kaffe switches to GNU Classpath Feb 2004: First FOSDEM Java Libre track Apr 2004: Richard Stallman on the 'Java Trap' Jan 2005: OpenOffice.org runs on gcj Mai 2005: Work on Harmony starts 7 Sun & Open Source Java RIs Juni 2005: Java EE RI Glassfish goes Open Source Mai 2006: First Glassfish release Mai 2006: Java announced to go Open Source November 2006: Java ME RI PhoneME goes Open Source November 2006: Java SE RI Hotspot und Javac go Open Source Mai 2007: The rest of Java SE follows suit 8 Status: JavaOne, Mai 2007 OpenJDK can be fully built from source, 'mostly' Open Source 25,169 Source code files 894 (4%) Binary files (“plugs”) 1,885 (8%) Open Source, though not GPLv2 The rest is GPLv2 (+ CP exception) Sun couldn't release the 4% back then as free software.
    [Show full text]
  • Java Magazine Is Provided on an “As Is” Basis
    //NOVEMBER/DECEMBER 2014 / THE INTERNET OF THINGS JAVA IS EVERYWHERE 13 29 20 HENRIK STÅHL INDUSTRIAL AUTOMATION JAVA: THE NEXT ON JAVA AND IOT WITH ROBOTS GENERATION ORACLE.COM/JAVAMAGAZINE //table of contents / 13 20 29 COMMUNITY JAVA: THE NEXT ROBOTS MAKE JAVA DEVELOPMENT GENERATION FACTORIES Teach kids to code SMARTER and give them tools Keba’s systems help FOR THE INTERNET for success. usher in the next OF THINGS industrial revolution. JAVA IN ACTION Oracle’s Henrik Ståhl discusses the Internet of Things for Java developers. Internet of Things JAVA TECH New theme icon. See how it works. COVER ART BY LINDY GROENING COMMUNITY JAVA TECH 45 55 03 35 Embedded Rich Client ABOUT US From the Editor New to Java A Smart-Home Platform Building Castles in the Sky 05 Code Java on the Raspberry Pi for the Mass Market Use JavaFX 3D to model historical Java Nation BlueJ brings Java SE 8 development Eclipse SmartHome bridges the gap treasures and more. JavaOne recap, plus news, directly to the Raspberry Pi. between tech-savvy users and average 62 people, events, and books 38 users to provide a smart-home platform Rich Client for everyone. Java Architect A Bridge from Java 2D to JavaFX 25 50 JCP Executive Series jdeps, Compact Profiles, Profit from the easy migration path The Java Advantage for IoT and Java Modularity Embedded provided by FXGraphics2D. Freescale’s Maulin Patel discusses the A look at the future of Java modularity The Device I/O API 67 Internet of Things (IoT) and how the JCP 41 A standard API for peripherals and Fix This helps to facilitate evolving technologies.
    [Show full text]
  • No. 18-956 Petitioner, V. Respondent. on Writ of Certiorari to the U.S
    No. 18-956 IN THE GOOGLE LLC, Petitioner, v. ORACLE AMERICA, INC., Respondent. On Writ of Certiorari to the U.S. Court of Appeals for the Federal Circuit JOINT APPENDIX VOLUME 1 PAGES 1-341 Thomas C. Goldstein E. Joshua Rosenkranz GOLDSTEIN & RUSSELL, P.C. ORRICK, HERRINGTON & 7475 Wisconsin Ave. SUTCLIFFE LLP Suite 850 51 West 52nd Street Bethesda, MD 20814 New York, NY 10019 (202) 362-0636 (212) 506-5000 [email protected] [email protected] Counsel of Record for Petitioner Counsel of Record for Respondent PETITION FOR A WRIT OF CERTIORARI FILED JAN. 24, 2019 CERTIORARI GRANTED NOV. 15, 2019 TABLE OF CONTENTS VOLUME 1 Docket Excerpts: U.S. Court of Appeals for the Federal Circuit, No. 13-1021 .................................. 1 Docket Excerpts: U.S. Court of Appeals for the Federal Circuit, No. 17-1118 .................................. 3 Docket Excerpts: U.S. District Court for the Northern District of California, No. 3:10-cv-03561 .................................................... 5 Transcript of 2012 Jury Trial Proceedings (excerpts) ............................................................... 30 Final Charge to the Jury (Phase One) and Special Verdict Form, Dist. Ct. Docs. 1018 & 1018-1 (Apr. 30, 2012) ....................................... 72 Special Verdict Form, Dist. Ct. Doc. 1089 (May 7, 2012) ......................................................... 95 Trial Exhibit 7803, Deposition Clips of Henrik Stahl Played by Video During Trial (Jan. 14, 2016) (excerpts) ...................................... 98 Order re 62 Classes and Interfaces, Dist. Ct. Doc. 1839 (May 6, 2016) ...................................... 103 Joint Filing Regarding Agreed Statement Regarding Copyrightability (ECF No. 1788), Dist. Ct. Doc. 1846 (May 7, 2016) ....................... 105 Transcript of 2016 Jury Trial Proceedings (excerpts) ............................................................. 109 Final Charge to the Jury (Phase One) and Special Verdict Form, Dist.
    [Show full text]
  • Creating a Java Platform Enterprise Appliance Using the Glassfish
    Creating a Java™ Platform, Enterprise Edition (Java EE Platform) Appliance Using GlassFish™ and OpenSolaris™ Peter Karlsson, Technology Evangelist Lee Chuk Munn, Staff Engineer Learn how we build a JavaEE application appliance Under funded Under pressure for One Appliance per GeekTM (OAPG) cause! 2008 JavaOneSM Conference | java.sun.com/javaone | 2 Agenda OpenSolaris™ Project / GlassFish Appliance OpenSolaris Project • Short Introduction to Solaris ZFS • (Another) Short Introduction to SMF GlassFish Application Server Appliance Features Overview • Installing Applications • Integration with SMF Summary 2008 JavaOneSM Conference | java.sun.com/javaone | 3 OpenSolaris/GlassFish Appliance 2008 JavaOneSM Conference | java.sun.com/javaone | 4 What is an Appliance? An instrument or device designed for a particular use or function • A solution to solving problem by enabling the proper function Typically hardware and software bundled and tightly integrated Example of appliance • Toaster • Wireless router 2008 JavaOneSM Conference | java.sun.com/javaone | 5 Criteria for an Appliance* Purpose • Scope – scope of operation • Design – native or packaged • Ends not means – what it achieves rather than how it is done Convenience • Ease of use – aim for plug-and-play • Simplicity – if you need to open it up, then it is not simple • Compatibility – harmony with the environment Value • Alignment – align to the business requirements • Cost – lower TCO and should cost less than sum of parts • Performance – does not only refer to speed but for achieving its
    [Show full text]
  • Presentation Title up to a Maximum of Three Lines Font
    The Script Bowl Featuring Groovy, JRuby, Jython and Scala Raghavan “Rags” N. Srinivas CTO, Technology Evangelism The Script Bowl: Groovy Style Guillaume Laforge VP Technology at G2One, Inc. Groovy Project Manager http://www.g2one.com Guillaume Laforge Groovy Project Manager • Co-author of the Groovy in Action best-seller Manning • JSR-241 Spec Lead, • VP Technology at G2One, Inc. standardizing the Groovy • Professional services around dynamic language in the JCP Groovy and Grails • http://www.g2one.com • Initiator of the Grails web application framework 2008 JavaOneSM Conference | java.sun.com/javaone | 3 Groovy is… An Open Source dynamic language for the Virtual Machine for the Java™ platform (Java Virtual Machine or JVM™ machine) No impedence mismatch with Java™ programming environment • Groovy uses a syntax much like Java programming language • Shares the same object / threading / security model as Java programming language • Uses the same APIs (regex, collections, strings…) • Compiles down to normal Java programming language bytecode Provides native syntax constructs • Lists, maps, regex, ranges Supports closures • Simpler than any proposals for Java programming language! Groovy simplifies the use of many Java programming language APIs • XML, Swing, JDBC™ API, unit testing & mocking, templating … 2008 JavaOneSM Conference | java.sun.com/javaone | 4 The Script Bowl: JRuby Charles Nutter Technical Lead, JRuby JRuby Co-Lead Charles Oliver Nutter Longtime developer of Java application environment (11+ yrs ) Engineer at Sun Microsystems
    [Show full text]
  • Java (Software Platform) from Wikipedia, the Free Encyclopedia Not to Be Confused with Javascript
    Java (software platform) From Wikipedia, the free encyclopedia Not to be confused with JavaScript. This article may require copy editing for grammar, style, cohesion, tone , or spelling. You can assist by editing it. (February 2016) Java (software platform) Dukesource125.gif The Java technology logo Original author(s) James Gosling, Sun Microsystems Developer(s) Oracle Corporation Initial release 23 January 1996; 20 years ago[1][2] Stable release 8 Update 73 (1.8.0_73) (February 5, 2016; 34 days ago) [±][3] Preview release 9 Build b90 (November 2, 2015; 4 months ago) [±][4] Written in Java, C++[5] Operating system Windows, Solaris, Linux, OS X[6] Platform Cross-platform Available in 30+ languages List of languages [show] Type Software platform License Freeware, mostly open-source,[8] with a few proprietary[9] compo nents[10] Website www.java.com Java is a set of computer software and specifications developed by Sun Microsyst ems, later acquired by Oracle Corporation, that provides a system for developing application software and deploying it in a cross-platform computing environment . Java is used in a wide variety of computing platforms from embedded devices an d mobile phones to enterprise servers and supercomputers. While less common, Jav a applets run in secure, sandboxed environments to provide many features of nati ve applications and can be embedded in HTML pages. Writing in the Java programming language is the primary way to produce code that will be deployed as byte code in a Java Virtual Machine (JVM); byte code compil ers are also available for other languages, including Ada, JavaScript, Python, a nd Ruby.
    [Show full text]
  • Javaone 2017
    JavaOne 2017 An Overview Paul Webber October 17, 2017 The Conference Oct 1 - 5 ● Friday, Sep 29, Java Champion Summit at Oracle HQ ● Saturday, Sep 30, JavaOne4Kids, Hilton Union Square ● Sunday - Wednesday, Sessions at Moscone West ● Thursday, Sessions at Marriott Marquis Java Champion Summit JC Summit Agenda 2016 ● Netbeans Update - Handed over to the Apache Foundation https://netbeans.org/community/apache-incubator.html ● JDK 9 (mid 2017) ● Java EE 8 (end of 2017) and Java EE 9 (end of 2018) ● Cloud PaaS ● Oracle IaaS ● Oracle Cloud ● Java Community Process JC Summit Agenda 2017 ● Java EE Update - Handed over to the Eclipse Foundation https://www.eclipse.org/org/foundation/ ● JDK Release Cycle - Twice a year - 18.3, 18.9, 19.3 etc. ○ Project Panama - Foreign Function Interface (VM level) ○ Project Valhalla - Specialized Generics and Value Types ○ Project Amber - Local-Variable Type Inference and Enhanced Enums ○ Project Loom - Continuations and Fibers (enhancing concurrency) ● Java Groups around the World ○ Even a Virtual JUG ● Java on Mobile ● Java Community Process JDK New Release Cycle Changes to the JDK Release Model by Aurelio Garcia-Ribeyro https://youtu.be/UeyyLielXsU JDK 9 Released! List of JEPs from the JSRs 102: Process API Updates 238: Multi-Release JAR Files 274: Enhanced Method Handles 110: HTTP 2 Client 240: Remove the JVM TI hprof Agent 275: Modular Java Application Packaging 143: Improve Contended Locking 241: Remove the jhat Tool 276: Dynamic Linking of Language-Defined Object Models 158: Unified JVM Logging 243: Java-Level
    [Show full text]
  • Java in a World of Containers
    CON4429 - Java in a World of Containers [email protected] @PaulSandoz [email protected] Director, Java Virtual Machine @MiKaelVidstedt Copyright © 2017, Oracle and/or its affiliates. All rights reserved. 1 Agenda Producing images and running containers with JDK 9 Size analysis of JDK DocKer Images A quicK looK at startup me Copyright © 2017, Oracle and/or its affiliates. All rights reserved. | 2 Java 8 DocKer image • Official Java 8 SE (Server JRE) available on the docKer store • See also DockerFiles on GitHub Copyright © 2017, Oracle and/or its affiliates. All rights reserved. | 3 In a world of containers we expect… • Many distribuTons of Java runTmes • Forces that push towards – Smaller images – Faster execuTon using less resources (and respecTng resource constraints) Copyright © 2017, Oracle and/or its affiliates. All rights reserved. | 4 Java has plans for a world of containers • Official OpenJDK builds will make it easier to distribute Java runTmes • Java 9 tooling can produce custom Java runTmes that are smaller • Current and future Java tooling will produce applicaon-specific Java runTmes that startup faster Copyright © 2017, Oracle and/or its affiliates. All rights reserved. | 5 Producing DocKer images with a JDK • Very easy to create a DockerFile that copies (or adds) a tarball of a JDK – A resulTng DocKer image will be large (> 300MB) • Not necessarily good for development or execuTon – More stuff than required to build or run an applicaon Copyright © 2017, Oracle and/or its affiliates. All rights reserved. | 6 JDK 9 is modular • JDK 9 is modular and introduces modules to the Java plaorm • A module is a set of pacKages designed for reuse • Modules improve the reliability and maintainability of your programs • JDK 9 is itself composed of 79 modules Copyright © 2017, Oracle and/or its affiliates.
    [Show full text]
  • 2007 Javaonesm Conference Word “BENEFIT” Is in Green Instead of Orange
    there are 3 cover versions: Prospect 1 (Java) It should say “... Save $200!” on the front and back cover. The first early bird pricing on the IFC and IBC should be “$2,495”, and the word “BENEFIT” is in orange. ADVANCE CONFERENCE GUIDE Prospect 2 (Non-Java) The front cover photo and text is different from Prospect 1. The text of the introduction Last Chance to Save $200! Register by April 4, 2007, at java.sun.com/javaone paragraphs on the IFC is also different, the 2007 JavaOneSM Conference word “BENEFIT” is in green instead of orange. Features Java Technology, Open Source, Web 2.0, Emerging Technologies, and More Don’t miss this year’s newly expanded content. Advance your development skills with hundreds of expert-led, in-depth technical sessions in nine tracks over four days: The back cover and the IBC are the same as Consumer Technologies | Java™ SE | Desktop | Java EE | Java ME Prospect 1. The Next-Generation Web | Open Source | Services and Integration | Tools and Languages How to navigate this brochure and easily find what you need... Alumni For other information for Home Conference Overview JavaOnePavilion this year’s Conference, visit java.sun.com/javaone. It should say “... Save $300!” on the front Registration Conference-at-a-Glance Special Programs and back cover. The first early bird pricing on Hyperlinks Bookmark Buttons Search Click on any of the underlined Use the bookmark tab to Click on the buttons at the top Pull down from the Edit menu and the IFC and IBC should be “$2,395”, and the links to visit specific web sites.
    [Show full text]
  • Java Security: a Ten Year Retrospective
    Java Security: A Ten Year Retrospective Li Gong Mozilla Online Ltd Beijing, China [email protected] Abstract— The first edition of Java (both the language and the inevitable leaks to the press, and behind the scenes efforts to platform) was released in 1995, which contained the all-or- keep things quiet while solutions were being rolled out. Sun nothing security access model. A mid-1997 paper I published Microsystems was an eager participant in this fight, and I in IEEE Micro laid out a vision for the future of Java security, found myself at numerous industry conferences sitting on the which notably included a model for fine-grained access control, same panel with Jim Roskind from Netscape and Barbara a crypto architecture, and a number of other security Fox from Microsoft, lobbing verbal missiles at and mechanisms. The first implementation of these features was deflecting unflattering comments from the floor to each officially released in late 1998 as part of the JDK 1.2 platform. other. I quietly chuckled much later when I quoted George Ten years on, the original vision of Java security was largely Bernard Shaw in my Java security book, who famously said realized and the overall architecture had in fact been carried “Security is the chief pretence of civilization.” But I am over to both the enterprise Java and mobile Java platforms. getting ahead of myself here. This paper reflects on lessons -- technical and otherwise -- learned in the process of designing and implementing the Java Soon after Java’s first release, a more scholarly debate on security architecture and in the aftermath of its release into the runtime security (a term that was mostly focused on Java but real world also generalized to include any mobile code) raged on the ACM Risks Forum [1], the most popular discussion forum Keywords-Java; security; least privilege; access control; safe on such topics that was founded and moderated by Peter G.
    [Show full text]