@huyl08
2016-07-10T06:35:59.000000Z
字数 3897
阅读 1393
The Apache Accumulo™ sorted, distributed key/value store is a robust,
scalable, high performance data storage and retrieval system. Apache Accumulo
is based on Google's BigTable design and is built on top of Apache
Hadoop, Zookeeper, and Thrift. Apache Accumulo features a few
novel improvements on the BigTable design in the form of cell-based access
control and a server-side programming mechanism that can modify key/value pairs
at various points in the data management process. Other notable improvements
and feature are outlined here.
To install and run an Accumulo binary distribution, follow the install
instructions.
Accumulo provides the following documentation :
This documentation is available on the Accumulo site. In the source and
binary distributions of Accumulo, the documentation is at different locations.
In the Accumulo binary distribution, all documentation is in the docs
directory. The binary distribution does not include example source code, but
it does include a jar with the compiled examples. This examples jar makes it
easy to step through the example readmes, after following the install
instructions.
In the Accumulo source, documentations is found at the following locations.
Accumulo uses Maven to compile, test, and package its source. The
following command will build the binary tar.gz from source. Note, these
instructions will not work for the Accumulo binary distribution as it does not
include source.
mvn package -P assemble
This command produces a file at the following location.
assemble/target/accumulo-X.Y.Z-SNAPSHOT-bin.tar.gz
This will not include documentation, adding the -P docs
option to the maven
command will build documentation.
The public Accumulo API is composed of :
All public types in the following packages and their subpackages excluding
those named impl, thrift, or crypto.
A type is a class, interface, or enum. Anything with public or protected
acccess in an API type is in the API. This includes, but is not limited to:
methods, members classes, interfaces, and enums. Package-private types in
the above packages are not considered public API.
The following regex matches imports that are not Accumulo public API. This
regex can be used with RegexpSingleline to automatically find suspicious
imports in a project using Accumulo.
import\s+org\.apache\.accumulo\.(.*\.(impl|thrift|crypto)\..*|(?!core|minicluster).*|core\.(?!client|data|security).*)
The Accumulo project maintains binary compatibility across this API within a
major release, as defined in the Java Language Specification 3rd ed. Starting
with Accumulo 1.6.2 and 1.7.0 all API changes will follow semver 2.0
This distribution includes cryptographic software. The country in which you
currently reside may have restrictions on the import, possession, use, and/or
re-export to another country, of encryption software. BEFORE using any
encryption software, please check your country's laws, regulations and
policies concerning the import, possession, or use, and re-export of encryption
software, to see if this is permitted. See http://www.wassenaar.org/ for more
information.
The U.S. Government Department of Commerce, Bureau of Industry and Security
(BIS), has classified this software as Export Commodity Control Number (ECCN)
5D002.C.1, which includes information security software using or performing
cryptographic functions with asymmetric algorithms. The form and manner of this
Apache Software Foundation distribution makes it eligible for export under the
License Exception ENC Technology Software Unrestricted (TSU) exception (see the
BIS Export Administration Regulations, Section 740.13) for both object code and
source code.
The following provides more details on the included cryptographic software:
Apache Accumulo uses the built-in java cryptography libraries in its RFile
encryption implementation. See oracle's export-regulations doc
for more details for on Java's cryptography features. Apache Accumulo also uses
the bouncycastle library for some crypographic technology as well. See
the BouncyCastle FAQ for
more details on bouncycastle's cryptography features.