]> git.proxmox.com Git - ceph.git/blob - ceph/doc/releases/infernalis.rst
43a2af3861bdf79d3b4ceff3b67ec755e2d9d1f0
[ceph.git] / ceph / doc / releases / infernalis.rst
1 .. _infernalis-release-notes:
2
3 ==========
4 Infernalis
5 ==========
6
7 Infernalis is the 9th stable release of Ceph. It is named after the
8 vampire squid (Vampyroteuthis infernalis, the "vampire squid from
9 hell").
10
11 v9.2.1 Infernalis
12 =================
13
14 This Infernalis point release fixes several packagins and init script
15 issues, enables the librbd objectmap feature by default, a few librbd
16 bugs, and a range of miscellaneous bug fixes across the system.
17
18 We recommend that all infernalis v9.2.0 users upgrade.
19
20 For more detailed information, see :download:`the complete changelog <../changelog/v9.2.1.txt>`.
21
22 Upgrading
23 ---------
24
25 * Some symbols wrongly exposed by the C++ interface for librados in
26 v9.1.0 and v9.2.0 were removed. If you compiled your own
27 application against librados shipped with these releases, it is very
28 likely referencing these removed symbols. So you will need to
29 recompile it.
30
31
32 Notable Changes
33 ---------------
34 * build/ops: Ceph daemon failed to start, because the service name was already used. (`issue#13474 <http://tracker.ceph.com/issues/13474>`_, `pr#6833 <http://github.com/ceph/ceph/pull/6833>`_, Chuanhong Wang)
35 * build/ops: ceph upstart script rbdmap.conf incorrectly processes parameters (`issue#13214 <http://tracker.ceph.com/issues/13214>`_, `pr#6396 <http://github.com/ceph/ceph/pull/6396>`_, Sage Weil)
36 * build/ops: libunwind package missing on CentOS 7 (`issue#13997 <http://tracker.ceph.com/issues/13997>`_, `pr#6845 <http://github.com/ceph/ceph/pull/6845>`_, Loic Dachary)
37 * build/ops: rbd-replay-* moved from ceph-test-dbg to ceph-common-dbg as well (`issue#13785 <http://tracker.ceph.com/issues/13785>`_, `pr#6628 <http://github.com/ceph/ceph/pull/6628>`_, Loic Dachary)
38 * build/ops: systemd/ceph-disk@.service assumes /bin/flock (`issue#13975 <http://tracker.ceph.com/issues/13975>`_, `pr#6852 <http://github.com/ceph/ceph/pull/6852>`_, Loic Dachary)
39 * build/ops: systemd: no rbdmap systemd unit file (`issue#13374 <http://tracker.ceph.com/issues/13374>`_, `pr#6500 <http://github.com/ceph/ceph/pull/6500>`_, Boris Ranto)
40 * common: auth/cephx: large amounts of log are produced by osd (`issue#13610 <http://tracker.ceph.com/issues/13610>`_, `pr#6836 <http://github.com/ceph/ceph/pull/6836>`_, Qiankun Zheng)
41 * common: log: Log.cc: Assign LOG_DEBUG priority to syslog calls (`issue#13993 <http://tracker.ceph.com/issues/13993>`_, `pr#6993 <http://github.com/ceph/ceph/pull/6993>`_, Brad Hubbard)
42 * crush: crash if we see CRUSH_ITEM_NONE in early rule step (`issue#13477 <http://tracker.ceph.com/issues/13477>`_, `pr#6626 <http://github.com/ceph/ceph/pull/6626>`_, Sage Weil)
43 * fs: Ceph file system is not freeing space (`issue#13777 <http://tracker.ceph.com/issues/13777>`_, `pr#7431 <http://github.com/ceph/ceph/pull/7431>`_, Yan, Zheng, John Spray)
44 * fs: Ceph-fuse won't start correctly when the option log_max_new in ceph.conf set to zero (`issue#13443 <http://tracker.ceph.com/issues/13443>`_, `pr#6395 <http://github.com/ceph/ceph/pull/6395>`_, Wenjun Huang)
45 * fs: Segmentation fault accessing file using fuse mount (`issue#13714 <http://tracker.ceph.com/issues/13714>`_, `pr#6853 <http://github.com/ceph/ceph/pull/6853>`_, Yan, Zheng)
46 * librbd: Avoid re-writing old-format image header on resize (`issue#13674 <http://tracker.ceph.com/issues/13674>`_, `pr#6630 <http://github.com/ceph/ceph/pull/6630>`_, Jason Dillaman)
47 * librbd: ImageWatcher shouldn't block the notification thread (`issue#14373 <http://tracker.ceph.com/issues/14373>`_, `pr#7406 <http://github.com/ceph/ceph/pull/7406>`_, Jason Dillaman)
48 * librbd: QEMU hangs after creating snapshot and stopping VM (`issue#13726 <http://tracker.ceph.com/issues/13726>`_, `pr#6632 <http://github.com/ceph/ceph/pull/6632>`_, Jason Dillaman)
49 * librbd: Verify self-managed snapshot functionality on image create (`issue#13633 <http://tracker.ceph.com/issues/13633>`_, `pr#7080 <http://github.com/ceph/ceph/pull/7080>`_, Jason Dillaman)
50 * librbd: [ FAILED ] TestLibRBD.SnapRemoveViaLockOwner (`issue#14164 <http://tracker.ceph.com/issues/14164>`_, `pr#7079 <http://github.com/ceph/ceph/pull/7079>`_, Jason Dillaman)
51 * librbd: enable feature objectmap (`issue#13558 <http://tracker.ceph.com/issues/13558>`_, `pr#6477 <http://github.com/ceph/ceph/pull/6477>`_, xinxin shu)
52 * librbd: fix merge-diff for >2GB diff-files (`issue#14030 <http://tracker.ceph.com/issues/14030>`_, `pr#6981 <http://github.com/ceph/ceph/pull/6981>`_, Jason Dillaman)
53 * librbd: flattening an rbd image with active IO can lead to hang (`issue#14092 <http://tracker.ceph.com/issues/14092>`_, `issue#14483 <http://tracker.ceph.com/issues/14483>`_, `pr#7484 <http://github.com/ceph/ceph/pull/7484>`_, Jason Dillaman)
54 * mds: fix client capabilities during reconnect (client.XXXX isn't responding to mclientcaps warning) (`issue#11482 <http://tracker.ceph.com/issues/11482>`_, `pr#6752 <http://github.com/ceph/ceph/pull/6752>`_, Yan, Zheng)
55 * mon: Ceph Pools' MAX AVAIL is 0 if some OSDs' weight is 0 (`issue#13840 <http://tracker.ceph.com/issues/13840>`_, `pr#6907 <http://github.com/ceph/ceph/pull/6907>`_, Chengyuan Li)
56 * mon: should not set isvalid = true when cephx_verify_authorizer retur... (`issue#13525 <http://tracker.ceph.com/issues/13525>`_, `pr#6392 <http://github.com/ceph/ceph/pull/6392>`_, Ruifeng Yang)
57 * objecter: pool op callback may hang forever. (`issue#13642 <http://tracker.ceph.com/issues/13642>`_, `pr#6627 <http://github.com/ceph/ceph/pull/6627>`_, xie xingguo)
58 * objecter: potential null pointer access when do pool_snap_list. (`issue#13639 <http://tracker.ceph.com/issues/13639>`_, `pr#6840 <http://github.com/ceph/ceph/pull/6840>`_, xie xingguo)
59 * osd: FileStore: potential memory leak if getattrs fails. (`issue#13597 <http://tracker.ceph.com/issues/13597>`_, `pr#6846 <http://github.com/ceph/ceph/pull/6846>`_, xie xingguo)
60 * osd: OSD::build_past_intervals_parallel() shall reset primary and up_primary when begin a new past_interval. (`issue#13471 <http://tracker.ceph.com/issues/13471>`_, `pr#6397 <http://github.com/ceph/ceph/pull/6397>`_, xiexingguo)
61 * osd: call on_new_interval on newly split child PG (`issue#13962 <http://tracker.ceph.com/issues/13962>`_, `pr#6849 <http://github.com/ceph/ceph/pull/6849>`_, Sage Weil)
62 * osd: ceph-disk list fails on /dev/cciss!c0d0 (`issue#13970 <http://tracker.ceph.com/issues/13970>`_, `issue#14230 <http://tracker.ceph.com/issues/14230>`_, `pr#6880 <http://github.com/ceph/ceph/pull/6880>`_, Loic Dachary)
63 * osd: ceph-disk: use blkid instead of sgdisk -i (`issue#14080 <http://tracker.ceph.com/issues/14080>`_, `pr#7001 <http://github.com/ceph/ceph/pull/7001>`_, Loic Dachary, Ilya Dryomov)
64 * osd: fix race condition during send_failures (`issue#13821 <http://tracker.ceph.com/issues/13821>`_, `pr#6694 <http://github.com/ceph/ceph/pull/6694>`_, Sage Weil)
65 * osd: osd/PG.cc: 288: FAILED assert(info.last_epoch_started >= info.history.last_epoch_started) (`issue#14015 <http://tracker.ceph.com/issues/14015>`_, `pr#6851 <http://github.com/ceph/ceph/pull/6851>`_, David Zafman)
66 * osd: pgs stuck inconsistent after infernalis upgrade (`issue#13862 <http://tracker.ceph.com/issues/13862>`_, `pr#7421 <http://github.com/ceph/ceph/pull/7421>`_, David Zafman)
67 * rbd: TaskFinisher::cancel should remove event from SafeTimer (`issue#14476 <http://tracker.ceph.com/issues/14476>`_, `pr#7426 <http://github.com/ceph/ceph/pull/7426>`_, Douglas Fuller)
68 * rbd: cls_rbd: object_map_save should enable checksums (`issue#14280 <http://tracker.ceph.com/issues/14280>`_, `pr#7428 <http://github.com/ceph/ceph/pull/7428>`_, Douglas Fuller)
69 * rbd: misdirected op in rbd balance-reads test (`issue#13491 <http://tracker.ceph.com/issues/13491>`_, `pr#6629 <http://github.com/ceph/ceph/pull/6629>`_, Jason Dillaman)
70 * rbd: pure virtual method called (`issue#13636 <http://tracker.ceph.com/issues/13636>`_, `pr#6633 <http://github.com/ceph/ceph/pull/6633>`_, Jason Dillaman)
71 * rbd: rbd clone issue (`issue#13553 <http://tracker.ceph.com/issues/13553>`_, `pr#6474 <http://github.com/ceph/ceph/pull/6474>`_, xinxin shu)
72 * rbd: rbd-replay does not check for EOF and goes to endless loop (`issue#14452 <http://tracker.ceph.com/issues/14452>`_, `pr#7427 <http://github.com/ceph/ceph/pull/7427>`_, Mykola Golub)
73 * rbd: unknown argument --quiet in udevadm settle (`issue#13560 <http://tracker.ceph.com/issues/13560>`_, `pr#6634 <http://github.com/ceph/ceph/pull/6634>`_, Jason Dillaman)
74 * rgw: init script reload doesn't work on EL7 (`issue#13709 <http://tracker.ceph.com/issues/13709>`_, `pr#6650 <http://github.com/ceph/ceph/pull/6650>`_, Hervé Rousseau)
75 * rgw: radosgw-admin --help doesn't show the orphans find command (`issue#14516 <http://tracker.ceph.com/issues/14516>`_, `pr#7543 <http://github.com/ceph/ceph/pull/7543>`_, Yehuda Sadeh)
76 * tests: ceph-disk workunit uses configobj (`issue#14004 <http://tracker.ceph.com/issues/14004>`_, `pr#6828 <http://github.com/ceph/ceph/pull/6828>`_, Loic Dachary)
77 * tests: fsx failed to compile (`issue#14384 <http://tracker.ceph.com/issues/14384>`_, `pr#7429 <http://github.com/ceph/ceph/pull/7429>`_, Greg Farnum)
78 * tests: notification slave needs to wait for master (`issue#13810 <http://tracker.ceph.com/issues/13810>`_, `pr#7225 <http://github.com/ceph/ceph/pull/7225>`_, Jason Dillaman)
79 * tests: rebuild exclusive lock test should acquire exclusive lock (`issue#14121 <http://tracker.ceph.com/issues/14121>`_, `pr#7038 <http://github.com/ceph/ceph/pull/7038>`_, Jason Dillaman)
80 * tests: testprofile must be removed before it is re-created (`issue#13664 <http://tracker.ceph.com/issues/13664>`_, `pr#6449 <http://github.com/ceph/ceph/pull/6449>`_, Loic Dachary)
81 * tests: verify it is possible to reuse an OSD id (`issue#13988 <http://tracker.ceph.com/issues/13988>`_, `pr#6882 <http://github.com/ceph/ceph/pull/6882>`_, Loic Dachary)
82
83 v9.2.0 Infernalis
84 =================
85
86 This major release will be the foundation for the next stable series.
87 There have been some major changes since v0.94.x Hammer, and the
88 upgrade process is non-trivial. Please read these release notes carefully.
89
90 Major Changes from Hammer
91 -------------------------
92
93 - *General*:
94
95 * Ceph daemons are now managed via systemd (with the exception of
96 Ubuntu Trusty, which still uses upstart).
97 * Ceph daemons run as 'ceph' user instead root.
98 * On Red Hat distros, there is also an SELinux policy.
99
100 - *RADOS*:
101
102 * The RADOS cache tier can now proxy write operations to the base
103 tier, allowing writes to be handled without forcing migration of
104 an object into the cache.
105 * The SHEC erasure coding support is no longer flagged as
106 experimental. SHEC trades some additional storage space for faster
107 repair.
108 * There is now a unified queue (and thus prioritization) of client
109 IO, recovery, scrubbing, and snapshot trimming.
110 * There have been many improvements to low-level repair tooling
111 (ceph-objectstore-tool).
112 * The internal ObjectStore API has been significantly cleaned up in order
113 to facilitate new storage backends like NewStore.
114
115 - *RGW*:
116
117 * The Swift API now supports object expiration.
118 * There are many Swift API compatibility improvements.
119
120 - *RBD*:
121
122 * The ``rbd du`` command shows actual usage (quickly, when
123 object-map is enabled).
124 * The object-map feature has seen many stability improvements.
125 * Object-map and exclusive-lock features can be enabled or disabled
126 dynamically.
127 * You can now store user metadata and set persistent librbd options
128 associated with individual images.
129 * The new deep-flatten features allows flattening of a clone and all
130 of its snapshots. (Previously snapshots could not be flattened.)
131 * The export-diff command command is now faster (it uses aio). There is also
132 a new fast-diff feature.
133 * The --size argument can be specified with a suffix for units
134 (e.g., ``--size 64G``).
135 * There is a new ``rbd status`` command that, for now, shows who has
136 the image open/mapped.
137
138 - *CephFS*:
139
140 * You can now rename snapshots.
141 * There have been ongoing improvements around administration, diagnostics,
142 and the check and repair tools.
143 * The caching and revocation of client cache state due to unused
144 inodes has been dramatically improved.
145 * The ceph-fuse client behaves better on 32-bit hosts.
146
147 Distro compatibility
148 --------------------
149
150 We have decided to drop support for many older distributions so that we can
151 move to a newer compiler toolchain (e.g., C++11). Although it is still possible
152 to build Ceph on older distributions by installing backported development tools,
153 we are not building and publishing release packages for ceph.com.
154
155 We now build packages for:
156
157 * CentOS 7 or later. We have dropped support for CentOS 6 (and other
158 RHEL 6 derivatives, like Scientific Linux 6).
159 * Debian Jessie 8.x or later. Debian Wheezy 7.x's g++ has incomplete
160 support for C++11 (and no systemd).
161 * Ubuntu Trusty 14.04 or later. Ubuntu Precise 12.04 is no longer
162 supported.
163 * Fedora 22 or later.
164
165 Upgrading from Firefly
166 ----------------------
167
168 Upgrading directly from Firefly v0.80.z is not recommended. It is
169 possible to do a direct upgrade, but not without downtime. We
170 recommend that clusters are first upgraded to Hammer v0.94.4 or a
171 later v0.94.z release; only then is it possible to upgrade to
172 Infernalis 9.2.z for an online upgrade (see below).
173
174 To do an offline upgrade directly from Firefly, all Firefly OSDs must
175 be stopped and marked down before any Infernalis OSDs will be allowed
176 to start up. This fencing is enforced by the Infernalis monitor, so
177 use an upgrade procedure like:
178
179 #. Upgrade Ceph on monitor hosts
180 #. Restart all ceph-mon daemons
181 #. Upgrade Ceph on all OSD hosts
182 #. Stop all ceph-osd daemons
183 #. Mark all OSDs down with something like::
184
185 ceph osd down `seq 0 1000`
186
187 #. Start all ceph-osd daemons
188 #. Upgrade and restart remaining daemons (ceph-mds, radosgw)
189
190 Upgrading from Hammer
191 ---------------------
192
193 * All cluster nodes must first upgrade to Hammer v0.94.4 or a later v0.94.z release; only
194 then is it possible to upgrade to Infernalis 9.2.z.
195
196 * For all distributions that support systemd (CentOS 7, Fedora, Debian
197 Jessie 8.x, OpenSUSE), ceph daemons are now managed using native systemd
198 files instead of the legacy sysvinit scripts. For example::
199
200 systemctl start ceph.target # start all daemons
201 systemctl status ceph-osd@12 # check status of osd.12
202
203 The main notable distro that is *not* yet using systemd is Ubuntu trusty
204 14.04. (The next Ubuntu LTS, 16.04, will use systemd instead of upstart.)
205
206 * Ceph daemons now run as user and group ``ceph`` by default. The
207 ceph user has a static UID assigned by Fedora and Debian (also used
208 by derivative distributions like RHEL/CentOS and Ubuntu). On SUSE
209 the ceph user will currently get a dynamically assigned UID when the
210 user is created.
211
212 If your systems already have a ceph user, upgrading the package will cause
213 problems. We suggest you first remove or rename the existing 'ceph' user
214 and 'ceph' group before upgrading.
215
216 When upgrading, administrators have two options:
217
218 #. Add the following line to ``ceph.conf`` on all hosts::
219
220 setuser match path = /var/lib/ceph/$type/$cluster-$id
221
222 This will make the Ceph daemons run as root (i.e., not drop
223 privileges and switch to user ceph) if the daemon's data
224 directory is still owned by root. Newly deployed daemons will
225 be created with data owned by user ceph and will run with
226 reduced privileges, but upgraded daemons will continue to run as
227 root.
228
229 #. Fix the data ownership during the upgrade. This is the
230 preferred option, but it is more work and can be very time
231 consuming. The process for each host is to:
232
233 #. Upgrade the ceph package. This creates the ceph user and group. For
234 example::
235
236 ceph-deploy install --stable infernalis HOST
237
238 #. Stop the daemon(s)::
239
240 service ceph stop # fedora, centos, rhel, debian
241 stop ceph-all # ubuntu
242
243 #. Fix the ownership::
244
245 chown -R ceph:ceph /var/lib/ceph
246 chown -R ceph:ceph /var/log/ceph
247
248 #. Restart the daemon(s)::
249
250 start ceph-all # ubuntu
251 systemctl start ceph.target # debian, centos, fedora, rhel
252
253 Alternatively, the same process can be done with a single daemon
254 type, for example by stopping only monitors and chowning only
255 ``/var/lib/ceph/mon``.
256
257 * The on-disk format for the experimental KeyValueStore OSD backend has
258 changed. You will need to remove any OSDs using that backend before you
259 upgrade any test clusters that use it.
260
261 * When a pool quota is reached, librados operations now block indefinitely,
262 the same way they do when the cluster fills up. (Previously they would return
263 -ENOSPC). By default, a full cluster or pool will now block. If your
264 librados application can handle ENOSPC or EDQUOT errors gracefully, you can
265 get error returns instead by using the new librados OPERATION_FULL_TRY flag.
266
267 * The return code for librbd's rbd_aio_read and Image::aio_read API methods no
268 longer returns the number of bytes read upon success. Instead, it returns 0
269 upon success and a negative value upon failure.
270
271 * 'ceph scrub', 'ceph compact' and 'ceph sync force are now DEPRECATED. Users
272 should instead use 'ceph mon scrub', 'ceph mon compact' and
273 'ceph mon sync force'.
274
275 * 'ceph mon_metadata' should now be used as 'ceph mon metadata'. There is no
276 need to deprecate this command (same major release since it was first
277 introduced).
278
279 * The `--dump-json` option of "osdmaptool" is replaced by `--dump json`.
280
281 * The commands of "pg ls-by-{pool,primary,osd}" and "pg ls" now take "recovering"
282 instead of "recovery", to include the recovering pgs in the listed pgs.
283
284 Notable Changes since Hammer
285 ----------------------------
286
287 * aarch64: add optimized version of crc32c (Yazen Ghannam, Steve Capper)
288 * auth: cache/reuse crypto lib key objects, optimize msg signature check (Sage Weil)
289 * auth: reinit NSS after fork() (#11128 Yan, Zheng)
290 * autotools: fix out of tree build (Krxysztof Kosinski)
291 * autotools: improve make check output (Loic Dachary)
292 * buffer: add invalidate_crc() (Piotr Dalek)
293 * buffer: fix zero bug (#12252 Haomai Wang)
294 * buffer: some cleanup (Michal Jarzabek)
295 * build: allow tcmalloc-minimal (Thorsten Behrens)
296 * build: C++11 now supported
297 * build: cmake: fix nss linking (Danny Al-Gaaf)
298 * build: cmake: misc fixes (Orit Wasserman, Casey Bodley)
299 * build: disable LTTNG by default (#11333 Josh Durgin)
300 * build: do not build ceph-dencoder with tcmalloc (#10691 Boris Ranto)
301 * build: fix junit detection on Fedora 22 (Ira Cooper)
302 * build: fix pg ref disabling (William A. Kennington III)
303 * build: fix ppc build (James Page)
304 * build: install-deps: misc fixes (Loic Dachary)
305 * build: install-deps.sh improvements (Loic Dachary)
306 * build: install-deps: support OpenSUSE (Loic Dachary)
307 * build: make_dist_tarball.sh (Sage Weil)
308 * build: many cmake improvements
309 * build: misc cmake fixes (Matt Benjamin)
310 * build: misc fixes (Boris Ranto, Ken Dreyer, Owen Synge)
311 * build: OSX build fixes (Yan, Zheng)
312 * build: remove rest-bench
313 * ceph-authtool: fix return code on error (Gerhard Muntingh)
314 * ceph-detect-init: added Linux Mint (Michal Jarzabek)
315 * ceph-detect-init: robust init system detection (Owen Synge)
316 * ceph-disk: ensure 'zap' only operates on a full disk (#11272 Loic Dachary)
317 * ceph-disk: fix zap sgdisk invocation (Owen Synge, Thorsten Behrens)
318 * ceph-disk: follow ceph-osd hints when creating journal (#9580 Sage Weil)
319 * ceph-disk: handle re-using existing partition (#10987 Loic Dachary)
320 * ceph-disk: improve parted output parsing (#10983 Loic Dachary)
321 * ceph-disk: install pip > 6.1 (#11952 Loic Dachary)
322 * ceph-disk: make suppression work for activate-all and activate-journal (Dan van der Ster)
323 * ceph-disk: many fixes (Loic Dachary, Alfredo Deza)
324 * ceph-disk: fixes to respect init system (Loic Dachary, Owen Synge)
325 * ceph-disk: pass --cluster arg on prepare subcommand (Kefu Chai)
326 * ceph-disk: support for multipath devices (Loic Dachary)
327 * ceph-disk: support NVMe device partitions (#11612 Ilja Slepnev)
328 * ceph: fix 'df' units (Zhe Zhang)
329 * ceph: fix parsing in interactive cli mode (#11279 Kefu Chai)
330 * cephfs-data-scan: many additions, improvements (John Spray)
331 * ceph-fuse: do not require successful remount when unmounting (#10982 Greg Farnum)
332 * ceph-fuse, libcephfs: don't clear COMPLETE when trimming null (Yan, Zheng)
333 * ceph-fuse, libcephfs: drop inode when rmdir finishes (#11339 Yan, Zheng)
334 * ceph-fuse,libcephfs: fix uninline (#11356 Yan, Zheng)
335 * ceph-fuse, libcephfs: hold exclusive caps on dirs we "own" (#11226 Greg Farnum)
336 * ceph-fuse: mostly behave on 32-bit hosts (Yan, Zheng)
337 * ceph: improve error output for 'tell' (#11101 Kefu Chai)
338 * ceph-monstore-tool: fix store-copy (Huangjun)
339 * ceph: new 'ceph daemonperf' command (John Spray, Mykola Golub)
340 * ceph-objectstore-tool: many many improvements (David Zafman)
341 * ceph-objectstore-tool: refactoring and cleanup (John Spray)
342 * ceph-post-file: misc fixes (Joey McDonald, Sage Weil)
343 * ceph_test_rados: test pipelined reads (Zhiqiang Wang)
344 * client: avoid sending unnecessary FLUSHSNAP messages (Yan, Zheng)
345 * client: exclude setfilelock when calculating oldest tid (Yan, Zheng)
346 * client: fix error handling in check_pool_perm (John Spray)
347 * client: fsync waits only for inode's caps to flush (Yan, Zheng)
348 * client: invalidate kernel dcache when cache size exceeds limits (Yan, Zheng)
349 * client: make fsync wait for unsafe dir operations (Yan, Zheng)
350 * client: pin lookup dentry to avoid inode being freed (Yan, Zheng)
351 * common: add descriptions to perfcounters (Kiseleva Alyona)
352 * common: add perf counter descriptions (Alyona Kiseleva)
353 * common: bufferlist performance tuning (Piotr Dalek, Sage Weil)
354 * common: detect overflow of int config values (#11484 Kefu Chai)
355 * common: fix bit_vector extent calc (#12611 Jason Dillaman)
356 * common: fix json parsing of utf8 (#7387 Tim Serong)
357 * common: fix leak of pthread_mutexattr (#11762 Ketor Meng)
358 * common: fix LTTNG vs fork issue (Josh Durgin)
359 * common: fix throttle max change (Henry Chang)
360 * common: make mutex more efficient
361 * common: make work queue addition/removal thread safe (#12662 Jason Dillaman)
362 * common: optracker improvements (Zhiqiang Wang, Jianpeng Ma)
363 * common: PriorityQueue tests (Kefu Chai)
364 * common: some async compression infrastructure (Haomai Wang)
365 * crush: add --check to validate dangling names, max osd id (Kefu Chai)
366 * crush: cleanup, sync with kernel (Ilya Dryomov)
367 * crush: fix crash from invalid 'take' argument (#11602 Shiva Rkreddy, Sage Weil)
368 * crush: fix divide-by-2 in straw2 (#11357 Yann Dupont, Sage Weil)
369 * crush: fix has_v4_buckets (#11364 Sage Weil)
370 * crush: fix subtree base weight on adjust_subtree_weight (#11855 Sage Weil)
371 * crush: respect default replicated ruleset config on map creation (Ilya Dryomov)
372 * crushtool: fix order of operations, usage (Sage Weil)
373 * crypto: fix NSS leak (Jason Dillaman)
374 * crypto: fix unbalanced init/shutdown (#12598 Zheng Yan)
375 * deb: fix rest-bench-dbg and ceph-test-dbg dependendies (Ken Dreyer)
376 * debian: minor package reorg (Ken Dreyer)
377 * deb, rpm: move ceph-objectstore-tool to ceph (Ken Dreyer)
378 * doc: docuemnt object corpus generation (#11099 Alexis Normand)
379 * doc: document region hostnames (Robin H. Johnson)
380 * doc: fix gender neutrality (Alexandre Maragone)
381 * doc: fix install doc (#10957 Kefu Chai)
382 * doc: fix sphinx issues (Kefu Chai)
383 * doc: man page updates (Kefu Chai)
384 * doc: mds data structure docs (Yan, Zheng)
385 * doc: misc updates (Fracois Lafont, Ken Dreyer, Kefu Chai, Owen Synge, Gael Fenet-Garde, Loic Dachary, Yannick Atchy-Dalama, Jiaying Ren, Kevin Caradant, Robert Maxime, Nicolas Yong, Germain Chipaux, Arthur Gorjux, Gabriel Sentucq, Clement Lebrun, Jean-Remi Deveaux, Clair Massot, Robin Tang, Thomas Laumondais, Jordan Dorne, Yuan Zhou, Valentin Thomas, Pierre Chaumont, Benjamin Troquereau, Benjamin Sesia, Vikhyat Umrao, Nilamdyuti Goswami, Vartika Rai, Florian Haas, Loic Dachary, Simon Guinot, Andy Allan, Alistair Israel, Ken Dreyer, Robin Rehu, Lee Revell, Florian Marsylle, Thomas Johnson, Bosse Klykken, Travis Rhoden, Ian Kelling)
386 * doc: swift tempurls (#10184 Abhishek Lekshmanan)
387 * doc: switch doxygen integration back to breathe (#6115 Kefu Chai)
388 * doc: update release schedule docs (Loic Dachary)
389 * erasure-code: cleanup (Kefu Chai)
390 * erasure-code: improve tests (Loic Dachary)
391 * erasure-code: shec: fix recovery bugs (Takanori Nakao, Shotaro Kawaguchi)
392 * erasure-code: update ISA-L to 2.13 (Yuan Zhou)
393 * gmock: switch to submodule (Danny Al-Gaaf, Loic Dachary)
394 * hadoop: add terasort test (Noah Watkins)
395 * init-radosgw: merge with sysv version; fix enumeration (Sage Weil)
396 * java: fix libcephfs bindings (Noah Watkins)
397 * libcephfs: add pread, pwrite (Jevon Qiao)
398 * libcephfs,ceph-fuse: cache cleanup (Zheng Yan)
399 * libcephfs,ceph-fuse: fix request resend on cap reconnect (#10912 Yan, Zheng)
400 * librados: add config observer (Alistair Strachan)
401 * librados: add FULL_TRY and FULL_FORCE flags for dealing with full clusters or pools (Sage Weil)
402 * librados: add src_fadvise_flags for copy-from (Jianpeng Ma)
403 * librados: define C++ flags from C constants (Josh Durgin)
404 * librados: fadvise flags per op (Jianpeng Ma)
405 * librados: fix last_force_resent handling (#11026 Jianpeng Ma)
406 * librados: fix memory leak from C_TwoContexts (Xiong Yiliang)
407 * librados: fix notify completion race (#13114 Sage Weil)
408 * librados: fix striper when stripe_count = 1 and stripe_unit != object_size (#11120 Yan, Zheng)
409 * librados, libcephfs: randomize client nonces (Josh Durgin)
410 * librados: op perf counters (John Spray)
411 * librados: pybind: fix binary omap values (Robin H. Johnson)
412 * librados: pybind: fix write() method return code (Javier Guerra)
413 * librados: respect default_crush_ruleset on pool_create (#11640 Yuan Zhou)
414 * libradosstriper: fix leak (Danny Al-Gaaf)
415 * librbd: add const for single-client-only features (Josh Durgin)
416 * librbd: add deep-flatten operation (Jason Dillaman)
417 * librbd: add purge_on_error cache behavior (Jianpeng Ma)
418 * librbd: allow additional metadata to be stored with the image (Haomai Wang)
419 * librbd: avoid blocking aio API methods (#11056 Jason Dillaman)
420 * librbd: better handling for dup flatten requests (#11370 Jason Dillaman)
421 * librbd: cancel in-flight ops on watch error (#11363 Jason Dillaman)
422 * librbd: default new images to format 2 (#11348 Jason Dillaman)
423 * librbd: fadvise for copy, export, import (Jianpeng Ma)
424 * librbd: fast diff implementation that leverages object map (Jason Dillaman)
425 * librbd: fix fast diff bugs (#11553 Jason Dillaman)
426 * librbd: fix image format detection (Zhiqiang Wang)
427 * librbd: fix lock ordering issue (#11577 Jason Dillaman)
428 * librbd: fix reads larger than the cache size (Lu Shi)
429 * librbd: fix snapshot creation when other snap is active (#11475 Jason Dillaman)
430 * librbd: flatten/copyup fixes (Jason Dillaman)
431 * librbd: handle NOCACHE fadvise flag (Jinapeng Ma)
432 * librbd: lockdep, helgrind validation (Jason Dillaman, Josh Durgin)
433 * librbd: metadata filter fixes (Haomai Wang)
434 * librbd: misc aio fixes (#5488 Jason Dillaman)
435 * librbd: misc rbd fixes (#11478 #11113 #11342 #11380 Jason Dillaman, Zhiqiang Wang)
436 * librbd: new diff_iterate2 API (Jason Dillaman)
437 * librbd: object map rebuild support (Jason Dillaman)
438 * librbd: only update image flags while hold exclusive lock (#11791 Jason Dillaman)
439 * librbd: optionally disable allocation hint (Haomai Wang)
440 * librbd: prevent race between resize requests (#12664 Jason Dillaman)
441 * librbd: readahead fixes (Zhiqiang Wang)
442 * librbd: return result code from close (#12069 Jason Dillaman)
443 * librbd: store metadata, including config options, in image (Haomai Wang)
444 * librbd: tolerate old osds when getting image metadata (#11549 Jason Dillaman)
445 * librbd: use write_full when possible (Zhiqiang Wang)
446 * log: fix data corruption race resulting from log rotation (#12465 Samuel Just)
447 * logrotate.d: prefer service over invoke-rc.d (#11330 Win Hierman, Sage Weil)
448 * mds: add 'damaged' state to MDSMap (John Spray)
449 * mds: add nicknames for perfcounters (John Spray)
450 * mds: avoid emitting cap warnigns before evicting session (John Spray)
451 * mds: avoid getting stuck in XLOCKDONE (#11254 Yan, Zheng)
452 * mds: disable problematic rstat propagation into snap parents (Yan, Zheng)
453 * mds: do not add snapped items to bloom filter (Yan, Zheng)
454 * mds: expose frags via asok (John Spray)
455 * mds: fix expected holes in journal objects (#13167 Yan, Zheng)
456 * mds: fix handling for missing mydir dirfrag (#11641 John Spray)
457 * mds: fix integer truncateion on large client ids (Henry Chang)
458 * mds: fix mydir replica issue with shutdown (#10743 John Spray)
459 * mds: fix out-of-order messages (#11258 Yan, Zheng)
460 * mds: fix rejoin (Yan, Zheng)
461 * mds: fix setting entire file layout in one setxattr (John Spray)
462 * mds: fix shutdown (John Spray)
463 * mds: fix shutdown with strays (#10744 John Spray)
464 * mds: fix SnapServer crash on deleted pool (John Spray)
465 * mds: fix snapshot bugs (Yan, Zheng)
466 * mds: fix stray reintegration (Yan, Zheng)
467 * mds: fix stray handling (John Spray)
468 * mds: fix suicide beacon (John Spray)
469 * mds: flush immediately in do_open_truncate (#11011 John Spray)
470 * mds: handle misc corruption issues (John Spray)
471 * mds: improve dump methods (John Spray)
472 * mds: many fixes (Yan, Zheng, John Spray, Greg Farnum)
473 * mds: many snapshot and stray fixes (Yan, Zheng)
474 * mds: misc fixes (Jianpeng Ma, Dan van der Ster, Zhang Zhi)
475 * mds: misc journal cleanups and fixes (#10368 John Spray)
476 * mds: misc repair improvements (John Spray)
477 * mds: misc snap fixes (Zheng Yan)
478 * mds: misc snapshot fixes (Yan, Zheng)
479 * mds: new SessionMap storage using omap (#10649 John Spray)
480 * mds: persist completed_requests reliably (#11048 John Spray)
481 * mds: reduce memory consumption (Yan, Zheng)
482 * mds: respawn instead of suicide on blacklist (John Spray)
483 * mds: separate safe_pos in Journaler (#10368 John Spray)
484 * mds: snapshot rename support (#3645 Yan, Zheng)
485 * mds: store layout on header object (#4161 John Spray)
486 * mds: throttle purge stray operations (#10390 John Spray)
487 * mds: tolerate clock jumping backwards (#11053 Yan, Zheng)
488 * mds: warn when clients fail to advance oldest_client_tid (#10657 Yan, Zheng)
489 * misc cleanups and fixes (Danny Al-Gaaf)
490 * misc coverity fixes (Danny Al-Gaaf)
491 * misc performance and cleanup (Nathan Cutler, Xinxin Shu)
492 * mon: add cache over MonitorDBStore (Kefu Chai)
493 * mon: add 'mon_metadata <id>' command (Kefu Chai)
494 * mon: add 'node ls ...' command (Kefu Chai)
495 * mon: add NOFORWARD, OBSOLETE, DEPRECATE flags for mon commands (Joao Eduardo Luis)
496 * mon: add PG count to 'ceph osd df' output (Michal Jarzabek)
497 * mon: 'ceph osd metadata' can dump all osds (Haomai Wang)
498 * mon: clean up, reorg some mon commands (Joao Eduardo Luis)
499 * monclient: flush_log (John Spray)
500 * mon: detect kv backend failures (Sage Weil)
501 * mon: disallow >2 tiers (#11840 Kefu Chai)
502 * mon: disallow ec pools as tiers (#11650 Samuel Just)
503 * mon: do not deactivate last mds (#10862 John Spray)
504 * mon: fix average utilization calc for 'osd df' (Mykola Golub)
505 * mon: fix CRUSH map test for new pools (Sage Weil)
506 * mon: fix log dump crash when debugging (Mykola Golub)
507 * mon: fix mds beacon replies (#11590 Kefu Chai)
508 * mon: fix metadata update race (Mykola Golub)
509 * mon: fix min_last_epoch_clean tracking (Kefu Chai)
510 * mon: fix 'pg ls' sort order, state names (#11569 Kefu Chai)
511 * mon: fix refresh (#11470 Joao Eduardo Luis)
512 * mon: fix variance calc in 'osd df' (Sage Weil)
513 * mon: improve callout to crushtool (Mykola Golub)
514 * mon: make blocked op messages more readable (Jianpeng Ma)
515 * mon: make osd get pool 'all' only return applicable fields (#10891 Michal Jarzabek)
516 * mon: misc scaling fixes (Sage Weil)
517 * mon: normalize erasure-code profile for storage and comparison (Loic Dachary)
518 * mon: only send mon metadata to supporting peers (Sage Weil)
519 * mon: optionally specify osd id on 'osd create' (Mykola Golub)
520 * mon: 'osd tree' fixes (Kefu Chai)
521 * mon: periodic background scrub (Joao Eduardo Luis)
522 * mon: prevent bucket deletion when referenced by a crush rule (#11602 Sage Weil)
523 * mon: prevent pgp_num > pg_num (#12025 Xinxin Shu)
524 * mon: prevent pool with snapshot state from being used as a tier (#11493 Sage Weil)
525 * mon: prime pg_temp when CRUSH map changes (Sage Weil)
526 * mon: refine check_remove_tier checks (#11504 John Spray)
527 * mon: reject large max_mds values (#12222 John Spray)
528 * mon: remove spurious who arg from 'mds rm ...' (John Spray)
529 * mon: streamline session handling, fix memory leaks (Sage Weil)
530 * mon: upgrades must pass through hammer (Sage Weil)
531 * mon: warn on bogus cache tier config (Jianpeng Ma)
532 * msgr: add ceph_perf_msgr tool (Hoamai Wang)
533 * msgr: async: fix seq handling (Haomai Wang)
534 * msgr: async: many many fixes (Haomai Wang)
535 * msgr: simple: fix clear_pipe (#11381 Haomai Wang)
536 * msgr: simple: fix connect_seq assert (Haomai Wang)
537 * msgr: xio: fastpath improvements (Raju Kurunkad)
538 * msgr: xio: fix ip and nonce (Raju Kurunkad)
539 * msgr: xio: improve lane assignment (Vu Pham)
540 * msgr: xio: sync with accellio v1.4 (Vu Pham)
541 * msgr: xio: misc fixes (#10735 Matt Benjamin, Kefu Chai, Danny Al-Gaaf, Raju Kurunkad, Vu Pham, Casey Bodley)
542 * msg: unit tests (Haomai Wang)
543 * objectcacher: misc bug fixes (Jianpeng Ma)
544 * osd: add latency perf counters for tier operations (Xinze Chi)
545 * osd: add misc perfcounters (Xinze Chi)
546 * osd: add simple sleep injection in recovery (Sage Weil)
547 * osd: allow SEEK_HOLE/SEEK_DATA for sparse read (Zhiqiang Wang)
548 * osd: avoid dup omap sets for in pg metadata (Sage Weil)
549 * osd: avoid multiple hit set insertions (Zhiqiang Wang)
550 * osd: avoid transaction append in some cases (Sage Weil)
551 * osd: break PG removal into multiple iterations (#10198 Guang Yang)
552 * osd: cache proxy-write support (Zhiqiang Wang, Samuel Just)
553 * osd: check scrub state when handling map (Jianpeng Ma)
554 * osd: clean up some constness, privateness (Kefu Chai)
555 * osd: clean up temp object if promotion fails (Jianpeng Ma)
556 * osd: configure promotion based on write recency (Zhiqiang Wang)
557 * osd: constrain collections to meta and PGs (normal and temp) (Sage Weil)
558 * osd: don't send dup MMonGetOSDMap requests (Sage Weil, Kefu Chai)
559 * osd: EIO injection (David Zhang)
560 * osd: elminiate txn apend, ECSubWrite copy (Samuel Just)
561 * osd: erasure-code: drop entries according to LRU (Andreas-Joachim Peters)
562 * osd: erasure-code: fix SHEC floating point bug (#12936 Loic Dachary)
563 * osd: erasure-code: update to ISA-L 2.14 (Yuan Zhou)
564 * osd: filejournal: cleanup (David Zafman)
565 * osd: filestore: clone using splice (Jianpeng Ma)
566 * osd: filestore: fix recursive lock (Xinxin Shu)
567 * osd: fix check_for_full (Henry Chang)
568 * osd: fix dirty accounting in make_writeable (Zhiqiang Wang)
569 * osd: fix dup promotion lost op bug (Zhiqiang Wang)
570 * osd: fix endless repair when object is unrecoverable (Jianpeng Ma, Kefu Chai)
571 * osd: fix hitset object naming to use GMT (Kefu Chai)
572 * osd: fix misc memory leaks (Sage Weil)
573 * osd: fix negative degraded stats during backfill (Guang Yang)
574 * osd: fix osdmap dump of blacklist items (John Spray)
575 * osd: fix peek_queue locking in FileStore (Xinze Chi)
576 * osd: fix pg resurrection (#11429 Samuel Just)
577 * osd: fix promotion vs full cache tier (Samuel Just)
578 * osd: fix replay requeue when pg is still activating (#13116 Samuel Just)
579 * osd: fix scrub stat bugs (Sage Weil, Samuel Just)
580 * osd: fix snap flushing from cache tier (again) (#11787 Samuel Just)
581 * osd: fix snap handling on promotion (#11296 Sam Just)
582 * osd: fix temp-clearing (David Zafman)
583 * osd: force promotion for ops EC can't handle (Zhiqiang Wang)
584 * osd: handle log split with overlapping entries (#11358 Samuel Just)
585 * osd: ignore non-existent osds in unfound calc (#10976 Mykola Golub)
586 * osd: improve behavior on machines with large memory pages (Steve Capper)
587 * osd: include a temp namespace within each collection/pgid (Sage Weil)
588 * osd: increase default max open files (Owen Synge)
589 * osd: keyvaluestore: misc fixes (Varada Kari)
590 * osd: low and high speed flush modes (Mingxin Liu)
591 * osd: make suicide timeouts individually configurable (Samuel Just)
592 * osd: merge multiple setattr calls into a setattrs call (Xinxin Shu)
593 * osd: misc fixes (Ning Yao, Kefu Chai, Xinze Chi, Zhiqiang Wang, Jianpeng Ma)
594 * osd: move scrub in OpWQ (Samuel Just)
595 * osd: newstore prototype (Sage Weil)
596 * osd: ObjectStore internal API refactor (Sage Weil)
597 * osd: peer_features includes self (David Zafman)
598 * osd: pool size change triggers new interval (#11771 Samuel Just)
599 * osd: prepopulate needs_recovery_map when only one peer has missing (#9558 Guang Yang)
600 * osd: randomize scrub times (#10973 Kefu Chai)
601 * osd: recovery, peering fixes (#11687 Samuel Just)
602 * osd: refactor scrub and digest recording (Sage Weil)
603 * osd: refuse first write to EC object at non-zero offset (Jianpeng Ma)
604 * osd: relax reply order on proxy read (#11211 Zhiqiang Wang)
605 * osd: require firefly features (David Zafman)
606 * osd: set initial crush weight with more precision (Sage Weil)
607 * osd: SHEC no longer experimental
608 * osd: skip promotion for flush/evict op (Zhiqiang Wang)
609 * osd: stripe over small xattrs to fit in XFS's 255 byte inline limit (Sage Weil, Ning Yao)
610 * osd: sync object_map on syncfs (Samuel Just)
611 * osd: take excl lock of op is rw (Samuel Just)
612 * osd: throttle evict ops (Yunchuan Wen)
613 * osd: upgrades must pass through hammer (Sage Weil)
614 * osd: use a temp object for recovery (Sage Weil)
615 * osd: use blkid to collection partition information (Joseph Handzik)
616 * osd: use SEEK_HOLE / SEEK_DATA for sparse copy (Xinxin Shu)
617 * osd: WBThrottle cleanups (Jianpeng Ma)
618 * osd: write journal header on clean shutdown (Xinze Chi)
619 * osdc/Objecter: allow per-pool calls to op_cancel_writes (John Spray)
620 * os/filestore: enlarge getxattr buffer size (Jianpeng Ma)
621 * pybind: pep8 cleanups (Danny Al-Gaaf)
622 * pycephfs: many fixes for bindings (Haomai Wang)
623 * qa: fix filelock_interrupt.py test (Yan, Zheng)
624 * qa: improve ceph-disk tests (Loic Dachary)
625 * qa: improve docker build layers (Loic Dachary)
626 * qa: run-make-check.sh script (Loic Dachary)
627 * rados: add --striper option to use libradosstriper (#10759 Sebastien Ponce)
628 * rados: bench: add --no-verify option to improve performance (Piotr Dalek)
629 * rados bench: misc fixes (Dmitry Yatsushkevich)
630 * rados: fix error message on failed pool removal (Wido den Hollander)
631 * radosgw-admin: add 'bucket check' function to repair bucket index (Yehuda Sadeh)
632 * radosgw-admin: fix subuser modify output (#12286 Guce)
633 * rados: handle --snapid arg properly (Abhishek Lekshmanan)
634 * rados: improve bench buffer handling, performance (Piotr Dalek)
635 * rados: misc bench fixes (Dmitry Yatsushkevich)
636 * rados: new pool import implementation (John Spray)
637 * rados: translate errno to string in CLI (#10877 Kefu Chai)
638 * rbd: accept map options config option (Ilya Dryomov)
639 * rbd: add disk usage tool (#7746 Jason Dillaman)
640 * rbd: allow unmapping by spec (Ilya Dryomov)
641 * rbd: cli: fix arg parsing with --io-pattern (Dmitry Yatsushkevich)
642 * rbd: deprecate --new-format option (Jason Dillman)
643 * rbd: fix error messages (#2862 Rajesh Nambiar)
644 * rbd: fix link issues (Jason Dillaman)
645 * rbd: improve CLI arg parsing, usage (Ilya Dryomov)
646 * rbd: rbd-replay-prep and rbd-replay improvements (Jason Dillaman)
647 * rbd: recognize queue_depth kernel option (Ilya Dryomov)
648 * rbd: support G and T units for CLI (Abhishek Lekshmanan)
649 * rbd: update rbd man page (Ilya Dryomov)
650 * rbd: update xfstests tests (Douglas Fuller)
651 * rbd: use image-spec and snap-spec in help (Vikhyat Umrao, Ilya Dryomov)
652 * rest-bench: misc fixes (Shawn Chen)
653 * rest-bench: support https (#3968 Yuan Zhou)
654 * rgw: add max multipart upload parts (#12146 Abshishek Dixit)
655 * rgw: add missing headers to Swift container details (#10666 Ahmad Faheem, Dmytro Iurchenko)
656 * rgw: add stats to headers for account GET (#10684 Yuan Zhou)
657 * rgw: add Trasnaction-Id to response (Abhishek Dixit)
658 * rgw: add X-Timestamp for Swift containers (#10938 Radoslaw Zarzynski)
659 * rgw: always check if token is expired (#11367 Anton Aksola, Riku Lehto)
660 * rgw: conversion tool to repair broken multipart objects (#12079 Yehuda Sadeh)
661 * rgw: document layout of pools and objects (Pete Zaitcev)
662 * rgw: do not enclose bucket header in quotes (#11860 Wido den Hollander)
663 * rgw: do not prefetch data for HEAD requests (Guang Yang)
664 * rgw: do not preserve ACLs when copying object (#12370 Yehuda Sadeh)
665 * rgw: do not set content-type if length is 0 (#11091 Orit Wasserman)
666 * rgw: don't clobber bucket/object owner when setting ACLs (#10978 Yehuda Sadeh)
667 * rgw: don't use end_marker for namespaced object listing (#11437 Yehuda Sadeh)
668 * rgw: don't use rgw_socket_path if frontend is configured (#11160 Yehuda Sadeh)
669 * rgw: enforce Content-Length for POST on Swift cont/obj (#10661 Radoslaw Zarzynski)
670 * rgw: error out if frontend did not send all data (#11851 Yehuda Sadeh)
671 * rgw: expose the number of unhealthy workers through admin socket (Guang Yang)
672 * rgw: fail if parts not specified on multipart upload (#11435 Yehuda Sadeh)
673 * rgw: fix assignment of copy obj attributes (#11563 Yehuda Sadeh)
674 * rgw: fix broken stats in container listing (#11285 Radoslaw Zarzynski)
675 * rgw: fix bug in domain/subdomain splitting (Robin H. Johnson)
676 * rgw: fix casing of Content-Type header (Robin H. Johnson)
677 * rgw: fix civetweb max threads (#10243 Yehuda Sadeh)
678 * rgw: fix Connection: header handling (#12298 Wido den Hollander)
679 * rgw: fix copy metadata, support X-Copied-From for swift (#10663 Radoslaw Zarzynski)
680 * rgw: fix data corruptions race condition (#11749 Wuxingyi)
681 * rgw: fix decoding of X-Object-Manifest from GET on Swift DLO (Radslow Rzarzynski)
682 * rgw: fix GET on swift account when limit == 0 (#10683 Radoslaw Zarzynski)
683 * rgw: fix handling empty metadata items on Swift container (#11088 Radoslaw Zarzynski)
684 * rgw: fix JSON response when getting user quota (#12117 Wuxingyi)
685 * rgw: fix locator for objects starting with _ (#11442 Yehuda Sadeh)
686 * rgw: fix log rotation (Wuxingyi)
687 * rgw: fix mulitipart upload in retry path (#11604 Yehuda Sadeh)
688 * rgw: fix quota enforcement on POST (#11323 Sergey Arkhipov)
689 * rgw: fix reset_loc (#11974 Yehuda Sadeh)
690 * rgw: fix return code on missing upload (#11436 Yehuda Sadeh)
691 * rgw: fix sysvinit script
692 * rgw: fix sysvinit script w/ multiple instances (Sage Weil, Pavan Rallabhandi)
693 * rgw: force content_type for swift bucket stats requests (#12095 Orit Wasserman)
694 * rgw: force content type header on responses with no body (#11438 Orit Wasserman)
695 * rgw: generate Date header for civetweb (#10873 Radoslaw Zarzynski)
696 * rgw: generate new object tag when setting attrs (#11256 Yehuda Sadeh)
697 * rgw: improve content-length env var handling (#11419 Robin H. Johnson)
698 * rgw: improved support for swift account metadata (Radoslaw Zarzynski)
699 * rgw: improve handling of already removed buckets in expirer (Radoslaw Rzarzynski)
700 * rgw: issue aio for first chunk before flush cached data (#11322 Guang Yang)
701 * rgw: log to /var/log/ceph instead of /var/log/radosgw
702 * rgw: make init script wait for radosgw to stop (#11140 Dmitry Yatsushkevich)
703 * rgw: make max put size configurable (#6999 Yuan Zhou)
704 * rgw: make quota/gc threads configurable (#11047 Guang Yang)
705 * rgw: make read user buckets backward compat (#10683 Radoslaw Zarzynski)
706 * rgw: merge manifests properly with prefix override (#11622 Yehuda Sadeh)
707 * rgw: only scan for objects not in a namespace (#11984 Yehuda Sadeh)
708 * rgw: orphan detection tool (Yehuda Sadeh)
709 * rgw: pass in civetweb configurables (#10907 Yehuda Sadeh)
710 * rgw: rectify 202 Accepted in PUT response (#11148 Radoslaw Zarzynski)
711 * rgw: remove meta file after deleting bucket (#11149 Orit Wasserman)
712 * rgw: remove trailing :port from HTTP_HOST header (Sage Weil)
713 * rgw: return 412 on bad limit when listing buckets (#11613 Yehuda Sadeh)
714 * rgw: rework X-Trans-Id header to conform with Swift API (Radoslaw Rzarzynski)
715 * rgw: s3 encoding-type for get bucket (Jeff Weber)
716 * rgw: send ETag, Last-Modified for swift (#11087 Radoslaw Zarzynski)
717 * rgw: set content length on container GET, PUT, DELETE, HEAD (#10971, #11036 Radoslaw Zarzynski)
718 * rgw: set max buckets per user in ceph.conf (Vikhyat Umrao)
719 * rgw: shard work over multiple librados instances (Pavan Rallabhandi)
720 * rgw: support end marker on swift container GET (#10682 Radoslaw Zarzynski)
721 * rgw: support for Swift expiration API (Radoslaw Rzarzynski, Yehuda Sadeh)
722 * rgw: swift: allow setting attributes with COPY (#10662 Ahmad Faheem, Dmytro Iurchenko)
723 * rgw: swift: do not override sent content type (#12363 Orit Wasserman)
724 * rgw: swift: enforce Content-Type in response (#12157 Radoslaw Zarzynski)
725 * rgw: swift: fix account listing (#11501 Radoslaw Zarzynski)
726 * rgw: swift: fix metadata handling on copy (#10645 Radoslaw Zarzynski)
727 * rgw: swift: send Last-Modified header (#10650 Radoslaw Zarzynski)
728 * rgw: swift: set Content-Length for account GET (#12158 Radoslav Zarzynski)
729 * rgw: swift: set content-length on keystone tokens (#11473 Herv Rousseau)
730 * rgw: update keystone cache with token info (#11125 Yehuda Sadeh)
731 * rgw: update to latest civetweb, enable config for IPv6 (#10965 Yehuda Sadeh)
732 * rgw: use attrs from source bucket on copy (#11639 Javier M. Mellid)
733 * rgw: use correct oid for gc chains (#11447 Yehuda Sadeh)
734 * rgw: user rm is idempotent (Orit Wasserman)
735 * rgw: use unique request id for civetweb (#10295 Orit Wasserman)
736 * rocksdb: add perf counters for get/put latency (Xinxin Shu)
737 * rocksdb, leveldb: fix compact_on_mount (Xiaoxi Chen)
738 * rocksdb: pass options as single string (Xiaoxi Chen)
739 * rocksdb: update to latest (Xiaoxi Chen)
740 * rpm: add suse firewall files (Tim Serong)
741 * rpm: always rebuild and install man pages for rpm (Owen Synge)
742 * rpm: loosen ceph-test dependencies (Ken Dreyer)
743 * rpm: many spec file fixes (Owen Synge, Ken Dreyer)
744 * rpm: misc fixes (Boris Ranto, Owen Synge, Ken Dreyer, Ira Cooper)
745 * rpm: misc systemd and SUSE fixes (Owen Synge, Nathan Cutler)
746 * selinux policy (Boris Ranto, Milan Broz)
747 * systemd: logrotate fixes (Tim Serong, Lars Marowsky-Bree, Nathan Cutler)
748 * systemd: many fixes (Sage Weil, Owen Synge, Boris Ranto, Dan van der Ster)
749 * systemd: run daemons as user ceph
750 * sysvinit compat: misc fixes (Owen Synge)
751 * test: misc fs test improvements (John Spray, Loic Dachary)
752 * test: python tests, linter cleanup (Alfredo Deza)
753 * tests: fixes for rbd xstests (Douglas Fuller)
754 * tests: fix tiering health checks (Loic Dachary)
755 * tests for low-level performance (Haomai Wang)
756 * tests: many ec non-regression improvements (Loic Dachary)
757 * tests: many many ec test improvements (Loic Dachary)
758 * upstart: throttle restarts (#11798 Sage Weil, Greg Farnum)
759
760
761 v9.1.0 Infernalis release candidate
762 ===================================
763
764 This is the first Infernalis release candidate. There have been some
765 major changes since Hammer, and the upgrade process is non-trivial.
766 Please read carefully.
767
768 Getting the release candidate
769 -----------------------------
770
771 The v9.1.0 packages are pushed to the development release repositories::
772
773 http://download.ceph.com/rpm-testing
774 http://download.ceph.com/debian-testing
775
776 For for info, see::
777
778 http://docs.ceph.com/docs/master/install/get-packages/
779
780 Or install with ceph-deploy via::
781
782 ceph-deploy install --testing HOST
783
784
785 Known issues
786 ------------
787
788 * librbd and librados ABI compatibility is broken. Be careful
789 installing this RC on client machines (e.g., those running qemu).
790 It will be fixed in the final v9.2.0 release.
791
792
793 Major Changes from Hammer
794 -------------------------
795
796 - *General*:
797
798 * Ceph daemons are now managed via systemd (with the exception of
799 Ubuntu Trusty, which still uses upstart).
800 * Ceph daemons run as 'ceph' user instead of root.
801 * On Red Hat distros, there is also an SELinux policy.
802
803 - *RADOS*:
804
805 * The RADOS cache tier can now proxy write operations to the base
806 tier, allowing writes to be handled without forcing migration of
807 an object into the cache.
808 * The SHEC erasure coding support is no longer flagged as
809 experimental. SHEC trades some additional storage space for faster
810 repair.
811 * There is now a unified queue (and thus prioritization) of client
812 IO, scrubbing, and snapshot trimming.
813 * There have been many improvements to low-level repair tooling
814 (ceph-objectstore-tool).
815 * The internal ObjectStore API has been significantly cleaned up in order
816 to facilitate new storage backends like NewStore.
817
818 - *RGW*:
819
820 * The Swift API now supports object expiration.
821 * There are many Swift API compatibility improvements.
822
823 - *RBD*:
824
825 * The ``rbd du`` command shows actual usage (quickly, when
826 object-map is enabled).
827 * The object-map feature has seen many stability improvements.
828 * Object-map and exclusive-lock features can be enabled or disabled
829 dynamically.
830 * You can now store user metadata and set persistent librbd options
831 associated with individual images.
832 * The new deep-flatten features allows flattening of a clone and all
833 of its snapshots. (Previously snapshots could not be flattened.)
834 * The export-diff command command is now faster (it uses aio). There is also
835 a new fast-diff feature.
836 * The --size argument can be specified with a suffix for units
837 (e.g., ``--size 64G``).
838 * There is a new ``rbd status`` command that, for now, shows who has
839 the image open/mapped.
840
841 - *CephFS*:
842
843 * You can now rename snapshots.
844 * There have been ongoing improvements around administration, diagnostics,
845 and the check and repair tools.
846 * The caching and revocation of client cache state due to unused
847 inodes has been dramatically improved.
848 * The ceph-fuse client behaves better on 32-bit hosts.
849
850 Distro compatibility
851 --------------------
852
853 We have decided to drop support for many older distributions so that we can
854 move to a newer compiler toolchain (e.g., C++11). Although it is still possible
855 to build Ceph on older distributions by installing backported development tools,
856 we are not building and publishing release packages for them on ceph.com.
857
858 In particular,
859
860 * CentOS 7 or later; we have dropped support for CentOS 6 (and other
861 RHEL 6 derivatives, like Scientific Linux 6).
862 * Debian Jessie 8.x or later; Debian Wheezy 7.x's g++ has incomplete
863 support for C++11 (and no systemd).
864 * Ubuntu Trusty 14.04 or later; Ubuntu Precise 12.04 is no longer
865 supported.
866 * Fedora 22 or later.
867
868 Upgrading from Firefly
869 ----------------------
870
871 Upgrading directly from Firefly v0.80.z is not possible. All clusters
872 must first upgrade to Hammer v0.94.4 or a later v0.94.z release; only
873 then is it possible to do online upgrade to Infernalis 9.2.z.
874
875 User can upgrade to latest hammer v0.94.z
876 from gitbuilder with(also refer the hammer release notes for more details)::
877
878 ceph-deploy install --release hammer HOST
879
880
881 Upgrading from Hammer
882 ---------------------
883
884 * All cluster nodes must first upgrade to Hammer v0.94.4 or a later v0.94.z release; only
885 then is it possible to do online upgrade to Infernalis 9.2.z.
886
887 * For all distributions that support systemd (CentOS 7, Fedora, Debian
888 Jessie 8.x, OpenSUSE), ceph daemons are now managed using native systemd
889 files instead of the legacy sysvinit scripts. For example::
890
891 systemctl start ceph.target # start all daemons
892 systemctl status ceph-osd@12 # check status of osd.12
893
894 The main notable distro that is *not* yet using systemd is Ubuntu trusty
895 14.04. (The next Ubuntu LTS, 16.04, will use systemd instead of upstart.)
896
897 * Ceph daemons now run as user and group ``ceph`` by default. The
898 ceph user has a static UID assigned by Fedora and Debian (also used
899 by derivative distributions like RHEL/CentOS and Ubuntu). On SUSE
900 the ceph user will currently get a dynamically assigned UID when the
901 user is created.
902
903 If your systems already have a ceph user, the package upgrade
904 process will usually fail with an error. We suggest you first
905 remove or rename the existing 'ceph' user and then upgrade.
906
907 When upgrading, administrators have two options:
908
909 #. Add the following line to ``ceph.conf`` on all hosts::
910
911 setuser match path = /var/lib/ceph/$type/$cluster-$id
912
913 This will make the Ceph daemons run as root (i.e., not drop
914 privileges and switch to user ceph) if the daemon's data
915 directory is still owned by root. Newly deployed daemons will
916 be created with data owned by user ceph and will run with
917 reduced privileges, but upgraded daemons will continue to run as
918 root.
919
920 #. Fix the data ownership during the upgrade. This is the preferred option,
921 but is more work. The process for each host would be to:
922
923 #. Upgrade the ceph package. This creates the ceph user and group. For
924 example::
925
926 ceph-deploy install --stable infernalis HOST
927
928 #. Stop the daemon(s)::
929
930 service ceph stop # fedora, centos, rhel, debian
931 stop ceph-all # ubuntu
932
933 #. Fix the ownership::
934
935 chown -R ceph:ceph /var/lib/ceph
936 chown -R ceph:ceph /var/log/ceph
937
938 #. Restart the daemon(s)::
939
940 start ceph-all # ubuntu
941 systemctl start ceph.target # debian, centos, fedora, rhel
942
943 * The on-disk format for the experimental KeyValueStore OSD backend has
944 changed. You will need to remove any OSDs using that backend before you
945 upgrade any test clusters that use it.
946
947 Upgrade notes
948 -------------
949
950 * When a pool quota is reached, librados operations now block indefinitely,
951 the same way they do when the cluster fills up. (Previously they would return
952 -ENOSPC). By default, a full cluster or pool will now block. If your
953 librados application can handle ENOSPC or EDQUOT errors gracefully, you can
954 get error returns instead by using the new librados OPERATION_FULL_TRY flag.
955
956 Notable changes
957 ---------------
958
959 NOTE: These notes are somewhat abbreviated while we find a less
960 time-consuming process for generating them.
961
962 * build: C++11 now supported
963 * build: many cmake improvements
964 * build: OSX build fixes (Yan, Zheng)
965 * build: remove rest-bench
966 * ceph-disk: many fixes (Loic Dachary)
967 * ceph-disk: support for multipath devices (Loic Dachary)
968 * ceph-fuse: mostly behave on 32-bit hosts (Yan, Zheng)
969 * ceph-objectstore-tool: many improvements (David Zafman)
970 * common: bufferlist performance tuning (Piotr Dalek, Sage Weil)
971 * common: make mutex more efficient
972 * common: some async compression infrastructure (Haomai Wang)
973 * librados: add FULL_TRY and FULL_FORCE flags for dealing with full clusters or pools (Sage Weil)
974 * librados: fix notify completion race (#13114 Sage Weil)
975 * librados, libcephfs: randomize client nonces (Josh Durgin)
976 * librados: pybind: fix binary omap values (Robin H. Johnson)
977 * librbd: fix reads larger than the cache size (Lu Shi)
978 * librbd: metadata filter fixes (Haomai Wang)
979 * librbd: use write_full when possible (Zhiqiang Wang)
980 * mds: avoid emitting cap warnigns before evicting session (John Spray)
981 * mds: fix expected holes in journal objects (#13167 Yan, Zheng)
982 * mds: fix SnapServer crash on deleted pool (John Spray)
983 * mds: many fixes (Yan, Zheng, John Spray, Greg Farnum)
984 * mon: add cache over MonitorDBStore (Kefu Chai)
985 * mon: 'ceph osd metadata' can dump all osds (Haomai Wang)
986 * mon: detect kv backend failures (Sage Weil)
987 * mon: fix CRUSH map test for new pools (Sage Weil)
988 * mon: fix min_last_epoch_clean tracking (Kefu Chai)
989 * mon: misc scaling fixes (Sage Weil)
990 * mon: streamline session handling, fix memory leaks (Sage Weil)
991 * mon: upgrades must pass through hammer (Sage Weil)
992 * msg/async: many fixes (Haomai Wang)
993 * osd: cache proxy-write support (Zhiqiang Wang, Samuel Just)
994 * osd: configure promotion based on write recency (Zhiqiang Wang)
995 * osd: don't send dup MMonGetOSDMap requests (Sage Weil, Kefu Chai)
996 * osd: erasure-code: fix SHEC floating point bug (#12936 Loic Dachary)
997 * osd: erasure-code: update to ISA-L 2.14 (Yuan Zhou)
998 * osd: fix hitset object naming to use GMT (Kefu Chai)
999 * osd: fix misc memory leaks (Sage Weil)
1000 * osd: fix peek_queue locking in FileStore (Xinze Chi)
1001 * osd: fix promotion vs full cache tier (Samuel Just)
1002 * osd: fix replay requeue when pg is still activating (#13116 Samuel Just)
1003 * osd: fix scrub stat bugs (Sage Weil, Samuel Just)
1004 * osd: force promotion for ops EC can't handle (Zhiqiang Wang)
1005 * osd: improve behavior on machines with large memory pages (Steve Capper)
1006 * osd: merge multiple setattr calls into a setattrs call (Xinxin Shu)
1007 * osd: newstore prototype (Sage Weil)
1008 * osd: ObjectStore internal API refactor (Sage Weil)
1009 * osd: SHEC no longer experimental
1010 * osd: throttle evict ops (Yunchuan Wen)
1011 * osd: upgrades must pass through hammer (Sage Weil)
1012 * osd: use SEEK_HOLE / SEEK_DATA for sparse copy (Xinxin Shu)
1013 * rbd: rbd-replay-prep and rbd-replay improvements (Jason Dillaman)
1014 * rgw: expose the number of unhealthy workers through admin socket (Guang Yang)
1015 * rgw: fix casing of Content-Type header (Robin H. Johnson)
1016 * rgw: fix decoding of X-Object-Manifest from GET on Swift DLO (Radslow Rzarzynski)
1017 * rgw: fix sysvinit script
1018 * rgw: fix sysvinit script w/ multiple instances (Sage Weil, Pavan Rallabhandi)
1019 * rgw: improve handling of already removed buckets in expirer (Radoslaw Rzarzynski)
1020 * rgw: log to /var/log/ceph instead of /var/log/radosgw
1021 * rgw: rework X-Trans-Id header to be conform with Swift API (Radoslaw Rzarzynski)
1022 * rgw: s3 encoding-type for get bucket (Jeff Weber)
1023 * rgw: set max buckets per user in ceph.conf (Vikhyat Umrao)
1024 * rgw: support for Swift expiration API (Radoslaw Rzarzynski, Yehuda Sadeh)
1025 * rgw: user rm is idempotent (Orit Wasserman)
1026 * selinux policy (Boris Ranto, Milan Broz)
1027 * systemd: many fixes (Sage Weil, Owen Synge, Boris Ranto, Dan van der Ster)
1028 * systemd: run daemons as user ceph
1029
1030
1031 v9.0.3
1032 ======
1033
1034 This is the second to last batch of development work for the
1035 Infernalis cycle. The most intrusive change is an internal (non
1036 user-visible) change to the OSD's ObjectStore interface. Many fixes and
1037 improvements elsewhere across RGW, RBD, and another big pile of CephFS
1038 scrub/repair improvements.
1039
1040 Upgrading
1041 ---------
1042
1043 * The return code for librbd's rbd_aio_read and Image::aio_read API methods no
1044 longer returns the number of bytes read upon success. Instead, it returns 0
1045 upon success and a negative value upon failure.
1046
1047 * 'ceph scrub', 'ceph compact' and 'ceph sync force' are now deprecated. Users
1048 should instead use 'ceph mon scrub', 'ceph mon compact' and
1049 'ceph mon sync force'.
1050
1051 * 'ceph mon_metadata' should now be used as 'ceph mon metadata'.
1052
1053 * The `--dump-json` option of "osdmaptool" is replaced by `--dump json`.
1054
1055 * The commands of 'pg ls-by-{pool,primary,osd}' and 'pg ls' now take 'recovering'
1056 instead of 'recovery' to include the recovering pgs in the listed pgs.
1057
1058
1059 Notable Changes
1060 ---------------
1061
1062 * autotools: fix out of tree build (Krxysztof Kosinski)
1063 * autotools: improve make check output (Loic Dachary)
1064 * buffer: add invalidate_crc() (Piotr Dalek)
1065 * buffer: fix zero bug (#12252 Haomai Wang)
1066 * build: fix junit detection on Fedora 22 (Ira Cooper)
1067 * ceph-disk: install pip > 6.1 (#11952 Loic Dachary)
1068 * cephfs-data-scan: many additions, improvements (John Spray)
1069 * ceph: improve error output for 'tell' (#11101 Kefu Chai)
1070 * ceph-objectstore-tool: misc improvements (David Zafman)
1071 * ceph-objectstore-tool: refactoring and cleanup (John Spray)
1072 * ceph_test_rados: test pipelined reads (Zhiqiang Wang)
1073 * common: fix bit_vector extent calc (#12611 Jason Dillaman)
1074 * common: make work queue addition/removal thread safe (#12662 Jason Dillaman)
1075 * common: optracker improvements (Zhiqiang Wang, Jianpeng Ma)
1076 * crush: add --check to validate dangling names, max osd id (Kefu Chai)
1077 * crush: cleanup, sync with kernel (Ilya Dryomov)
1078 * crush: fix subtree base weight on adjust_subtree_weight (#11855 Sage Weil)
1079 * crypo: fix NSS leak (Jason Dillaman)
1080 * crypto: fix unbalanced init/shutdown (#12598 Zheng Yan)
1081 * doc: misc updates (Kefu Chai, Owen Synge, Gael Fenet-Garde, Loic Dachary, Yannick Atchy-Dalama, Jiaying Ren, Kevin Caradant, Robert Maxime, Nicolas Yong, Germain Chipaux, Arthur Gorjux, Gabriel Sentucq, Clement Lebrun, Jean-Remi Deveaux, Clair Massot, Robin Tang, Thomas Laumondais, Jordan Dorne, Yuan Zhou, Valentin Thomas, Pierre Chaumont, Benjamin Troquereau, Benjamin Sesia, Vikhyat Umrao)
1082 * erasure-code: cleanup (Kefu Chai)
1083 * erasure-code: improve tests (Loic Dachary)
1084 * erasure-code: shec: fix recovery bugs (Takanori Nakao, Shotaro Kawaguchi)
1085 * libcephfs: add pread, pwrite (Jevon Qiao)
1086 * libcephfs,ceph-fuse: cache cleanup (Zheng Yan)
1087 * librados: add src_fadvise_flags for copy-from (Jianpeng Ma)
1088 * librados: respect default_crush_ruleset on pool_create (#11640 Yuan Zhou)
1089 * librbd: fadvise for copy, export, import (Jianpeng Ma)
1090 * librbd: handle NOCACHE fadvise flag (Jinapeng Ma)
1091 * librbd: optionally disable allocation hint (Haomai Wang)
1092 * librbd: prevent race between resize requests (#12664 Jason Dillaman)
1093 * log: fix data corruption race resulting from log rotation (#12465 Samuel Just)
1094 * mds: expose frags via asok (John Spray)
1095 * mds: fix setting entire file layout in one setxattr (John Spray)
1096 * mds: fix shutdown (John Spray)
1097 * mds: handle misc corruption issues (John Spray)
1098 * mds: misc fixes (Jianpeng Ma, Dan van der Ster, Zhang Zhi)
1099 * mds: misc snap fixes (Zheng Yan)
1100 * mds: store layout on header object (#4161 John Spray)
1101 * misc performance and cleanup (Nathan Cutler, Xinxin Shu)
1102 * mon: add NOFORWARD, OBSOLETE, DEPRECATE flags for mon commands (Joao Eduardo Luis)
1103 * mon: add PG count to 'ceph osd df' output (Michal Jarzabek)
1104 * mon: clean up, reorg some mon commands (Joao Eduardo Luis)
1105 * mon: disallow >2 tiers (#11840 Kefu Chai)
1106 * mon: fix log dump crash when debugging (Mykola Golub)
1107 * mon: fix metadata update race (Mykola Golub)
1108 * mon: fix refresh (#11470 Joao Eduardo Luis)
1109 * mon: make blocked op messages more readable (Jianpeng Ma)
1110 * mon: only send mon metadata to supporting peers (Sage Weil)
1111 * mon: periodic background scrub (Joao Eduardo Luis)
1112 * mon: prevent pgp_num > pg_num (#12025 Xinxin Shu)
1113 * mon: reject large max_mds values (#12222 John Spray)
1114 * msgr: add ceph_perf_msgr tool (Hoamai Wang)
1115 * msgr: async: fix seq handling (Haomai Wang)
1116 * msgr: xio: fastpath improvements (Raju Kurunkad)
1117 * msgr: xio: sync with accellio v1.4 (Vu Pham)
1118 * osd: clean up temp object if promotion fails (Jianpeng Ma)
1119 * osd: constrain collections to meta and PGs (normal and temp) (Sage Weil)
1120 * osd: filestore: clone using splice (Jianpeng Ma)
1121 * osd: filestore: fix recursive lock (Xinxin Shu)
1122 * osd: fix dup promotion lost op bug (Zhiqiang Wang)
1123 * osd: fix temp-clearing (David Zafman)
1124 * osd: include a temp namespace within each collection/pgid (Sage Weil)
1125 * osd: low and high speed flush modes (Mingxin Liu)
1126 * osd: peer_features includes self (David Zafman)
1127 * osd: recovery, peering fixes (#11687 Samuel Just)
1128 * osd: require firefly features (David Zafman)
1129 * osd: set initial crush weight with more precision (Sage Weil)
1130 * osd: use a temp object for recovery (Sage Weil)
1131 * osd: use blkid to collection partition information (Joseph Handzik)
1132 * rados: add --striper option to use libradosstriper (#10759 Sebastien Ponce)
1133 * radosgw-admin: fix subuser modify output (#12286 Guce)
1134 * rados: handle --snapid arg properly (Abhishek Lekshmanan)
1135 * rados: improve bench buffer handling, performance (Piotr Dalek)
1136 * rados: new pool import implementation (John Spray)
1137 * rbd: fix link issues (Jason Dillaman)
1138 * rbd: improve CLI arg parsing, usage (Ilya Dryomov)
1139 * rbd: recognize queue_depth kernel option (Ilya Dryomov)
1140 * rbd: support G and T units for CLI (Abhishek Lekshmanan)
1141 * rbd: use image-spec and snap-spec in help (Vikhyat Umrao, Ilya Dryomov)
1142 * rest-bench: misc fixes (Shawn Chen)
1143 * rest-bench: support https (#3968 Yuan Zhou)
1144 * rgw: add max multipart upload parts (#12146 Abshishek Dixit)
1145 * rgw: add Trasnaction-Id to response (Abhishek Dixit)
1146 * rgw: document layout of pools and objects (Pete Zaitcev)
1147 * rgw: do not preserve ACLs when copying object (#12370 Yehuda Sadeh)
1148 * rgw: fix Connection: header handling (#12298 Wido den Hollander)
1149 * rgw: fix data corruptions race condition (#11749 Wuxingyi)
1150 * rgw: fix JSON response when getting user quota (#12117 Wuxingyi)
1151 * rgw: force content_type for swift bucket stats requests (#12095 Orit Wasserman)
1152 * rgw: improved support for swift account metadata (Radoslaw Zarzynski)
1153 * rgw: make max put size configurable (#6999 Yuan Zhou)
1154 * rgw: orphan detection tool (Yehuda Sadeh)
1155 * rgw: swift: do not override sent content type (#12363 Orit Wasserman)
1156 * rgw: swift: set Content-Length for account GET (#12158 Radoslav Zarzynski)
1157 * rpm: always rebuild and install man pages for rpm (Owen Synge)
1158 * rpm: misc fixes (Boris Ranto, Owen Synge, Ken Dreyer, Ira Cooper)
1159 * systemd: logrotate fixes (Tim Seron, Lars Marowsky-Bree, Nathan Cutler)
1160 * sysvinit compat: misc fixes (Owen Synge)
1161 * test: misc fs test improvements (John Spray, Loic Dachary)
1162 * test: python tests, linter cleanup (Alfredo Deza)
1163
1164
1165 v9.0.2
1166 ======
1167
1168 This development release features more of the OSD work queue
1169 unification, randomized osd scrub times, a huge pile of librbd fixes,
1170 more MDS repair and snapshot fixes, and a significant amount of work
1171 on the tests and build infrastructure.
1172
1173 Notable Changes
1174 ---------------
1175
1176 * buffer: some cleanup (Michal Jarzabek)
1177 * build: cmake: fix nss linking (Danny Al-Gaaf)
1178 * build: cmake: misc fixes (Orit Wasserman, Casey Bodley)
1179 * build: install-deps: misc fixes (Loic Dachary)
1180 * build: make_dist_tarball.sh (Sage Weil)
1181 * ceph-detect-init: added Linux Mint (Michal Jarzabek)
1182 * ceph-detect-init: robust init system detection (Owen Synge, Loic Dachary)
1183 * ceph-disk: ensure 'zap' only operates on a full disk (#11272 Loic Dachary)
1184 * ceph-disk: misc fixes to respect init system (Loic Dachary, Owen Synge)
1185 * ceph-disk: support NVMe device partitions (#11612 Ilja Slepnev)
1186 * ceph: fix 'df' units (Zhe Zhang)
1187 * ceph: fix parsing in interactive cli mode (#11279 Kefu Chai)
1188 * ceph-objectstore-tool: many many changes (David Zafman)
1189 * ceph-post-file: misc fixes (Joey McDonald, Sage Weil)
1190 * client: avoid sending unnecessary FLUSHSNAP messages (Yan, Zheng)
1191 * client: exclude setfilelock when calculating oldest tid (Yan, Zheng)
1192 * client: fix error handling in check_pool_perm (John Spray)
1193 * client: fsync waits only for inode's caps to flush (Yan, Zheng)
1194 * client: invalidate kernel dcache when cache size exceeds limits (Yan, Zheng)
1195 * client: make fsync wait for unsafe dir operations (Yan, Zheng)
1196 * client: pin lookup dentry to avoid inode being freed (Yan, Zheng)
1197 * common: detect overflow of int config values (#11484 Kefu Chai)
1198 * common: fix json parsing of utf8 (#7387 Tim Serong)
1199 * common: fix leak of pthread_mutexattr (#11762 Ketor Meng)
1200 * crush: respect default replicated ruleset config on map creation (Ilya Dryomov)
1201 * deb, rpm: move ceph-objectstore-tool to ceph (Ken Dreyer)
1202 * doc: man page updates (Kefu Chai)
1203 * doc: misc updates (#11396 Nilamdyuti, Fracois Lafont, Ken Dreyer, Kefu Chai)
1204 * init-radosgw: merge with sysv version; fix enumeration (Sage Weil)
1205 * librados: add config observer (Alistair Strachan)
1206 * librbd: add const for single-client-only features (Josh Durgin)
1207 * librbd: add deep-flatten operation (Jason Dillaman)
1208 * librbd: avoid blocking aio API methods (#11056 Jason Dillaman)
1209 * librbd: fix fast diff bugs (#11553 Jason Dillaman)
1210 * librbd: fix image format detection (Zhiqiang Wang)
1211 * librbd: fix lock ordering issue (#11577 Jason Dillaman)
1212 * librbd: flatten/copyup fixes (Jason Dillaman)
1213 * librbd: lockdep, helgrind validation (Jason Dillaman, Josh Durgin)
1214 * librbd: only update image flags while hold exclusive lock (#11791 Jason Dillaman)
1215 * librbd: return result code from close (#12069 Jason Dillaman)
1216 * librbd: tolerate old osds when getting image metadata (#11549 Jason Dillaman)
1217 * mds: do not add snapped items to bloom filter (Yan, Zheng)
1218 * mds: fix handling for missing mydir dirfrag (#11641 John Spray)
1219 * mds: fix rejoin (Yan, Zheng)
1220 * mds: fix stra reintegration (Yan, Zheng)
1221 * mds: fix suicide beason (John Spray)
1222 * mds: misc repair improvements (John Spray)
1223 * mds: misc snapshot fixes (Yan, Zheng)
1224 * mds: respawn instead of suicide on blacklist (John Spray)
1225 * misc coverity fixes (Danny Al-Gaaf)
1226 * mon: add 'mon_metadata <id>' command (Kefu Chai)
1227 * mon: add 'node ls ...' command (Kefu Chai)
1228 * mon: disallow ec pools as tiers (#11650 Samuel Just)
1229 * mon: fix mds beacon replies (#11590 Kefu Chai)
1230 * mon: fix 'pg ls' sort order, state names (#11569 Kefu Chai)
1231 * mon: normalize erasure-code profile for storage and comparison (Loic Dachary)
1232 * mon: optionally specify osd id on 'osd create' (Mykola Golub)
1233 * mon: 'osd tree' fixes (Kefu Chai)
1234 * mon: prevent pool with snapshot state from being used as a tier (#11493 Sage Weil)
1235 * mon: refine check_remove_tier checks (#11504 John Spray)
1236 * mon: remove spurious who arg from 'mds rm ...' (John Spray)
1237 * msgr: async: misc fixes (Haomai Wang)
1238 * msgr: xio: fix ip and nonce (Raju Kurunkad)
1239 * msgr: xio: improve lane assignment (Vu Pham)
1240 * msgr: xio: misc fixes (Vu Pham, Cosey Bodley)
1241 * osd: avoid transaction append in some cases (Sage Weil)
1242 * osdc/Objecter: allow per-pool calls to op_cancel_writes (John Spray)
1243 * osd: elminiate txn apend, ECSubWrite copy (Samuel Just)
1244 * osd: filejournal: cleanup (David Zafman)
1245 * osd: fix check_for_full (Henry Chang)
1246 * osd: fix dirty accounting in make_writeable (Zhiqiang Wang)
1247 * osd: fix osdmap dump of blacklist items (John Spray)
1248 * osd: fix snap flushing from cache tier (again) (#11787 Samuel Just)
1249 * osd: fix snap handling on promotion (#11296 Sam Just)
1250 * osd: handle log split with overlapping entries (#11358 Samuel Just)
1251 * osd: keyvaluestore: misc fixes (Varada Kari)
1252 * osd: make suicide timeouts individually configurable (Samuel Just)
1253 * osd: move scrub in OpWQ (Samuel Just)
1254 * osd: pool size change triggers new interval (#11771 Samuel Just)
1255 * osd: randomize scrub times (#10973 Kefu Chai)
1256 * osd: refactor scrub and digest recording (Sage Weil)
1257 * osd: refuse first write to EC object at non-zero offset (Jianpeng Ma)
1258 * osd: stripe over small xattrs to fit in XFS's 255 byte inline limit (Sage Weil, Ning Yao)
1259 * osd: sync object_map on syncfs (Samuel Just)
1260 * osd: take excl lock of op is rw (Samuel Just)
1261 * osd: WBThrottle cleanups (Jianpeng Ma)
1262 * pycephfs: many fixes for bindings (Haomai Wang)
1263 * rados: bench: add --no-verify option to improve performance (Piotr Dalek)
1264 * rados: misc bench fixes (Dmitry Yatsushkevich)
1265 * rbd: add disk usage tool (#7746 Jason Dillaman)
1266 * rgw: alwasy check if token is expired (#11367 Anton Aksola, Riku Lehto)
1267 * rgw: conversion tool to repair broken multipart objects (#12079 Yehuda Sadeh)
1268 * rgw: do not enclose bucket header in quotes (#11860 Wido den Hollander)
1269 * rgw: error out if frontend did not send all data (#11851 Yehuda Sadeh)
1270 * rgw: fix assignment of copy obj attributes (#11563 Yehuda Sadeh)
1271 * rgw: fix reset_loc (#11974 Yehuda Sadeh)
1272 * rgw: improve content-length env var handling (#11419 Robin H. Johnson)
1273 * rgw: only scan for objects not in a namespace (#11984 Yehuda Sadeh)
1274 * rgw: remove trailing :port from HTTP_HOST header (Sage Weil)
1275 * rgw: shard work over multiple librados instances (Pavan Rallabhandi)
1276 * rgw: swift: enforce Content-Type in response (#12157 Radoslaw Zarzynski)
1277 * rgw: use attrs from source bucket on copy (#11639 Javier M. Mellid)
1278 * rocksdb: pass options as single string (Xiaoxi Chen)
1279 * rpm: many spec file fixes (Owen Synge, Ken Dreyer)
1280 * tests: fixes for rbd xstests (Douglas Fuller)
1281 * tests: fix tiering health checks (Loic Dachary)
1282 * tests for low-level performance (Haomai Wang)
1283 * tests: many ec non-regression improvements (Loic Dachary)
1284 * tests: many many ec test improvements (Loic Dachary)
1285 * upstart: throttle restarts (#11798 Sage Weil, Greg Farnum)
1286
1287
1288 v9.0.1
1289 ======
1290
1291 This development release is delayed a bit due to tooling changes in the build
1292 environment. As a result the next one (v9.0.2) will have a bit more work than
1293 is usual.
1294
1295 Highlights here include lots of RGW Swift fixes, RBD feature work
1296 surrounding the new object map feature, more CephFS snapshot fixes,
1297 and a few important CRUSH fixes.
1298
1299 Notable Changes
1300 ---------------
1301
1302 * auth: cache/reuse crypto lib key objects, optimize msg signature check (Sage Weil)
1303 * build: allow tcmalloc-minimal (Thorsten Behrens)
1304 * build: do not build ceph-dencoder with tcmalloc (#10691 Boris Ranto)
1305 * build: fix pg ref disabling (William A. Kennington III)
1306 * build: install-deps.sh improvements (Loic Dachary)
1307 * build: misc fixes (Boris Ranto, Ken Dreyer, Owen Synge)
1308 * ceph-authtool: fix return code on error (Gerhard Muntingh)
1309 * ceph-disk: fix zap sgdisk invocation (Owen Synge, Thorsten Behrens)
1310 * ceph-disk: pass --cluster arg on prepare subcommand (Kefu Chai)
1311 * ceph-fuse, libcephfs: drop inode when rmdir finishes (#11339 Yan, Zheng)
1312 * ceph-fuse,libcephfs: fix uninline (#11356 Yan, Zheng)
1313 * ceph-monstore-tool: fix store-copy (Huangjun)
1314 * common: add perf counter descriptions (Alyona Kiseleva)
1315 * common: fix throttle max change (Henry Chang)
1316 * crush: fix crash from invalid 'take' argument (#11602 Shiva Rkreddy, Sage Weil)
1317 * crush: fix divide-by-2 in straw2 (#11357 Yann Dupont, Sage Weil)
1318 * deb: fix rest-bench-dbg and ceph-test-dbg dependendies (Ken Dreyer)
1319 * doc: document region hostnames (Robin H. Johnson)
1320 * doc: update release schedule docs (Loic Dachary)
1321 * init-radosgw: run radosgw as root (#11453 Ken Dreyer)
1322 * librados: fadvise flags per op (Jianpeng Ma)
1323 * librbd: allow additional metadata to be stored with the image (Haomai Wang)
1324 * librbd: better handling for dup flatten requests (#11370 Jason Dillaman)
1325 * librbd: cancel in-flight ops on watch error (#11363 Jason Dillaman)
1326 * librbd: default new images to format 2 (#11348 Jason Dillaman)
1327 * librbd: fast diff implementation that leverages object map (Jason Dillaman)
1328 * librbd: fix snapshot creation when other snap is active (#11475 Jason Dillaman)
1329 * librbd: new diff_iterate2 API (Jason Dillaman)
1330 * librbd: object map rebuild support (Jason Dillaman)
1331 * logrotate.d: prefer service over invoke-rc.d (#11330 Win Hierman, Sage Weil)
1332 * mds: avoid getting stuck in XLOCKDONE (#11254 Yan, Zheng)
1333 * mds: fix integer truncateion on large client ids (Henry Chang)
1334 * mds: many snapshot and stray fixes (Yan, Zheng)
1335 * mds: persist completed_requests reliably (#11048 John Spray)
1336 * mds: separate safe_pos in Journaler (#10368 John Spray)
1337 * mds: snapshot rename support (#3645 Yan, Zheng)
1338 * mds: warn when clients fail to advance oldest_client_tid (#10657 Yan, Zheng)
1339 * misc cleanups and fixes (Danny Al-Gaaf)
1340 * mon: fix average utilization calc for 'osd df' (Mykola Golub)
1341 * mon: fix variance calc in 'osd df' (Sage Weil)
1342 * mon: improve callout to crushtool (Mykola Golub)
1343 * mon: prevent bucket deletion when referenced by a crush rule (#11602 Sage Weil)
1344 * mon: prime pg_temp when CRUSH map changes (Sage Weil)
1345 * monclient: flush_log (John Spray)
1346 * msgr: async: many many fixes (Haomai Wang)
1347 * msgr: simple: fix clear_pipe (#11381 Haomai Wang)
1348 * osd: add latency perf counters for tier operations (Xinze Chi)
1349 * osd: avoid multiple hit set insertions (Zhiqiang Wang)
1350 * osd: break PG removal into multiple iterations (#10198 Guang Yang)
1351 * osd: check scrub state when handling map (Jianpeng Ma)
1352 * osd: fix endless repair when object is unrecoverable (Jianpeng Ma, Kefu Chai)
1353 * osd: fix pg resurrection (#11429 Samuel Just)
1354 * osd: ignore non-existent osds in unfound calc (#10976 Mykola Golub)
1355 * osd: increase default max open files (Owen Synge)
1356 * osd: prepopulate needs_recovery_map when only one peer has missing (#9558 Guang Yang)
1357 * osd: relax reply order on proxy read (#11211 Zhiqiang Wang)
1358 * osd: skip promotion for flush/evict op (Zhiqiang Wang)
1359 * osd: write journal header on clean shutdown (Xinze Chi)
1360 * qa: run-make-check.sh script (Loic Dachary)
1361 * rados bench: misc fixes (Dmitry Yatsushkevich)
1362 * rados: fix error message on failed pool removal (Wido den Hollander)
1363 * radosgw-admin: add 'bucket check' function to repair bucket index (Yehuda Sadeh)
1364 * rbd: allow unmapping by spec (Ilya Dryomov)
1365 * rbd: deprecate --new-format option (Jason Dillman)
1366 * rgw: do not set content-type if length is 0 (#11091 Orit Wasserman)
1367 * rgw: don't use end_marker for namespaced object listing (#11437 Yehuda Sadeh)
1368 * rgw: fail if parts not specified on multipart upload (#11435 Yehuda Sadeh)
1369 * rgw: fix GET on swift account when limit == 0 (#10683 Radoslaw Zarzynski)
1370 * rgw: fix broken stats in container listing (#11285 Radoslaw Zarzynski)
1371 * rgw: fix bug in domain/subdomain splitting (Robin H. Johnson)
1372 * rgw: fix civetweb max threads (#10243 Yehuda Sadeh)
1373 * rgw: fix copy metadata, support X-Copied-From for swift (#10663 Radoslaw Zarzynski)
1374 * rgw: fix locator for objects starting with _ (#11442 Yehuda Sadeh)
1375 * rgw: fix mulitipart upload in retry path (#11604 Yehuda Sadeh)
1376 * rgw: fix quota enforcement on POST (#11323 Sergey Arkhipov)
1377 * rgw: fix return code on missing upload (#11436 Yehuda Sadeh)
1378 * rgw: force content type header on responses with no body (#11438 Orit Wasserman)
1379 * rgw: generate new object tag when setting attrs (#11256 Yehuda Sadeh)
1380 * rgw: issue aio for first chunk before flush cached data (#11322 Guang Yang)
1381 * rgw: make read user buckets backward compat (#10683 Radoslaw Zarzynski)
1382 * rgw: merge manifests properly with prefix override (#11622 Yehuda Sadeh)
1383 * rgw: return 412 on bad limit when listing buckets (#11613 Yehuda Sadeh)
1384 * rgw: send ETag, Last-Modified for swift (#11087 Radoslaw Zarzynski)
1385 * rgw: set content length on container GET, PUT, DELETE, HEAD (#10971, #11036 Radoslaw Zarzynski)
1386 * rgw: support end marker on swift container GET (#10682 Radoslaw Zarzynski)
1387 * rgw: swift: fix account listing (#11501 Radoslaw Zarzynski)
1388 * rgw: swift: set content-length on keystone tokens (#11473 Herv Rousseau)
1389 * rgw: use correct oid for gc chains (#11447 Yehuda Sadeh)
1390 * rgw: use unique request id for civetweb (#10295 Orit Wasserman)
1391 * rocksdb, leveldb: fix compact_on_mount (Xiaoxi Chen)
1392 * rocksdb: add perf counters for get/put latency (Xinxin Shu)
1393 * rpm: add suse firewall files (Tim Serong)
1394 * rpm: misc systemd and suse fixes (Owen Synge, Nathan Cutler)
1395
1396
1397
1398 v9.0.0
1399 ======
1400
1401 This is the first development release for the Infernalis cycle, and
1402 the first Ceph release to sport a version number from the new
1403 numbering scheme. The "9" indicates this is the 9th release cycle--I
1404 (for Infernalis) is the 9th letter. The first "0" indicates this is a
1405 development release ("1" will mean release candidate and "2" will mean
1406 stable release), and the final "0" indicates this is the first such
1407 development release.
1408
1409 A few highlights include:
1410
1411 * a new 'ceph daemonperf' command to watch perfcounter stats in realtime
1412 * reduced MDS memory usage
1413 * many MDS snapshot fixes
1414 * librbd can now store options in the image itself
1415 * many fixes for RGW Swift API support
1416 * OSD performance improvements
1417 * many doc updates and misc bug fixes
1418
1419 Notable Changes
1420 ---------------
1421
1422 * aarch64: add optimized version of crc32c (Yazen Ghannam, Steve Capper)
1423 * auth: reinit NSS after fork() (#11128 Yan, Zheng)
1424 * build: disable LTTNG by default (#11333 Josh Durgin)
1425 * build: fix ppc build (James Page)
1426 * build: install-deps: support OpenSUSE (Loic Dachary)
1427 * build: misc cmake fixes (Matt Benjamin)
1428 * ceph-disk: follow ceph-osd hints when creating journal (#9580 Sage Weil)
1429 * ceph-disk: handle re-using existing partition (#10987 Loic Dachary)
1430 * ceph-disk: improve parted output parsing (#10983 Loic Dachary)
1431 * ceph-disk: make suppression work for activate-all and activate-journal (Dan van der Ster)
1432 * ceph-disk: misc fixes (Alfredo Deza)
1433 * ceph-fuse, libcephfs: don't clear COMPLETE when trimming null (Yan, Zheng)
1434 * ceph-fuse, libcephfs: hold exclusive caps on dirs we "own" (#11226 Greg Farnum)
1435 * ceph-fuse: do not require successful remount when unmounting (#10982 Greg Farnum)
1436 * ceph: new 'ceph daemonperf' command (John Spray, Mykola Golub)
1437 * common: PriorityQueue tests (Kefu Chai)
1438 * common: add descriptions to perfcounters (Kiseleva Alyona)
1439 * common: fix LTTNG vs fork issue (Josh Durgin)
1440 * crush: fix has_v4_buckets (#11364 Sage Weil)
1441 * crushtool: fix order of operations, usage (Sage Weil)
1442 * debian: minor package reorg (Ken Dreyer)
1443 * doc: docuemnt object corpus generation (#11099 Alexis Normand)
1444 * doc: fix gender neutrality (Alexandre Maragone)
1445 * doc: fix install doc (#10957 Kefu Chai)
1446 * doc: fix sphinx issues (Kefu Chai)
1447 * doc: mds data structure docs (Yan, Zheng)
1448 * doc: misc updates (Nilamdyuti Goswami, Vartika Rai, Florian Haas, Loic Dachary, Simon Guinot, Andy Allan, Alistair Israel, Ken Dreyer, Robin Rehu, Lee Revell, Florian Marsylle, Thomas Johnson, Bosse Klykken, Travis Rhoden, Ian Kelling)
1449 * doc: swift tempurls (#10184 Abhishek Lekshmanan)
1450 * doc: switch doxygen integration back to breathe (#6115 Kefu Chai)
1451 * erasure-code: update ISA-L to 2.13 (Yuan Zhou)
1452 * gmock: switch to submodule (Danny Al-Gaaf, Loic Dachary)
1453 * hadoop: add terasort test (Noah Watkins)
1454 * java: fix libcephfs bindings (Noah Watkins)
1455 * libcephfs,ceph-fuse: fix request resend on cap reconnect (#10912 Yan, Zheng)
1456 * librados: define C++ flags from C constants (Josh Durgin)
1457 * librados: fix last_force_resent handling (#11026 Jianpeng Ma)
1458 * librados: fix memory leak from C_TwoContexts (Xiong Yiliang)
1459 * librados: fix striper when stripe_count = 1 and stripe_unit != object_size (#11120 Yan, Zheng)
1460 * librados: op perf counters (John Spray)
1461 * librados: pybind: fix write() method return code (Javier Guerra)
1462 * libradosstriper: fix leak (Danny Al-Gaaf)
1463 * librbd: add purge_on_error cache behavior (Jianpeng Ma)
1464 * librbd: misc aio fixes (#5488 Jason Dillaman)
1465 * librbd: misc rbd fixes (#11478 #11113 #11342 #11380 Jason Dillaman, Zhiqiang Wang)
1466 * librbd: readahead fixes (Zhiqiang Wang)
1467 * librbd: store metadata, including config options, in image (Haomai Wang)
1468 * mds: add 'damaged' state to MDSMap (John Spray)
1469 * mds: add nicknames for perfcounters (John Spray)
1470 * mds: disable problematic rstat propagation into snap parents (Yan, Zheng)
1471 * mds: fix mydir replica issue with shutdown (#10743 John Spray)
1472 * mds: fix out-of-order messages (#11258 Yan, Zheng)
1473 * mds: fix shutdown with strays (#10744 John Spray)
1474 * mds: fix snapshot fixes (Yan, Zheng)
1475 * mds: fix stray handling (John Spray)
1476 * mds: flush immediately in do_open_truncate (#11011 John Spray)
1477 * mds: improve dump methods (John Spray)
1478 * mds: misc journal cleanups and fixes (#10368 John Spray)
1479 * mds: new SessionMap storage using omap (#10649 John Spray)
1480 * mds: reduce memory consumption (Yan, Zheng)
1481 * mds: throttle purge stray operations (#10390 John Spray)
1482 * mds: tolerate clock jumping backwards (#11053 Yan, Zheng)
1483 * misc coverity fixes (Danny Al-Gaaf)
1484 * mon: do not deactivate last mds (#10862 John Spray)
1485 * mon: make osd get pool 'all' only return applicable fields (#10891 Michal Jarzabek)
1486 * mon: warn on bogus cache tier config (Jianpeng Ma)
1487 * msg/async: misc bug fixes and updates (Haomai Wang)
1488 * msg/simple: fix connect_seq assert (Haomai Wang)
1489 * msg/xio: misc fixes (#10735 Matt Benjamin, Kefu Chai, Danny Al-Gaaf, Raju Kurunkad, Vu Pham)
1490 * msg: unit tests (Haomai Wang)
1491 * objectcacher: misc bug fixes (Jianpeng Ma)
1492 * os/filestore: enlarge getxattr buffer size (Jianpeng Ma)
1493 * osd: EIO injection (David Zhang)
1494 * osd: add misc perfcounters (Xinze Chi)
1495 * osd: add simple sleep injection in recovery (Sage Weil)
1496 * osd: allow SEEK_HOLE/SEEK_DATA for sparse read (Zhiqiang Wang)
1497 * osd: avoid dup omap sets for in pg metadata (Sage Weil)
1498 * osd: clean up some constness, privateness (Kefu Chai)
1499 * osd: erasure-code: drop entries according to LRU (Andreas-Joachim Peters)
1500 * osd: fix negative degraded stats during backfill (Guang Yang)
1501 * osd: misc fixes (Ning Yao, Kefu Chai, Xinze Chi, Zhiqiang Wang, Jianpeng Ma)
1502 * pybind: pep8 cleanups (Danny Al-Gaaf)
1503 * qa: fix filelock_interrupt.py test (Yan, Zheng)
1504 * qa: improve ceph-disk tests (Loic Dachary)
1505 * qa: improve docker build layers (Loic Dachary)
1506 * rados: translate erno to string in CLI (#10877 Kefu Chai)
1507 * rbd: accept map options config option (Ilya Dryomov)
1508 * rbd: cli: fix arg parsing with --io-pattern (Dmitry Yatsushkevich)
1509 * rbd: fix error messages (#2862 Rajesh Nambiar)
1510 * rbd: update rbd man page (Ilya Dryomov)
1511 * rbd: update xfstests tests (Douglas Fuller)
1512 * rgw: add X-Timestamp for Swift containers (#10938 Radoslaw Zarzynski)
1513 * rgw: add missing headers to Swift container details (#10666 Ahmad Faheem, Dmytro Iurchenko)
1514 * rgw: add stats to headers for account GET (#10684 Yuan Zhou)
1515 * rgw: do not prefecth data for HEAD requests (Guang Yang)
1516 * rgw: don't clobber bucket/object owner when setting ACLs (#10978 Yehuda Sadeh)
1517 * rgw: don't use rgw_socket_path if frontend is configured (#11160 Yehuda Sadeh)
1518 * rgw: enforce Content-Lenth for POST on Swift cont/obj (#10661 Radoslaw Zarzynski)
1519 * rgw: fix handling empty metadata items on Swift container (#11088 Radoslaw Zarzynski)
1520 * rgw: fix log rotation (Wuxingyi)
1521 * rgw: generate Date header for civetweb (#10873 Radoslaw Zarzynski)
1522 * rgw: make init script wait for radosgw to stop (#11140 Dmitry Yatsushkevich)
1523 * rgw: make quota/gc threads configurable (#11047 Guang Yang)
1524 * rgw: pass in civetweb configurables (#10907 Yehuda Sadeh)
1525 * rgw: rectify 202 Accepted in PUT response (#11148 Radoslaw Zarzynski)
1526 * rgw: remove meta file after deleting bucket (#11149 Orit Wasserman)
1527 * rgw: swift: allow setting attributes with COPY (#10662 Ahmad Faheem, Dmytro Iurchenko)
1528 * rgw: swift: fix metadata handling on copy (#10645 Radoslaw Zarzynski)
1529 * rgw: swift: send Last-Modified header (#10650 Radoslaw Zarzynski)
1530 * rgw: update keystone cache with token info (#11125 Yehuda Sadeh)
1531 * rgw: update to latest civetweb, enable config for IPv6 (#10965 Yehuda Sadeh)
1532 * rocksdb: update to latest (Xiaoxi Chen)
1533 * rpm: loosen ceph-test dependencies (Ken Dreyer)
1534