Release 0.9 ("?")
2015-??-??
For this release we have mainly focused on ease of use and ease of
installation for new users. Recognizing that most users don't have
their own servers, we've been working on making it easier to run
Camlistore on cloud providers. Initially we've targeted the Google Cloud Platform and Scaleway, making sure Camlistore
is well-adapted to those environments. For users wishing to use Google
Cloud Platform, we now provide a web-based launcher for users to
create their own Camlistore instances:
For users wishing to use Scaleway, see our early scaleway-camlistore
image. Our Scaleway image does not yet use Scaleway's Object Storage service, however,
and puts all Camlistore data on the same volume as the Camlistore code itself, potentially complicating
upgrades. It should be considered an early preview.
Making Camlistore run well on cloud providers required two other
major features: the blobpacked
storage backend (for
latency and cost reasons) and HTTP/2 (for latency reasons).
The blobpacked
storage backend allows faster reading &
serving of files because it stores related blobs contiguously within
larger container blobs (which are also valid zip files) instead of
many small randomly dispersed blobs. See the blobpacked
package documentation.
The Go HTTP/2 implementation
was developed for both Camlistore and the Go standard library and will
be included in Go 1.6. Camlistore 0.9 only requires Go 1.5 but
includes a vendored copy of golang.org/x/net/http2
. See
https://http2.golang.org/ for
a demo.
Source release:
Binary release, new in this release:
Please note that Go 1.5 or newer is now required for this release.
Release stats
33 total commiters over 942 commits since Camlistore 0.8, including Aaron Bieber,
Aaron Boodman, Andrew Gerrand, Antonin Amand, Bill Thiede, Brad
Fitzpatrick, David Jack, Emil Hessman, Eric Drechsel, Fabian Reinartz,
Fabian Wickborn, Felix Geller, Gina White, Govert Versluis, Jingguo
Yao, Lindsey Simon, Mario Russo, Mathieu Lonjaret, Matthieu
Rakotojaona, Patrick Mezard, Robert Kroeger, Salman Aljammaz, Salmān
Aljammāz, Steven L. Speek, Tamás Gulácsi, Will Norris.
Thank you!
Changes in 0.9
Android
- Restrict upload by WiFI SSID.
Camget
- Do not fetch file if already exists on local disk.
Camput
- New option for
share
command: -search
.
- Detect and warn when using wrong GPG key.
- New option for
file
command: -contents_only
.
Camtool
- New
makestatic
command.
- New
packblobs
command.
- New option for
search
command: -rawquery.
Cammount
Devcam
- Detect and warn when outdated.
test
command does check for bad imports and gofmt.
- New option for
server
command: -wipecache
.
- New option for
server
command: -memindex
.
Deploy
- Launcher to help deploy Camlistore on Google Cloud Platform.
Docker
misc/docker/dock.go
: new program to generate a docker image for camlistored, as well binaries in isolation.
Genfileembed
- New flag to generate build tags.
Images
- Optional faster resizing with djpeg (if available)
- Support for tiff decoding.
Importers
Indexer
- Improved MySQL connection handling (switch to
go-mysql-driver
).
- New sorted implementation: levelDB (https://github.com/syndtr/goleveldb).
- Out of order reindexing finished/fixed.
- When indexing from images: always try a small prefix buffer first, then read full file if needed.
- Defined a (large) limit on key and value size for all sorted implementations.
- The wholeRef of a file is always indexed, for faster file stats everywhere.
- RDBMS-specific placeholder replacements (and table name replacements) are now cached.
Misc performance changes, bug fixes, clean-ups, etc.
HTTP/2
- make.go: improvements, refactoring, and cleanup.
- Migration to new third_parties:
golang.org/x/oauth2
, google.golang.org/cloud
, etc.
- goexif: features and fixes, then contributed upstream.
- Server system status is constantly refreshed over websocket.
- Most of the JSON maps (e.g. for server responses) should be gone in favor of annotated structs.
- More robust localhost detection.
- The setup wizard was removed.
Ports
- Solaris: Camlistore should at least build.
- Darwin/386: deprecated, and user is warned about it when trying to build.
Schema
- Cache last blob read when reading files -> major performance optimization.
- File/chunks related changes, often optimizations with blobpacked in mind.
Search
- New "Around" parameter for queries. Introduced to help web UI features.
Storage
- New
blobpacked
blobserver: keeps related blobs physically contiguous within zip files.
- Many Google Cloud Storage improvements.
- New SubFetcher interface.
- New BlobStreamer interface.
- New WholeRefFetcher interface.
- New memory blobserver.
Website
- New launcher to deploy Camlistore on Google Cloud: https://camlistore.org/launch.
- CONTRIBUTORS are generated from git log.
- Issue tracker has moved to github.
Web UI
- New style: top search bar, pudgy navigation menu, vertical contextual actions sidebar.
- Simpler URL blobRef format:
/ui/
.
- Some new features:
- Improved uploading: context aware (add to an existing set), duplicate detection/prevention, better drop area, show bytes transfered.
- Aspects: generic attributes editor for permanode aspect. New directory aspect.
- Sidebar: mass tagging/deleting.
- Selections state is saved accross navigation.
- Download: view original (non-resized) item.
- Videos rendering.
- Pages changes:
- Improved status page, with lots more info, and restart camlistored "button".
- New help page: client tools configuration, and download links.
- New mobile auto-configuration page with QR code.
- New /debug/config page.
- misc:
- Piggy menu shows server errors.
- Left/right navigation restored.
- Better layout on mobile.
- Cleaned out most of the non-React, legacy code.
Wkfs
- New package that provides a filesystem abstraction layer.