mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-12-31 15:06:26 +00:00
Merge branch 'public-single-node' into pmm-6401-read-prometheus-data-files
This commit is contained in:
commit
db286fdd73
30 changed files with 705 additions and 282 deletions
|
@ -149,7 +149,7 @@ func (tbf *tmpBlocksFile) MustReadBlockRefAt(partRef storage.PartRef, addr tmpBl
|
||||||
} else {
|
} else {
|
||||||
bb := tmpBufPool.Get()
|
bb := tmpBufPool.Get()
|
||||||
defer tmpBufPool.Put(bb)
|
defer tmpBufPool.Put(bb)
|
||||||
bb.B = bytesutil.Resize(bb.B, addr.size)
|
bb.B = bytesutil.ResizeNoCopy(bb.B, addr.size)
|
||||||
tbf.r.MustReadAt(bb.B, int64(addr.offset))
|
tbf.r.MustReadAt(bb.B, int64(addr.offset))
|
||||||
buf = bb.B
|
buf = bb.B
|
||||||
}
|
}
|
||||||
|
|
|
@ -98,7 +98,7 @@ func marshalTimeseriesFast(dst []byte, tss []*timeseries, maxSize int, step int6
|
||||||
|
|
||||||
// Allocate the buffer for the marshaled tss before its' marshaling.
|
// Allocate the buffer for the marshaled tss before its' marshaling.
|
||||||
// This should reduce memory fragmentation and memory usage.
|
// This should reduce memory fragmentation and memory usage.
|
||||||
dst = bytesutil.Resize(dst, size)
|
dst = bytesutil.ResizeNoCopy(dst, size)
|
||||||
dst = marshalFastTimestamps(dst[:0], tss[0].Timestamps)
|
dst = marshalFastTimestamps(dst[:0], tss[0].Timestamps)
|
||||||
for _, ts := range tss {
|
for _, ts := range tss {
|
||||||
dst = ts.marshalFastNoTimestamps(dst)
|
dst = ts.marshalFastNoTimestamps(dst)
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
{
|
{
|
||||||
"files": {
|
"files": {
|
||||||
"main.css": "./static/css/main.098d452b.css",
|
"main.css": "./static/css/main.098d452b.css",
|
||||||
"main.js": "./static/js/main.eef1a9bb.js",
|
"main.js": "./static/js/main.2fe3eeab.js",
|
||||||
"static/js/27.cc1b69f7.chunk.js": "./static/js/27.cc1b69f7.chunk.js",
|
"static/js/27.939f971b.chunk.js": "./static/js/27.939f971b.chunk.js",
|
||||||
"index.html": "./index.html"
|
"index.html": "./index.html"
|
||||||
},
|
},
|
||||||
"entrypoints": [
|
"entrypoints": [
|
||||||
"static/css/main.098d452b.css",
|
"static/css/main.098d452b.css",
|
||||||
"static/js/main.eef1a9bb.js"
|
"static/js/main.2fe3eeab.js"
|
||||||
]
|
]
|
||||||
}
|
}
|
|
@ -1 +1 @@
|
||||||
<!doctype html><html lang="en"><head><meta charset="utf-8"/><link rel="icon" href="./favicon.ico"/><meta name="viewport" content="width=device-width,initial-scale=1"/><meta name="theme-color" content="#000000"/><meta name="description" content="VM-UI is a metric explorer for Victoria Metrics"/><link rel="apple-touch-icon" href="./apple-touch-icon.png"/><link rel="icon" type="image/png" sizes="32x32" href="./favicon-32x32.png"><link rel="manifest" href="./manifest.json"/><title>VM UI</title><link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap"/><script defer="defer" src="./static/js/main.eef1a9bb.js"></script><link href="./static/css/main.098d452b.css" rel="stylesheet"></head><body><noscript>You need to enable JavaScript to run this app.</noscript><div id="root"></div></body></html>
|
<!doctype html><html lang="en"><head><meta charset="utf-8"/><link rel="icon" href="./favicon.ico"/><meta name="viewport" content="width=device-width,initial-scale=1"/><meta name="theme-color" content="#000000"/><meta name="description" content="VM-UI is a metric explorer for Victoria Metrics"/><link rel="apple-touch-icon" href="./apple-touch-icon.png"/><link rel="icon" type="image/png" sizes="32x32" href="./favicon-32x32.png"><link rel="manifest" href="./manifest.json"/><title>VM UI</title><link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap"/><script defer="defer" src="./static/js/main.2fe3eeab.js"></script><link href="./static/css/main.098d452b.css" rel="stylesheet"></head><body><noscript>You need to enable JavaScript to run this app.</noscript><div id="root"></div></body></html>
|
1
app/vmselect/vmui/static/js/27.939f971b.chunk.js
Normal file
1
app/vmselect/vmui/static/js/27.939f971b.chunk.js
Normal file
|
@ -0,0 +1 @@
|
||||||
|
"use strict";(self.webpackChunkvmui=self.webpackChunkvmui||[]).push([[27],{4027:function(e,t,n){n.r(t),n.d(t,{getCLS:function(){return y},getFCP:function(){return g},getFID:function(){return C},getLCP:function(){return P},getTTFB:function(){return D}});var i,r,a,o,u=function(e,t){return{name:e,value:void 0===t?-1:t,delta:0,entries:[],id:"v2-".concat(Date.now(),"-").concat(Math.floor(8999999999999*Math.random())+1e12)}},c=function(e,t){try{if(PerformanceObserver.supportedEntryTypes.includes(e)){if("first-input"===e&&!("PerformanceEventTiming"in self))return;var n=new PerformanceObserver((function(e){return e.getEntries().map(t)}));return n.observe({type:e,buffered:!0}),n}}catch(e){}},f=function(e,t){var n=function n(i){"pagehide"!==i.type&&"hidden"!==document.visibilityState||(e(i),t&&(removeEventListener("visibilitychange",n,!0),removeEventListener("pagehide",n,!0)))};addEventListener("visibilitychange",n,!0),addEventListener("pagehide",n,!0)},s=function(e){addEventListener("pageshow",(function(t){t.persisted&&e(t)}),!0)},m=function(e,t,n){var i;return function(r){t.value>=0&&(r||n)&&(t.delta=t.value-(i||0),(t.delta||void 0===i)&&(i=t.value,e(t)))}},v=-1,p=function(){return"hidden"===document.visibilityState?0:1/0},d=function(){f((function(e){var t=e.timeStamp;v=t}),!0)},l=function(){return v<0&&(v=p(),d(),s((function(){setTimeout((function(){v=p(),d()}),0)}))),{get firstHiddenTime(){return v}}},g=function(e,t){var n,i=l(),r=u("FCP"),a=function(e){"first-contentful-paint"===e.name&&(f&&f.disconnect(),e.startTime<i.firstHiddenTime&&(r.value=e.startTime,r.entries.push(e),n(!0)))},o=window.performance&&performance.getEntriesByName&&performance.getEntriesByName("first-contentful-paint")[0],f=o?null:c("paint",a);(o||f)&&(n=m(e,r,t),o&&a(o),s((function(i){r=u("FCP"),n=m(e,r,t),requestAnimationFrame((function(){requestAnimationFrame((function(){r.value=performance.now()-i.timeStamp,n(!0)}))}))})))},h=!1,T=-1,y=function(e,t){h||(g((function(e){T=e.value})),h=!0);var n,i=function(t){T>-1&&e(t)},r=u("CLS",0),a=0,o=[],v=function(e){if(!e.hadRecentInput){var t=o[0],i=o[o.length-1];a&&e.startTime-i.startTime<1e3&&e.startTime-t.startTime<5e3?(a+=e.value,o.push(e)):(a=e.value,o=[e]),a>r.value&&(r.value=a,r.entries=o,n())}},p=c("layout-shift",v);p&&(n=m(i,r,t),f((function(){p.takeRecords().map(v),n(!0)})),s((function(){a=0,T=-1,r=u("CLS",0),n=m(i,r,t)})))},E={passive:!0,capture:!0},w=new Date,L=function(e,t){i||(i=t,r=e,a=new Date,F(removeEventListener),S())},S=function(){if(r>=0&&r<a-w){var e={entryType:"first-input",name:i.type,target:i.target,cancelable:i.cancelable,startTime:i.timeStamp,processingStart:i.timeStamp+r};o.forEach((function(t){t(e)})),o=[]}},b=function(e){if(e.cancelable){var t=(e.timeStamp>1e12?new Date:performance.now())-e.timeStamp;"pointerdown"==e.type?function(e,t){var n=function(){L(e,t),r()},i=function(){r()},r=function(){removeEventListener("pointerup",n,E),removeEventListener("pointercancel",i,E)};addEventListener("pointerup",n,E),addEventListener("pointercancel",i,E)}(t,e):L(t,e)}},F=function(e){["mousedown","keydown","touchstart","pointerdown"].forEach((function(t){return e(t,b,E)}))},C=function(e,t){var n,a=l(),v=u("FID"),p=function(e){e.startTime<a.firstHiddenTime&&(v.value=e.processingStart-e.startTime,v.entries.push(e),n(!0))},d=c("first-input",p);n=m(e,v,t),d&&f((function(){d.takeRecords().map(p),d.disconnect()}),!0),d&&s((function(){var a;v=u("FID"),n=m(e,v,t),o=[],r=-1,i=null,F(addEventListener),a=p,o.push(a),S()}))},k={},P=function(e,t){var n,i=l(),r=u("LCP"),a=function(e){var t=e.startTime;t<i.firstHiddenTime&&(r.value=t,r.entries.push(e),n())},o=c("largest-contentful-paint",a);if(o){n=m(e,r,t);var v=function(){k[r.id]||(o.takeRecords().map(a),o.disconnect(),k[r.id]=!0,n(!0))};["keydown","click"].forEach((function(e){addEventListener(e,v,{once:!0,capture:!0})})),f(v,!0),s((function(i){r=u("LCP"),n=m(e,r,t),requestAnimationFrame((function(){requestAnimationFrame((function(){r.value=performance.now()-i.timeStamp,k[r.id]=!0,n(!0)}))}))}))}},D=function(e){var t,n=u("TTFB");t=function(){try{var t=performance.getEntriesByType("navigation")[0]||function(){var e=performance.timing,t={entryType:"navigation",startTime:0};for(var n in e)"navigationStart"!==n&&"toJSON"!==n&&(t[n]=Math.max(e[n]-e.navigationStart,0));return t}();if(n.value=n.delta=t.responseStart,n.value<0||n.value>performance.now())return;n.entries=[t],e(n)}catch(e){}},"complete"===document.readyState?setTimeout(t,0):addEventListener("load",(function(){return setTimeout(t,0)}))}}}]);
|
|
@ -1 +0,0 @@
|
||||||
"use strict";(self.webpackChunkvmui=self.webpackChunkvmui||[]).push([[27],{4027:function(e,n,t){t.r(n),t.d(n,{getCLS:function(){return y},getFCP:function(){return g},getFID:function(){return C},getLCP:function(){return P},getTTFB:function(){return D}});var i,r,a,o,u=function(e,n){return{name:e,value:void 0===n?-1:n,delta:0,entries:[],id:"v2-".concat(Date.now(),"-").concat(Math.floor(8999999999999*Math.random())+1e12)}},c=function(e,n){try{if(PerformanceObserver.supportedEntryTypes.includes(e)){if("first-input"===e&&!("PerformanceEventTiming"in self))return;var t=new PerformanceObserver((function(e){return e.getEntries().map(n)}));return t.observe({type:e,buffered:!0}),t}}catch(e){}},f=function(e,n){var t=function t(i){"pagehide"!==i.type&&"hidden"!==document.visibilityState||(e(i),n&&(removeEventListener("visibilitychange",t,!0),removeEventListener("pagehide",t,!0)))};addEventListener("visibilitychange",t,!0),addEventListener("pagehide",t,!0)},s=function(e){addEventListener("pageshow",(function(n){n.persisted&&e(n)}),!0)},m=function(e,n,t){var i;return function(r){n.value>=0&&(r||t)&&(n.delta=n.value-(i||0),(n.delta||void 0===i)&&(i=n.value,e(n)))}},v=-1,p=function(){return"hidden"===document.visibilityState?0:1/0},d=function(){f((function(e){var n=e.timeStamp;v=n}),!0)},l=function(){return v<0&&(v=p(),d(),s((function(){setTimeout((function(){v=p(),d()}),0)}))),{get firstHiddenTime(){return v}}},g=function(e,n){var t,i=l(),r=u("FCP"),a=function(e){"first-contentful-paint"===e.name&&(f&&f.disconnect(),e.startTime<i.firstHiddenTime&&(r.value=e.startTime,r.entries.push(e),t(!0)))},o=window.performance&&performance.getEntriesByName&&performance.getEntriesByName("first-contentful-paint")[0],f=o?null:c("paint",a);(o||f)&&(t=m(e,r,n),o&&a(o),s((function(i){r=u("FCP"),t=m(e,r,n),requestAnimationFrame((function(){requestAnimationFrame((function(){r.value=performance.now()-i.timeStamp,t(!0)}))}))})))},h=!1,T=-1,y=function(e,n){h||(g((function(e){T=e.value})),h=!0);var t,i=function(n){T>-1&&e(n)},r=u("CLS",0),a=0,o=[],v=function(e){if(!e.hadRecentInput){var n=o[0],i=o[o.length-1];a&&e.startTime-i.startTime<1e3&&e.startTime-n.startTime<5e3?(a+=e.value,o.push(e)):(a=e.value,o=[e]),a>r.value&&(r.value=a,r.entries=o,t())}},p=c("layout-shift",v);p&&(t=m(i,r,n),f((function(){p.takeRecords().map(v),t(!0)})),s((function(){a=0,T=-1,r=u("CLS",0),t=m(i,r,n)})))},E={passive:!0,capture:!0},w=new Date,L=function(e,n){i||(i=n,r=e,a=new Date,F(removeEventListener),S())},S=function(){if(r>=0&&r<a-w){var e={entryType:"first-input",name:i.type,target:i.target,cancelable:i.cancelable,startTime:i.timeStamp,processingStart:i.timeStamp+r};o.forEach((function(n){n(e)})),o=[]}},b=function(e){if(e.cancelable){var n=(e.timeStamp>1e12?new Date:performance.now())-e.timeStamp;"pointerdown"==e.type?function(e,n){var t=function(){L(e,n),r()},i=function(){r()},r=function(){removeEventListener("pointerup",t,E),removeEventListener("pointercancel",i,E)};addEventListener("pointerup",t,E),addEventListener("pointercancel",i,E)}(n,e):L(n,e)}},F=function(e){["mousedown","keydown","touchstart","pointerdown"].forEach((function(n){return e(n,b,E)}))},C=function(e,n){var t,a=l(),v=u("FID"),p=function(e){e.startTime<a.firstHiddenTime&&(v.value=e.processingStart-e.startTime,v.entries.push(e),t(!0))},d=c("first-input",p);t=m(e,v,n),d&&f((function(){d.takeRecords().map(p),d.disconnect()}),!0),d&&s((function(){var a;v=u("FID"),t=m(e,v,n),o=[],r=-1,i=null,F(addEventListener),a=p,o.push(a),S()}))},k={},P=function(e,n){var t,i=l(),r=u("LCP"),a=function(e){var n=e.startTime;n<i.firstHiddenTime&&(r.value=n,r.entries.push(e),t())},o=c("largest-contentful-paint",a);if(o){t=m(e,r,n);var v=function(){k[r.id]||(o.takeRecords().map(a),o.disconnect(),k[r.id]=!0,t(!0))};["keydown","click"].forEach((function(e){addEventListener(e,v,{once:!0,capture:!0})})),f(v,!0),s((function(i){r=u("LCP"),t=m(e,r,n),requestAnimationFrame((function(){requestAnimationFrame((function(){r.value=performance.now()-i.timeStamp,k[r.id]=!0,t(!0)}))}))}))}},D=function(e){var n,t=u("TTFB");n=function(){try{var n=performance.getEntriesByType("navigation")[0]||function(){var e=performance.timing,n={entryType:"navigation",startTime:0};for(var t in e)"navigationStart"!==t&&"toJSON"!==t&&(n[t]=Math.max(e[t]-e.navigationStart,0));return n}();if(t.value=t.delta=n.responseStart,t.value<0||t.value>performance.now())return;t.entries=[n],e(t)}catch(e){}},"complete"===document.readyState?setTimeout(n,0):addEventListener("pageshow",n)}}}]);
|
|
2
app/vmselect/vmui/static/js/main.2fe3eeab.js
Normal file
2
app/vmselect/vmui/static/js/main.2fe3eeab.js
Normal file
File diff suppressed because one or more lines are too long
|
@ -14,7 +14,7 @@
|
||||||
* @license MIT
|
* @license MIT
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/** @license MUI v5.2.6
|
/** @license MUI v5.3.0
|
||||||
*
|
*
|
||||||
* This source code is licensed under the MIT license found in the
|
* This source code is licensed under the MIT license found in the
|
||||||
* LICENSE file in the root directory of this source tree.
|
* LICENSE file in the root directory of this source tree.
|
File diff suppressed because one or more lines are too long
745
app/vmui/packages/vmui/package-lock.json
generated
745
app/vmui/packages/vmui/package-lock.json
generated
File diff suppressed because it is too large
Load diff
|
@ -6,10 +6,10 @@
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@date-io/dayjs": "^2.11.0",
|
"@date-io/dayjs": "^2.11.0",
|
||||||
"@emotion/styled": "^11.6.0",
|
"@emotion/styled": "^11.6.0",
|
||||||
"@mui/icons-material": "^5.2.5",
|
"@mui/icons-material": "^5.3.0",
|
||||||
"@mui/lab": "^5.0.0-alpha.64",
|
"@mui/lab": "^5.0.0-alpha.65",
|
||||||
"@mui/material": "^5.2.8",
|
"@mui/material": "^5.3.0",
|
||||||
"@mui/styles": "^5.2.3",
|
"@mui/styles": "^5.3.0",
|
||||||
"@testing-library/jest-dom": "^5.16.1",
|
"@testing-library/jest-dom": "^5.16.1",
|
||||||
"@testing-library/react": "^12.1.2",
|
"@testing-library/react": "^12.1.2",
|
||||||
"@testing-library/user-event": "^13.5.0",
|
"@testing-library/user-event": "^13.5.0",
|
||||||
|
@ -17,7 +17,7 @@
|
||||||
"@types/lodash.debounce": "^4.0.6",
|
"@types/lodash.debounce": "^4.0.6",
|
||||||
"@types/lodash.get": "^4.4.6",
|
"@types/lodash.get": "^4.4.6",
|
||||||
"@types/lodash.throttle": "^4.1.6",
|
"@types/lodash.throttle": "^4.1.6",
|
||||||
"@types/node": "^17.0.8",
|
"@types/node": "^17.0.10",
|
||||||
"@types/numeral": "^2.0.2",
|
"@types/numeral": "^2.0.2",
|
||||||
"@types/qs": "^6.9.7",
|
"@types/qs": "^6.9.7",
|
||||||
"@types/react": "^17.0.38",
|
"@types/react": "^17.0.38",
|
||||||
|
@ -30,9 +30,9 @@
|
||||||
"numeral": "^2.0.6",
|
"numeral": "^2.0.6",
|
||||||
"preact": "^10.6.4",
|
"preact": "^10.6.4",
|
||||||
"qs": "^6.10.3",
|
"qs": "^6.10.3",
|
||||||
"typescript": "~4.5.4",
|
"typescript": "~4.5.5",
|
||||||
"uplot": "^1.6.18",
|
"uplot": "^1.6.18",
|
||||||
"web-vitals": "^2.1.3"
|
"web-vitals": "^2.1.4"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"start": "react-app-rewired start",
|
"start": "react-app-rewired start",
|
||||||
|
@ -62,8 +62,8 @@
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/plugin-proposal-nullish-coalescing-operator": "^7.16.7",
|
"@babel/plugin-proposal-nullish-coalescing-operator": "^7.16.7",
|
||||||
"@typescript-eslint/eslint-plugin": "^5.9.1",
|
"@typescript-eslint/eslint-plugin": "^5.10.0",
|
||||||
"@typescript-eslint/parser": "^5.9.1",
|
"@typescript-eslint/parser": "^5.10.0",
|
||||||
"customize-cra": "^1.0.0",
|
"customize-cra": "^1.0.0",
|
||||||
"eslint-plugin-react": "^7.28.0",
|
"eslint-plugin-react": "^7.28.0",
|
||||||
"react-app-rewired": "^2.1.11"
|
"react-app-rewired": "^2.1.11"
|
||||||
|
|
|
@ -10,6 +10,7 @@ sort: 15
|
||||||
* BUGFIX: properly limit indexdb cache sizes. Previously they could exceed values set via `-memory.allowedPercent` and/or `-memory.allowedBytes` when `indexdb` contained many data parts. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/2007).
|
* BUGFIX: properly limit indexdb cache sizes. Previously they could exceed values set via `-memory.allowedPercent` and/or `-memory.allowedBytes` when `indexdb` contained many data parts. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/2007).
|
||||||
* BUGFIX: [vmui](https://docs.victoriametrics.com/#vmui): fix a bug, which could break time range picker when editing `From` or `To` input fields. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/2080).
|
* BUGFIX: [vmui](https://docs.victoriametrics.com/#vmui): fix a bug, which could break time range picker when editing `From` or `To` input fields. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/2080).
|
||||||
* BUGFIX: [vmui](https://docs.victoriametrics.com/#vmui): fix a bug, which could break switching between `graph`, `json` and `table` views. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/2084).
|
* BUGFIX: [vmui](https://docs.victoriametrics.com/#vmui): fix a bug, which could break switching between `graph`, `json` and `table` views. See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/2084).
|
||||||
|
* BUGFIX: show the original location of the warning or error message when logging throttled messages. Previously the location inside `lib/logger/throttler.go` was shown. This could increase the complexity of debugging.
|
||||||
|
|
||||||
|
|
||||||
## [v1.72.0](https://github.com/VictoriaMetrics/VictoriaMetrics/releases/tag/v1.72.0)
|
## [v1.72.0](https://github.com/VictoriaMetrics/VictoriaMetrics/releases/tag/v1.72.0)
|
||||||
|
|
|
@ -53,7 +53,7 @@ func (bb *ByteBuffer) MustReadAt(p []byte, offset int64) {
|
||||||
func (bb *ByteBuffer) ReadFrom(r io.Reader) (int64, error) {
|
func (bb *ByteBuffer) ReadFrom(r io.Reader) (int64, error) {
|
||||||
b := bb.B
|
b := bb.B
|
||||||
bLen := len(b)
|
bLen := len(b)
|
||||||
b = Resize(b, 4*1024)
|
b = ResizeWithCopy(b, 4*1024)
|
||||||
b = b[:cap(b)]
|
b = b[:cap(b)]
|
||||||
offset := bLen
|
offset := bLen
|
||||||
for {
|
for {
|
||||||
|
|
|
@ -5,13 +5,30 @@ import (
|
||||||
"unsafe"
|
"unsafe"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Resize resizes b to n bytes and returns b (which may be newly allocated).
|
// ResizeWithCopy resizes b to n bytes and returns the resized buffer (which may be newly allocated).
|
||||||
func Resize(b []byte, n int) []byte {
|
//
|
||||||
if nn := n - cap(b); nn > 0 {
|
// If newly allocated buffer is returned then b contents is copied to it.
|
||||||
b = append(b[:cap(b)], make([]byte, nn)...)
|
func ResizeWithCopy(b []byte, n int) []byte {
|
||||||
}
|
if n <= cap(b) {
|
||||||
return b[:n]
|
return b[:n]
|
||||||
}
|
}
|
||||||
|
// Allocate the exact number of bytes instead of using `b = append(b[:cap(b)], make([]byte, nn)...)`,
|
||||||
|
// since `append()` may allocate more than the requested bytes for additional capacity.
|
||||||
|
// Using make() instead of append() should save RAM when the resized slice is cached somewhere.
|
||||||
|
bNew := make([]byte, n)
|
||||||
|
copy(bNew, b)
|
||||||
|
return bNew
|
||||||
|
}
|
||||||
|
|
||||||
|
// ResizeNoCopy resizes b to n bytes and returns the resized buffer (which may be newly allocated).
|
||||||
|
//
|
||||||
|
// If newly allocated buffer is returned then b contents isn't copied to it.
|
||||||
|
func ResizeNoCopy(b []byte, n int) []byte {
|
||||||
|
if n <= cap(b) {
|
||||||
|
return b[:n]
|
||||||
|
}
|
||||||
|
return make([]byte, n)
|
||||||
|
}
|
||||||
|
|
||||||
// ToUnsafeString converts b to string without memory allocations.
|
// ToUnsafeString converts b to string without memory allocations.
|
||||||
//
|
//
|
||||||
|
|
|
@ -5,19 +5,62 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestResize(t *testing.T) {
|
func TestResizeNoCopy(t *testing.T) {
|
||||||
for i := 0; i < 1000; i++ {
|
for i := 0; i < 1000; i++ {
|
||||||
b := Resize(nil, i)
|
b := ResizeNoCopy(nil, i)
|
||||||
if len(b) != i {
|
if len(b) != i {
|
||||||
t.Fatalf("invalid b size; got %d; expecting %d", len(b), i)
|
t.Fatalf("invalid b size; got %d; expecting %d", len(b), i)
|
||||||
}
|
}
|
||||||
b1 := Resize(b, i)
|
b1 := ResizeNoCopy(b, i)
|
||||||
if len(b1) != len(b) || (len(b) > 0 && &b1[0] != &b[0]) {
|
if len(b1) != len(b) || (len(b) > 0 && &b1[0] != &b[0]) {
|
||||||
t.Fatalf("invalid b1; got %x; expecting %x", b1, b)
|
t.Fatalf("invalid b1; got %x; expecting %x", &b1[0], &b[0])
|
||||||
}
|
}
|
||||||
b2 := Resize(b[:0], i)
|
b2 := ResizeNoCopy(b[:0], i)
|
||||||
if len(b2) != len(b) || (len(b) > 0 && &b2[0] != &b[0]) {
|
if len(b2) != len(b) || (len(b) > 0 && &b2[0] != &b[0]) {
|
||||||
t.Fatalf("invalid b2; got %x; expecting %x", b2, b)
|
t.Fatalf("invalid b2; got %x; expecting %x", &b2[0], &b[0])
|
||||||
|
}
|
||||||
|
if i > 0 {
|
||||||
|
b[0] = 123
|
||||||
|
b3 := ResizeNoCopy(b, i+1)
|
||||||
|
if len(b3) != i+1 {
|
||||||
|
t.Fatalf("invalid b3 len; got %d; want %d", len(b3), i+1)
|
||||||
|
}
|
||||||
|
if &b3[0] == &b[0] {
|
||||||
|
t.Fatalf("b3 must be newly allocated")
|
||||||
|
}
|
||||||
|
if b3[0] != 0 {
|
||||||
|
t.Fatalf("b3[0] must be zeroed; got %d", b3[0])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestResizeWithCopy(t *testing.T) {
|
||||||
|
for i := 0; i < 1000; i++ {
|
||||||
|
b := ResizeWithCopy(nil, i)
|
||||||
|
if len(b) != i {
|
||||||
|
t.Fatalf("invalid b size; got %d; expecting %d", len(b), i)
|
||||||
|
}
|
||||||
|
b1 := ResizeWithCopy(b, i)
|
||||||
|
if len(b1) != len(b) || (len(b) > 0 && &b1[0] != &b[0]) {
|
||||||
|
t.Fatalf("invalid b1; got %x; expecting %x", &b1[0], &b[0])
|
||||||
|
}
|
||||||
|
b2 := ResizeWithCopy(b[:0], i)
|
||||||
|
if len(b2) != len(b) || (len(b) > 0 && &b2[0] != &b[0]) {
|
||||||
|
t.Fatalf("invalid b2; got %x; expecting %x", &b2[0], &b[0])
|
||||||
|
}
|
||||||
|
if i > 0 {
|
||||||
|
b[0] = 123
|
||||||
|
b3 := ResizeWithCopy(b, i+1)
|
||||||
|
if len(b3) != i+1 {
|
||||||
|
t.Fatalf("invalid b3 len; got %d; want %d", len(b3), i+1)
|
||||||
|
}
|
||||||
|
if &b3[0] == &b[0] {
|
||||||
|
t.Fatalf("b3 must be newly allocated for i=%d", i)
|
||||||
|
}
|
||||||
|
if b3[0] != b[0] || b3[0] != 123 {
|
||||||
|
t.Fatalf("b3[0] must equal b[0]; got %d; want %d", b3[0], b[0])
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -135,7 +135,7 @@ func (s *Server) serveUDP(insertHandler func(r io.Reader) error) {
|
||||||
go func() {
|
go func() {
|
||||||
defer wg.Done()
|
defer wg.Done()
|
||||||
var bb bytesutil.ByteBuffer
|
var bb bytesutil.ByteBuffer
|
||||||
bb.B = bytesutil.Resize(bb.B, 64*1024)
|
bb.B = bytesutil.ResizeNoCopy(bb.B, 64*1024)
|
||||||
for {
|
for {
|
||||||
bb.Reset()
|
bb.Reset()
|
||||||
bb.B = bb.B[:cap(bb.B)]
|
bb.B = bb.B[:cap(bb.B)]
|
||||||
|
|
|
@ -135,7 +135,7 @@ func (s *Server) serveUDP(insertHandler func(r io.Reader) error) {
|
||||||
go func() {
|
go func() {
|
||||||
defer wg.Done()
|
defer wg.Done()
|
||||||
var bb bytesutil.ByteBuffer
|
var bb bytesutil.ByteBuffer
|
||||||
bb.B = bytesutil.Resize(bb.B, 64*1024)
|
bb.B = bytesutil.ResizeNoCopy(bb.B, 64*1024)
|
||||||
for {
|
for {
|
||||||
bb.Reset()
|
bb.Reset()
|
||||||
bb.B = bb.B[:cap(bb.B)]
|
bb.B = bb.B[:cap(bb.B)]
|
||||||
|
|
|
@ -153,7 +153,7 @@ func (s *Server) serveUDP(insertHandler func(r io.Reader) error) {
|
||||||
go func() {
|
go func() {
|
||||||
defer wg.Done()
|
defer wg.Done()
|
||||||
var bb bytesutil.ByteBuffer
|
var bb bytesutil.ByteBuffer
|
||||||
bb.B = bytesutil.Resize(bb.B, 64*1024)
|
bb.B = bytesutil.ResizeNoCopy(bb.B, 64*1024)
|
||||||
for {
|
for {
|
||||||
bb.Reset()
|
bb.Reset()
|
||||||
bb.B = bb.B[:cap(bb.B)]
|
bb.B = bb.B[:cap(bb.B)]
|
||||||
|
|
|
@ -24,8 +24,6 @@ func WithThrottler(name string, throttle time.Duration) *LogThrottler {
|
||||||
}
|
}
|
||||||
|
|
||||||
lt = newLogThrottler(throttle)
|
lt = newLogThrottler(throttle)
|
||||||
lt.warnF = Warnf
|
|
||||||
lt.errorF = Errorf
|
|
||||||
logThrottlerRegistry[name] = lt
|
logThrottlerRegistry[name] = lt
|
||||||
return lt
|
return lt
|
||||||
}
|
}
|
||||||
|
@ -35,9 +33,6 @@ func WithThrottler(name string, throttle time.Duration) *LogThrottler {
|
||||||
// LogThrottler must be created via WithThrottler() call.
|
// LogThrottler must be created via WithThrottler() call.
|
||||||
type LogThrottler struct {
|
type LogThrottler struct {
|
||||||
ch chan struct{}
|
ch chan struct{}
|
||||||
|
|
||||||
warnF func(format string, args ...interface{})
|
|
||||||
errorF func(format string, args ...interface{})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func newLogThrottler(throttle time.Duration) *LogThrottler {
|
func newLogThrottler(throttle time.Duration) *LogThrottler {
|
||||||
|
@ -57,7 +52,7 @@ func newLogThrottler(throttle time.Duration) *LogThrottler {
|
||||||
func (lt *LogThrottler) Errorf(format string, args ...interface{}) {
|
func (lt *LogThrottler) Errorf(format string, args ...interface{}) {
|
||||||
select {
|
select {
|
||||||
case lt.ch <- struct{}{}:
|
case lt.ch <- struct{}{}:
|
||||||
lt.errorF(format, args...)
|
ErrorfSkipframes(1, format, args...)
|
||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -66,7 +61,7 @@ func (lt *LogThrottler) Errorf(format string, args ...interface{}) {
|
||||||
func (lt *LogThrottler) Warnf(format string, args ...interface{}) {
|
func (lt *LogThrottler) Warnf(format string, args ...interface{}) {
|
||||||
select {
|
select {
|
||||||
case lt.ch <- struct{}{}:
|
case lt.ch <- struct{}{}:
|
||||||
lt.warnF(format, args...)
|
WarnfSkipframes(1, format, args...)
|
||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,40 +0,0 @@
|
||||||
package logger
|
|
||||||
|
|
||||||
import (
|
|
||||||
"testing"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestLoggerWithThrottler(t *testing.T) {
|
|
||||||
lName := "test"
|
|
||||||
lThrottle := 50 * time.Millisecond
|
|
||||||
|
|
||||||
lt := WithThrottler(lName, lThrottle)
|
|
||||||
var i int
|
|
||||||
lt.warnF = func(format string, args ...interface{}) {
|
|
||||||
i++
|
|
||||||
}
|
|
||||||
|
|
||||||
lt.Warnf("")
|
|
||||||
lt.Warnf("")
|
|
||||||
lt.Warnf("")
|
|
||||||
|
|
||||||
if i != 1 {
|
|
||||||
t.Fatalf("expected logger will be throttled to 1; got %d instead", i)
|
|
||||||
}
|
|
||||||
|
|
||||||
time.Sleep(lThrottle * 2) // wait to throttle to fade off
|
|
||||||
// the same logger supposed to be return for the same name
|
|
||||||
WithThrottler(lName, lThrottle).Warnf("")
|
|
||||||
if i != 2 {
|
|
||||||
t.Fatalf("expected logger to have 2 iterations; got %d instead", i)
|
|
||||||
}
|
|
||||||
|
|
||||||
logThrottlerRegistryMu.Lock()
|
|
||||||
registeredN := len(logThrottlerRegistry)
|
|
||||||
logThrottlerRegistryMu.Unlock()
|
|
||||||
|
|
||||||
if registeredN != 1 {
|
|
||||||
t.Fatalf("expected only 1 logger to be registered; got %d", registeredN)
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -211,13 +211,13 @@ func (bsr *blockStreamReader) Next() bool {
|
||||||
bsr.bh = &bsr.bhs[bsr.bhIdx]
|
bsr.bh = &bsr.bhs[bsr.bhIdx]
|
||||||
bsr.bhIdx++
|
bsr.bhIdx++
|
||||||
|
|
||||||
bsr.sb.itemsData = bytesutil.Resize(bsr.sb.itemsData, int(bsr.bh.itemsBlockSize))
|
bsr.sb.itemsData = bytesutil.ResizeNoCopy(bsr.sb.itemsData, int(bsr.bh.itemsBlockSize))
|
||||||
if err := fs.ReadFullData(bsr.itemsReader, bsr.sb.itemsData); err != nil {
|
if err := fs.ReadFullData(bsr.itemsReader, bsr.sb.itemsData); err != nil {
|
||||||
bsr.err = fmt.Errorf("cannot read compressed items block with size %d: %w", bsr.bh.itemsBlockSize, err)
|
bsr.err = fmt.Errorf("cannot read compressed items block with size %d: %w", bsr.bh.itemsBlockSize, err)
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
bsr.sb.lensData = bytesutil.Resize(bsr.sb.lensData, int(bsr.bh.lensBlockSize))
|
bsr.sb.lensData = bytesutil.ResizeNoCopy(bsr.sb.lensData, int(bsr.bh.lensBlockSize))
|
||||||
if err := fs.ReadFullData(bsr.lensReader, bsr.sb.lensData); err != nil {
|
if err := fs.ReadFullData(bsr.lensReader, bsr.sb.lensData); err != nil {
|
||||||
bsr.err = fmt.Errorf("cannot read compressed lens block with size %d: %w", bsr.bh.lensBlockSize, err)
|
bsr.err = fmt.Errorf("cannot read compressed lens block with size %d: %w", bsr.bh.lensBlockSize, err)
|
||||||
return false
|
return false
|
||||||
|
@ -260,7 +260,7 @@ func (bsr *blockStreamReader) readNextBHS() error {
|
||||||
bsr.mrIdx++
|
bsr.mrIdx++
|
||||||
|
|
||||||
// Read compressed index block.
|
// Read compressed index block.
|
||||||
bsr.packedBuf = bytesutil.Resize(bsr.packedBuf, int(mr.indexBlockSize))
|
bsr.packedBuf = bytesutil.ResizeNoCopy(bsr.packedBuf, int(mr.indexBlockSize))
|
||||||
if err := fs.ReadFullData(bsr.indexReader, bsr.packedBuf); err != nil {
|
if err := fs.ReadFullData(bsr.indexReader, bsr.packedBuf); err != nil {
|
||||||
return fmt.Errorf("cannot read compressed index block with size %d: %w", mr.indexBlockSize, err)
|
return fmt.Errorf("cannot read compressed index block with size %d: %w", mr.indexBlockSize, err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -119,7 +119,7 @@ func (ib *inmemoryBlock) Add(x []byte) bool {
|
||||||
}
|
}
|
||||||
if cap(data) < maxInmemoryBlockSize {
|
if cap(data) < maxInmemoryBlockSize {
|
||||||
dataLen := len(data)
|
dataLen := len(data)
|
||||||
data = bytesutil.Resize(data, maxInmemoryBlockSize)[:dataLen]
|
data = bytesutil.ResizeWithCopy(data, maxInmemoryBlockSize)[:dataLen]
|
||||||
}
|
}
|
||||||
dataLen := len(data)
|
dataLen := len(data)
|
||||||
data = append(data, x...)
|
data = append(data, x...)
|
||||||
|
@ -141,7 +141,7 @@ func (ib *inmemoryBlock) sort() {
|
||||||
data := ib.data
|
data := ib.data
|
||||||
items := ib.items
|
items := ib.items
|
||||||
bb := bbPool.Get()
|
bb := bbPool.Get()
|
||||||
b := bytesutil.Resize(bb.B, len(data))
|
b := bytesutil.ResizeNoCopy(bb.B, len(data))
|
||||||
b = b[:0]
|
b = b[:0]
|
||||||
for i, it := range items {
|
for i, it := range items {
|
||||||
bLen := len(b)
|
bLen := len(b)
|
||||||
|
@ -378,12 +378,12 @@ func (ib *inmemoryBlock) UnmarshalData(sb *storageBlock, firstItem, commonPrefix
|
||||||
return fmt.Errorf("unexpected tail left unmarshaling %d lens; tail size=%d; contents=%X", itemsCount, len(tail), tail)
|
return fmt.Errorf("unexpected tail left unmarshaling %d lens; tail size=%d; contents=%X", itemsCount, len(tail), tail)
|
||||||
}
|
}
|
||||||
lens[0] = uint64(len(firstItem) - len(commonPrefix))
|
lens[0] = uint64(len(firstItem) - len(commonPrefix))
|
||||||
dataLen := uint64(len(commonPrefix) * int(itemsCount))
|
dataLen := len(commonPrefix) * int(itemsCount)
|
||||||
dataLen += lens[0]
|
dataLen += int(lens[0])
|
||||||
for i, xLen := range is.A {
|
for i, xLen := range is.A {
|
||||||
itemLen := xLen ^ lens[i]
|
itemLen := xLen ^ lens[i]
|
||||||
lens[i+1] = itemLen
|
lens[i+1] = itemLen
|
||||||
dataLen += itemLen
|
dataLen += int(itemLen)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Unmarshal items data.
|
// Unmarshal items data.
|
||||||
|
@ -391,7 +391,10 @@ func (ib *inmemoryBlock) UnmarshalData(sb *storageBlock, firstItem, commonPrefix
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("cannot decompress lensData: %w", err)
|
return fmt.Errorf("cannot decompress lensData: %w", err)
|
||||||
}
|
}
|
||||||
data := bytesutil.Resize(ib.data, maxInmemoryBlockSize)
|
// Resize ib.data to dataLen instead of maxInmemoryBlockSize,
|
||||||
|
// since the data isn't going to be resized after unmarshaling.
|
||||||
|
// This may save memory for caching the unmarshaled block.
|
||||||
|
data := bytesutil.ResizeNoCopy(ib.data, dataLen)
|
||||||
if n := int(itemsCount) - cap(ib.items); n > 0 {
|
if n := int(itemsCount) - cap(ib.items); n > 0 {
|
||||||
ib.items = append(ib.items[:cap(ib.items)], make([]Item, n)...)
|
ib.items = append(ib.items[:cap(ib.items)], make([]Item, n)...)
|
||||||
}
|
}
|
||||||
|
@ -417,12 +420,12 @@ func (ib *inmemoryBlock) UnmarshalData(sb *storageBlock, firstItem, commonPrefix
|
||||||
if prefixLen > uint64(len(prevItem)) {
|
if prefixLen > uint64(len(prevItem)) {
|
||||||
return fmt.Errorf("prefixLen cannot exceed %d; got %d", len(prevItem), prefixLen)
|
return fmt.Errorf("prefixLen cannot exceed %d; got %d", len(prevItem), prefixLen)
|
||||||
}
|
}
|
||||||
dataLen := len(data)
|
dataStart := len(data)
|
||||||
data = append(data, commonPrefix...)
|
data = append(data, commonPrefix...)
|
||||||
data = append(data, prevItem[:prefixLen]...)
|
data = append(data, prevItem[:prefixLen]...)
|
||||||
data = append(data, b[:suffixLen]...)
|
data = append(data, b[:suffixLen]...)
|
||||||
items[i] = Item{
|
items[i] = Item{
|
||||||
Start: uint32(dataLen),
|
Start: uint32(dataStart),
|
||||||
End: uint32(len(data)),
|
End: uint32(len(data)),
|
||||||
}
|
}
|
||||||
b = b[suffixLen:]
|
b = b[suffixLen:]
|
||||||
|
@ -431,7 +434,7 @@ func (ib *inmemoryBlock) UnmarshalData(sb *storageBlock, firstItem, commonPrefix
|
||||||
if len(b) > 0 {
|
if len(b) > 0 {
|
||||||
return fmt.Errorf("unexpected tail left after itemsData with len %d: %q", len(b), b)
|
return fmt.Errorf("unexpected tail left after itemsData with len %d: %q", len(b), b)
|
||||||
}
|
}
|
||||||
if uint64(len(data)) != dataLen {
|
if len(data) != dataLen {
|
||||||
return fmt.Errorf("unexpected data len; got %d; want %d", len(data), dataLen)
|
return fmt.Errorf("unexpected data len; got %d; want %d", len(data), dataLen)
|
||||||
}
|
}
|
||||||
ib.data = data
|
ib.data = data
|
||||||
|
@ -489,7 +492,7 @@ func (ib *inmemoryBlock) unmarshalDataPlain(sb *storageBlock, firstItem []byte,
|
||||||
// Unmarshal items data.
|
// Unmarshal items data.
|
||||||
data := ib.data
|
data := ib.data
|
||||||
items := ib.items
|
items := ib.items
|
||||||
data = bytesutil.Resize(data, len(firstItem)+len(sb.itemsData)+len(commonPrefix)*int(itemsCount))
|
data = bytesutil.ResizeNoCopy(data, len(firstItem)+len(sb.itemsData)+len(commonPrefix)*int(itemsCount))
|
||||||
data = append(data[:0], firstItem...)
|
data = append(data[:0], firstItem...)
|
||||||
items = append(items[:0], Item{
|
items = append(items[:0], Item{
|
||||||
Start: 0,
|
Start: 0,
|
||||||
|
|
|
@ -274,7 +274,7 @@ func (ps *partSearch) nextBHS() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ps *partSearch) readIndexBlock(mr *metaindexRow) (*indexBlock, error) {
|
func (ps *partSearch) readIndexBlock(mr *metaindexRow) (*indexBlock, error) {
|
||||||
ps.compressedIndexBuf = bytesutil.Resize(ps.compressedIndexBuf, int(mr.indexBlockSize))
|
ps.compressedIndexBuf = bytesutil.ResizeNoCopy(ps.compressedIndexBuf, int(mr.indexBlockSize))
|
||||||
ps.p.indexFile.MustReadAt(ps.compressedIndexBuf, int64(mr.indexBlockOffset))
|
ps.p.indexFile.MustReadAt(ps.compressedIndexBuf, int64(mr.indexBlockOffset))
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
|
@ -311,10 +311,10 @@ func (ps *partSearch) getInmemoryBlock(bh *blockHeader) (*inmemoryBlock, error)
|
||||||
func (ps *partSearch) readInmemoryBlock(bh *blockHeader) (*inmemoryBlock, error) {
|
func (ps *partSearch) readInmemoryBlock(bh *blockHeader) (*inmemoryBlock, error) {
|
||||||
ps.sb.Reset()
|
ps.sb.Reset()
|
||||||
|
|
||||||
ps.sb.itemsData = bytesutil.Resize(ps.sb.itemsData, int(bh.itemsBlockSize))
|
ps.sb.itemsData = bytesutil.ResizeNoCopy(ps.sb.itemsData, int(bh.itemsBlockSize))
|
||||||
ps.p.itemsFile.MustReadAt(ps.sb.itemsData, int64(bh.itemsBlockOffset))
|
ps.p.itemsFile.MustReadAt(ps.sb.itemsData, int64(bh.itemsBlockOffset))
|
||||||
|
|
||||||
ps.sb.lensData = bytesutil.Resize(ps.sb.lensData, int(bh.lensBlockSize))
|
ps.sb.lensData = bytesutil.ResizeNoCopy(ps.sb.lensData, int(bh.lensBlockSize))
|
||||||
ps.p.lensFile.MustReadAt(ps.sb.lensData, int64(bh.lensBlockOffset))
|
ps.p.lensFile.MustReadAt(ps.sb.lensData, int64(bh.lensBlockOffset))
|
||||||
|
|
||||||
ib := getInmemoryBlock()
|
ib := getInmemoryBlock()
|
||||||
|
|
|
@ -499,7 +499,7 @@ func (q *queue) readBlock(dst []byte) ([]byte, error) {
|
||||||
again:
|
again:
|
||||||
// Read block len.
|
// Read block len.
|
||||||
header := headerBufPool.Get()
|
header := headerBufPool.Get()
|
||||||
header.B = bytesutil.Resize(header.B, 8)
|
header.B = bytesutil.ResizeNoCopy(header.B, 8)
|
||||||
err := q.readFull(header.B)
|
err := q.readFull(header.B)
|
||||||
blockLen := encoding.UnmarshalUint64(header.B)
|
blockLen := encoding.UnmarshalUint64(header.B)
|
||||||
headerBufPool.Put(header)
|
headerBufPool.Put(header)
|
||||||
|
@ -520,7 +520,7 @@ again:
|
||||||
|
|
||||||
// Read block contents.
|
// Read block contents.
|
||||||
dstLen := len(dst)
|
dstLen := len(dst)
|
||||||
dst = bytesutil.Resize(dst, dstLen+int(blockLen))
|
dst = bytesutil.ResizeWithCopy(dst, dstLen+int(blockLen))
|
||||||
if err := q.readFull(dst[dstLen:]); err != nil {
|
if err := q.readFull(dst[dstLen:]); err != nil {
|
||||||
logger.Errorf("skipping corrupted %q, since contents with size %d bytes cannot be read from it: %s", q.readerPath, blockLen, err)
|
logger.Errorf("skipping corrupted %q, since contents with size %d bytes cannot be read from it: %s", q.readerPath, blockLen, err)
|
||||||
if err := q.skipBrokenChunkFile(); err != nil {
|
if err := q.skipBrokenChunkFile(); err != nil {
|
||||||
|
|
|
@ -40,7 +40,7 @@ func ReadLinesBlock(r io.Reader, dstBuf, tailBuf []byte) ([]byte, []byte, error)
|
||||||
func ReadLinesBlockExt(r io.Reader, dstBuf, tailBuf []byte, maxLineLen int) ([]byte, []byte, error) {
|
func ReadLinesBlockExt(r io.Reader, dstBuf, tailBuf []byte, maxLineLen int) ([]byte, []byte, error) {
|
||||||
startTime := time.Now()
|
startTime := time.Now()
|
||||||
if cap(dstBuf) < defaultBlockSize {
|
if cap(dstBuf) < defaultBlockSize {
|
||||||
dstBuf = bytesutil.Resize(dstBuf, defaultBlockSize)
|
dstBuf = bytesutil.ResizeNoCopy(dstBuf, defaultBlockSize)
|
||||||
}
|
}
|
||||||
dstBuf = append(dstBuf[:0], tailBuf...)
|
dstBuf = append(dstBuf[:0], tailBuf...)
|
||||||
tailBuf = tailBuf[:0]
|
tailBuf = tailBuf[:0]
|
||||||
|
@ -79,7 +79,7 @@ again:
|
||||||
if cap(dstBuf) < 2*len(dstBuf) {
|
if cap(dstBuf) < 2*len(dstBuf) {
|
||||||
// Increase dsbBuf capacity, so more data could be read into it.
|
// Increase dsbBuf capacity, so more data could be read into it.
|
||||||
dstBufLen := len(dstBuf)
|
dstBufLen := len(dstBuf)
|
||||||
dstBuf = bytesutil.Resize(dstBuf, 2*cap(dstBuf))
|
dstBuf = bytesutil.ResizeWithCopy(dstBuf, 2*cap(dstBuf))
|
||||||
dstBuf = dstBuf[:dstBufLen]
|
dstBuf = dstBuf[:dstBufLen]
|
||||||
}
|
}
|
||||||
goto again
|
goto again
|
||||||
|
|
|
@ -84,7 +84,7 @@ func ParseStream(req *http.Request, callback func(block *Block) error) error {
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
return fmt.Errorf("too big metricName size; got %d; shouldn't exceed %d", bufSize, 1024*1024)
|
return fmt.Errorf("too big metricName size; got %d; shouldn't exceed %d", bufSize, 1024*1024)
|
||||||
}
|
}
|
||||||
uw.metricNameBuf = bytesutil.Resize(uw.metricNameBuf, int(bufSize))
|
uw.metricNameBuf = bytesutil.ResizeNoCopy(uw.metricNameBuf, int(bufSize))
|
||||||
if _, err := io.ReadFull(br, uw.metricNameBuf); err != nil {
|
if _, err := io.ReadFull(br, uw.metricNameBuf); err != nil {
|
||||||
readErrors.Inc()
|
readErrors.Inc()
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
|
@ -105,7 +105,7 @@ func ParseStream(req *http.Request, callback func(block *Block) error) error {
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
return fmt.Errorf("too big native block size; got %d; shouldn't exceed %d", bufSize, 1024*1024)
|
return fmt.Errorf("too big native block size; got %d; shouldn't exceed %d", bufSize, 1024*1024)
|
||||||
}
|
}
|
||||||
uw.blockBuf = bytesutil.Resize(uw.blockBuf, int(bufSize))
|
uw.blockBuf = bytesutil.ResizeNoCopy(uw.blockBuf, int(bufSize))
|
||||||
if _, err := io.ReadFull(br, uw.blockBuf); err != nil {
|
if _, err := io.ReadFull(br, uw.blockBuf); err != nil {
|
||||||
readErrors.Inc()
|
readErrors.Inc()
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
|
|
|
@ -303,7 +303,7 @@ func (bsr *blockStreamReader) readBlock() error {
|
||||||
if usePrevTimestamps {
|
if usePrevTimestamps {
|
||||||
bsr.Block.timestampsData = append(bsr.Block.timestampsData[:0], bsr.prevTimestampsData...)
|
bsr.Block.timestampsData = append(bsr.Block.timestampsData[:0], bsr.prevTimestampsData...)
|
||||||
} else {
|
} else {
|
||||||
bsr.Block.timestampsData = bytesutil.Resize(bsr.Block.timestampsData, int(bsr.Block.bh.TimestampsBlockSize))
|
bsr.Block.timestampsData = bytesutil.ResizeNoCopy(bsr.Block.timestampsData, int(bsr.Block.bh.TimestampsBlockSize))
|
||||||
if err := fs.ReadFullData(bsr.timestampsReader, bsr.Block.timestampsData); err != nil {
|
if err := fs.ReadFullData(bsr.timestampsReader, bsr.Block.timestampsData); err != nil {
|
||||||
return fmt.Errorf("cannot read timestamps block at offset %d: %w", bsr.timestampsBlockOffset, err)
|
return fmt.Errorf("cannot read timestamps block at offset %d: %w", bsr.timestampsBlockOffset, err)
|
||||||
}
|
}
|
||||||
|
@ -312,7 +312,7 @@ func (bsr *blockStreamReader) readBlock() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read values data.
|
// Read values data.
|
||||||
bsr.Block.valuesData = bytesutil.Resize(bsr.Block.valuesData, int(bsr.Block.bh.ValuesBlockSize))
|
bsr.Block.valuesData = bytesutil.ResizeNoCopy(bsr.Block.valuesData, int(bsr.Block.bh.ValuesBlockSize))
|
||||||
if err := fs.ReadFullData(bsr.valuesReader, bsr.Block.valuesData); err != nil {
|
if err := fs.ReadFullData(bsr.valuesReader, bsr.Block.valuesData); err != nil {
|
||||||
return fmt.Errorf("cannot read values block at offset %d: %w", bsr.valuesBlockOffset, err)
|
return fmt.Errorf("cannot read values block at offset %d: %w", bsr.valuesBlockOffset, err)
|
||||||
}
|
}
|
||||||
|
@ -347,7 +347,7 @@ func (bsr *blockStreamReader) readIndexBlock() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read index block.
|
// Read index block.
|
||||||
bsr.compressedIndexData = bytesutil.Resize(bsr.compressedIndexData, int(bsr.mr.IndexBlockSize))
|
bsr.compressedIndexData = bytesutil.ResizeNoCopy(bsr.compressedIndexData, int(bsr.mr.IndexBlockSize))
|
||||||
if err := fs.ReadFullData(bsr.indexReader, bsr.compressedIndexData); err != nil {
|
if err := fs.ReadFullData(bsr.indexReader, bsr.compressedIndexData); err != nil {
|
||||||
return fmt.Errorf("cannot read index block from index data at offset %d: %w", bsr.indexBlockOffset, err)
|
return fmt.Errorf("cannot read index block from index data at offset %d: %w", bsr.indexBlockOffset, err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -376,8 +376,7 @@ func (mn *MetricName) Marshal(dst []byte) []byte {
|
||||||
tag := &mn.Tags[i]
|
tag := &mn.Tags[i]
|
||||||
requiredSize += len(tag.Key) + len(tag.Value) + 2
|
requiredSize += len(tag.Key) + len(tag.Value) + 2
|
||||||
}
|
}
|
||||||
dst = bytesutil.Resize(dst, requiredSize)
|
dst = bytesutil.ResizeWithCopy(dst, requiredSize)[:dstLen]
|
||||||
dst = dst[:dstLen]
|
|
||||||
|
|
||||||
// Marshal MetricGroup
|
// Marshal MetricGroup
|
||||||
dst = marshalTagValue(dst, mn.MetricGroup)
|
dst = marshalTagValue(dst, mn.MetricGroup)
|
||||||
|
@ -484,7 +483,7 @@ func MarshalMetricNameRaw(dst []byte, labels []prompb.Label) []byte {
|
||||||
dstSize += len(label.Value)
|
dstSize += len(label.Value)
|
||||||
dstSize += 4
|
dstSize += 4
|
||||||
}
|
}
|
||||||
dst = bytesutil.Resize(dst, dstSize)[:dstLen]
|
dst = bytesutil.ResizeWithCopy(dst, dstSize)[:dstLen]
|
||||||
|
|
||||||
// Marshal labels to dst.
|
// Marshal labels to dst.
|
||||||
for i := range labels {
|
for i := range labels {
|
||||||
|
|
|
@ -211,7 +211,7 @@ func skipSmallMetaindexRows(metaindex []metaindexRow, tsid *TSID) []metaindexRow
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ps *partSearch) readIndexBlock(mr *metaindexRow) (*indexBlock, error) {
|
func (ps *partSearch) readIndexBlock(mr *metaindexRow) (*indexBlock, error) {
|
||||||
ps.compressedIndexBuf = bytesutil.Resize(ps.compressedIndexBuf[:0], int(mr.IndexBlockSize))
|
ps.compressedIndexBuf = bytesutil.ResizeNoCopy(ps.compressedIndexBuf, int(mr.IndexBlockSize))
|
||||||
ps.p.indexFile.MustReadAt(ps.compressedIndexBuf, int64(mr.IndexBlockOffset))
|
ps.p.indexFile.MustReadAt(ps.compressedIndexBuf, int64(mr.IndexBlockOffset))
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
|
|
|
@ -75,10 +75,10 @@ func (br *BlockRef) MustReadBlock(dst *Block, fetchData bool) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
dst.timestampsData = bytesutil.Resize(dst.timestampsData[:0], int(br.bh.TimestampsBlockSize))
|
dst.timestampsData = bytesutil.ResizeNoCopy(dst.timestampsData, int(br.bh.TimestampsBlockSize))
|
||||||
br.p.timestampsFile.MustReadAt(dst.timestampsData, int64(br.bh.TimestampsBlockOffset))
|
br.p.timestampsFile.MustReadAt(dst.timestampsData, int64(br.bh.TimestampsBlockOffset))
|
||||||
|
|
||||||
dst.valuesData = bytesutil.Resize(dst.valuesData[:0], int(br.bh.ValuesBlockSize))
|
dst.valuesData = bytesutil.ResizeNoCopy(dst.valuesData, int(br.bh.ValuesBlockSize))
|
||||||
br.p.valuesFile.MustReadAt(dst.valuesData, int64(br.bh.ValuesBlockOffset))
|
br.p.valuesFile.MustReadAt(dst.valuesData, int64(br.bh.ValuesBlockOffset))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue