incubator-cvs mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From Apache Wiki <wikidi...@apache.org>
Subject [Incubator Wiki] Update of "GeodeProposal" by RomanShaposhnik
Date Sun, 12 Apr 2015 18:37:46 GMT
Dear Wiki user,

You have subscribed to a wiki page or wiki category on "Incubator Wiki" for change notification.

The "GeodeProposal" page has been changed by RomanShaposhnik:
https://wiki.apache.org/incubator/GeodeProposal

New page:
== Abstract ==
Geode is a data management platform that provides real-time, consistent access to data-intensive
applications throughout widely distributed cloud architectures.

Geode pools memory (along with CPU, network and optionally local disk) across multiple processes
to manage application objects and behavior. It uses dynamic replication and data partitioning
techniques for high availability, improved performance, scalability, and fault tolerance.
Geode is both a distributed data container and an in-memory data management system providing
reliable asynchronous event notifications and guaranteed message delivery.

== Proposal ==
The goal of this proposal is to bring the core of Pivotal Software, Inc.’s (Pivotal) Pivotal
GemFireⓇ codebase into the Apache Software Foundation (ASF) in order to build a vibrant,
diverse and self-governed open source community around the technology. Pivotal will continue
to market and sell Pivotal GemFire based on Geode. Geode and Pivotal GemFire will be managed
separately. This proposal covers the Geode source code (mainly written in Java), Geode documentation
and other materials currently available on GitHub.

While Geode is our primary choice for a name of the project, in order to facilitate PODLINGNAMESEARCH
we have come up with two alternatives:
  * Haptic
  * FIG

== Background ==
GemFire is an extremely mature and robust product that can trace its legacy all the way back
to one of the first Object Databases for Smalltalk: GemStone. The GemFire code base has been
maintained by the same group of engineers as a closed source project. Because of that, even
though the engineers behind GemFire are the de-facto knowledge leaders for distributed in-memory
management, they have had little exposure to the open source governance process.    The original
company developing GemStone and GemFire was acquired by VMWare in 2010 and later spun off
as part of Pivotal Software in 2013. Today GemFire is used by over 600 enterprise customers.
An example deployment includes China National Railways that uses Pivotal GemFire to run railway
ticketing for the entire country of China with a 10 node cluster that manages 2 gigabytes
"hot data" in memory, and 10 backup nodes for high availability and elastic scale.

== Rationale ==
Modern-day data management architectures require a robust in-memory data grid solution to
handle a variety of use cases, ranging from enterprise-wide caching to real-time transactional
applications at scale. In addition, as memory size and network bandwidth growth continues
to outpace those of disk, the importance of managing large pools of RAM at scale increases.
It is essential to innovate at the same pace and Pivotal strongly believes that in the Big
Data space, this can be optimally achieved through a vibrant, diverse, self-governed community
collectively innovating around a single codebase while at the same time cross-pollinating
with various other data management communities. ASF is the ideal place to meet these ambitious
goals.

== Initial Goals ==
Our initial goals are to bring Geode into the ASF, transition internal engineering processes
into the open, and foster a collaborative development model according to the "Apache Way."
Pivotal plans to develop new functionality in an open, community-driven way. To get there,
the existing internal build, test and release processes will be refactored to support open
development.

== Current Status ==
Currently, the project code base is licensed for evaluation purposes and is available for
download from Pivotal.io (https://network.pivotal.io/products/project-geode). The documentation
and wiki pages are available as public GitHub repositories under Project Geode organization
on GitHub (https://github.com/project-geode). Although Pivotal GemFire was developed as a
proprietary, closed-source product, the internal engineering practices adopted by the development
team lend themselves well to an open, collaborative and meritocratic environment.

The Pivotal GemFire team has always focused on building a robust end user community of paying
and non-paying customers. The existing documentation along with StackOverflow and other similar
forums are expected to facilitate conversions between our existing users so as to transform
them into an active community of Geode members, stakeholders and developers.

=== Meritocracy ===
Our proposed list of initial committers include the current GemFire R&D team, Pivotal
Field Engineers, and several existing customers and partners. This group will form a base
for the broader community we will invite to collaborate on the codebase. We intend to radically
expand the initial developer and user community by running the project in accordance with
the "Apache Way". Users and new contributors will be treated with respect and welcomed. By
participating in the community and providing quality patches/support that move the project
forward, they will earn merit. They also will be encouraged to provide non-code contributions
(documentation, events, community management, etc.) and will gain merit for doing so. Those
with a proven support and quality track record will be encouraged to become committers.

=== Community ===
If Geode is accepted for incubation, the primary initial goal will be transitioning the core
community towards embracing the Apache Way of project governance. We would solicit major existing
contributors to become committers on the project from the start.

=== Core Developers ===

While a few core developers are skilled in working in openly governed Apache communities.
Most of the core developers are currently NOT affiliated with the ASF and would require new
ICLAs before committing to the project.

=== Alignment ===
The following existing ASF projects can be considered when reviewing Geode proposal:

Apache HadoopⓇ is a distributed storage and processing framework for very large datasets
focusing primarily on batch processing for analytic purposes. Geode is a data management platform
that provides real-time, consistent, and transactional access to data-intensive applications.
Our roadmap includes plans to provide close integration with HDFS.

Apache HBase offers tabular data stored in Hadoop based on the Google Bigtable model.  HBase
uses a key-based partitioning scheme and column family data model that can work well for scan
intensive workloads but is not as broadly applicable as the rich object model, OQL querying,
and hash partitioning provided by Geode.  Geode will use the HFile format for storing data
in HDFS.

Apache Spark is a fast engine for processing large datasets, typically from a Hadoop cluster,
and performing batch, streaming, interactive, or machine learning workloads.  Geode supports
high throughput streaming ingest application patterns and data parallel algorithms. Geode
also ensures that data is highly available through redundancy while Spark recovers from faults
using RDD lineage recomputation.  Our roadmap includes plans for providing integration with
the Spark platform.

Apache Ignite (incubating) offers distributed in-memory processing capabilities which in some
ways overlap with Geode.  However, Geode has been in this field for more than 10 years and
the product API's, design, and implementation details are quite different.  In addition, Geode
offers highly optimized shared-nothing disk persistence for in-memory data which does not
appear to be available with Ignite.

Apache Cassandra is a highly scalable, distributed key-value store that focuses on eventual
consistency.  It uses log-structured merge trees to handle write-heavy workloads.  The Geode
distributed in-memory cluster provides highly performant and advanced capabilities including
network partition detection and recovery, version-based state synchronization and conflict
resolution, and single IO disk operations.

Apache ActiveMQ and its sub project Apache Apollo offers a powerful message queue framework
that is being considered for an open source implementation of Geode's WAN replication capabilities.

Apache Storm is a streaming engine that processes events through a directed graph of computation.
It requires Apache Zookeeper for coordination and Apache Kafka to reliably store the streaming
data source. Geode provides builtin capabilities for these functions. In addition, Geode offers
data locality for related entities and in-process access to reference data typically used
during processing.

Apache Kafka offers distributed and durable publish-subscribe messaging. Geode expands beyond
publish-subscribe messaging to support data oriented notifications delivered from highly available,
fault tolerant event queues that can be easily correlated to related data for further processing.
Apache Samza is a distributed processing framework heavily dependent on Apache Kafka and Apache
Hadoop YARN for messaging and distributed fault-tolerant processing.  Geode is data source
agnostic and leverages its own technology and implementation for such use cases.

== Known Risks ==
Development has been sponsored mostly by a single company (or its predecessors) thus far and
coordinated mainly by the core Pivotal GemFire team.

For the project to fully transition to the Apache Way governance model, development must shift
towards the meritocracy-centric model of growing a community of contributors balanced with
the needs for extreme stability and core implementation coherency.

The tools and development practices in place for the Pivotal GemFire product are compatible
with the ASF infrastructure and thus we do not anticipate any on-boarding pains. Migration
from the current GitHub repository is also expected to be straightforward.

The project currently includes a modified version of the JGroups software toolkit. JGroups
was initially released under the LGPL license. Although we have complied with the terms of
the LGPL by making the modified source available, LGPL is classified as an incompatible license
by the ASF.  The JGroups project has since been re-licenced under ALv2 (see http://www.jgroups.org/license.html)
and we plan to engage with the licensor to overcome this license incompatibility. If the license
incompatibility cannot be overcome through our discussions with the licensor, we will need
to rework this portion of the project based upon a newer version of the JGroups toolkit or
via other alternative development efforts.

=== Orphaned products ===
Pivotal is fully committed to Pivotal GemFire and the product will continue to be based on
the Geode project. Moreover, Pivotal has a vested interest in making Geode succeed by driving
its close integration with sister ASF projects. We expect this to further reduces the risk
of orphaning the product.

=== Inexperience with Open Source ===
Pivotal has embraced open source software since its formation by employing contributors/committers
and by shepherding open source projects like Cloud Foundry, Spring, RabbitMQ and MADlib. Pivotal
also supports other open source projects such as Redis, Chorus, Groovy and Grails. We have
experience with the formation of vibrant communities around open technologies with the Cloud
Foundry Foundation.  Although some of the initial committers have not been developers on an
entirely open source, community-driven project, we expect to bring to bear the open development
practices that have proven successful on longstanding Pivotal open source projects to the
Geode project.  Additionally, several ASF veterans agreed to mentor the project and are listed
in this proposal. The project will rely on their guidance and collective wisdom to quickly
transition the entire team of initial committers towards practicing the Apache Way.

=== Homogeneous Developers ===
While most of the initial committers are employed by Pivotal, we have already seen a healthy
level of interest from our existing customers and partners. We intend to convert that interest
directly into participation and will be investing in activities to recruit additional committers
from other companies.

=== Reliance on Salaried Developers ===
Most of the contributors are paid to work in the Big Data space. While they might wander from
their current employers, they are unlikely to venture far from their core expertises and thus
will continue to be engaged with the project regardless of their current employers.

=== Relationships with Other Apache Products ===
As mentioned in the Alignment section, Geode may consider various degrees of integration and
code exchange with Apache Ignite (incubating), Apache Hadoop, Apache Storm, Apache Spark and
Apache Kafka/Samza. Given the success that the Pivotal GemFire product enjoyed as an embedded
service, we expect integration points to be inside and outside the project. We look forward
to collaborating with these communities as well as other communities under the Apache umbrella.

=== An Excessive Fascination with the Apache Brand ===
While we intend to leverage the Apache ‘branding’ when talking to other projects as testament
of our project’s ‘neutrality’, we have no plans for making use of Apache brand in press
releases nor posting billboards advertising acceptance of Geode into Apache Incubator.

== Documentation ==
See documentation for the current state of the project documentation available as part of
the GitHub repository at 
https://github.com/project-geode/docs and live at http://geode-docs.cfapps.io/

== Initial Source ==
Pivotal is releasing the source code for Geode under an Evaluation License at https://network.pivotal.io/products/project-geode
.  We encourage ASF community members interested in  this proposal to download the source
code, review and try out the software. 

== Source and Intellectual Property Submission Plan ==
As soon as Geode is approved to join Apache Incubator, the source code will be transitioned
via the Software Grant Agreement onto ASF infrastructure and in turn made available under
the Apache License, version 2.0.  We know of no legal encumberments that would inhibit the
transfer of source code to the ASF.

== External Dependencies ==

Embedded dependencies (relocated):
   * json
   * jgroups
   * joptsimple

Runtime dependencies:
   * antlr
   * classmate
   * commons-fileupload
   * commons-io
   * commons-lang
   * commons-modeler
   * fastutil
   * findbugs annotations
   * guava
   * jackson
   * jansi
   * javax.activation
   * javax.mail-api
   * javax.resource-api
   * javax.servlet-api
   * javax.transaction-api
   * jetty
   * jline
   * jna
   * json4s
   * log4j
   * mx4j
   * paranamer
   * scala
   * slf4j
   * snappy-java
   * spring
   * swagger

Module or optional dependencies:
   * None

Build only dependencies:
   * None

Test only dependencies:
   * cglib
   * hamcrest
   * jmock
   * junit
   * multithreadedtc
   * objenesis

Cryptography
N/A

== Required Resources ==

=== Mailing lists ===
  * private@geode.incubator.apache.org (moderated subscriptions)
  * commits@geode.incubator.apache.org
  * dev@geode.incubator.apache.org
  * issues@geode.incubator.apache.org
  * user@geode.incubator.apache.org        

=== Git Repository ===
https://git-wip-us.apache.org/repos/asf/incubator-geode.git

=== Issue Tracking ===
JIRA Project Geode (GEODE)

=== Other Resources ===

Means of setting up regular builds for Geode on builds.apache.org

== Initial Committers ==
  * Amey Barve
  * Adib Saikali
  * Alan Strait
  * Amogh Shetkar
  * Anil Gingade
  * Anilkumar Gingade
  * Anthony Baker
  * Ashvin Agrawal
  * Asif Shahid
  * Avinash Dongre
  * Barry Oglesby
  * Ben Reser
  * Bruce Schuchardt
  * Bruce Szalwinski
  * Catherine Johnson
  * Chip Childers
  * Christian Tzolov
  * Dan Smith
  * Darrel Schneider
  * Dave Muirhead
  * David Yozie
  * Dick Cavender
  * Edin Zulich
  * Eric Shu
  * Gideon Low
  * Greg Chase
  * Hemant Bhanawat
  * Henry Saputra
  * Hitesh Khamesra
  * Jacob Barrett
  * Jags Ramnarayan
  * Jan Iversen
  * Jason Huynh
  * Jens Deppe
  * Jianxia Chen
  * John Blum
  * Justin Erenkrantz
  * Ketan Deshpande
  * Kirk Lund
  * Kishor Bachhav
  * Konstantin Boudnik
  * Konstantin Ignatyev
  * Lise Storc
  * Luke Shannon
  * Lyndon Adams
  * Lynn Gallinat
  * Lynn Hughes-Godfrey
  * Mark Bretl
  * Michael Schubert
  * Namrata Thanvi
  * Neeraj Kumar
  * Nilkanth Patel
  * Qihong Chen
  * Rahul Diyewar
  * Randy May
  * Roman Shaposhnik
  * Severine Tymon
  * Shatarupa Nandi
  * Shirish Deshmukh
  * Sonal Agarwal
  * Soubhik Chakraborty
  * Sourabh Bansod
  * Stephane Maldini
  * Stuart Williams
  * Sudhir Menon
  * Sunil Jigyasu
  * Supriya Pillai
  * Suranjan Kumar
  * Suyog Bhokare
  * Swapnil Bawaskar
  * Swati Sawant
  * Tushar Khairnar
  * Udo Kohlmeyer
  * Vince Ford
  * Vinesh Prasanna Manoharan
  * Vivek Bhaskar
  * Wes Williams
  * William A. Rowe Jr.
  * William Markito
  * Will Schipp
  * Xiaojian Zhou
  * Yogesh Mahajan

== Affiliations ==
  * WANDisco: Konstantin Boudnik
  * Bloomberg LP: Justin Erenkrantz
  * Cloud Foundry Foundation: Chip Childers
  * NASA JPL: Chris Mattmann
  * Unaffiliated: Jan Iversen
  * CDK Global: Ben Reser, Konstantin Ignatyev, Bruce Szalwinski
  * Pivotal: everyone else on this proposal

== Sponsors ==

=== Champion ===
Roman Shaposhnik

=== Nominated Mentors ===

The initial mentors are listed below: 
  * Chip Childers - Apache Member, Cloud Foundry Foundation
  * Justin Erenkrantz - Apache Member, Bloomberg LP
  * Konstantin Boudnik - Apache Member, WANDisco
  * Jan Iversen - Apache Member, Self employed
  * William A. Rowe Jr. - Apache Member, Pivotal
  * Henry Saputra - Apache Member, Pivotal
  * Roman Shaposhnik - Apache Member, Pivotal
  * Chris Mattmann - Apache Member, NASA JPL

=== Sponsoring Entity ===
We would like to propose Apache incubator to sponsor this project.

---------------------------------------------------------------------
To unsubscribe, e-mail: cvs-unsubscribe@incubator.apache.org
For additional commands, e-mail: cvs-help@incubator.apache.org


Mime
View raw message