Go to file
Michal Niewrzal 0eaf43120b satellite/repair/checker: optimize processing, part 3
ClassifySegmentPieces uses custom set implementation instead map.

Side note, for custom set implementation I also checked int8 bit set but
it didn't give better performance so I used simpler implementation.

Benchmark results (compared against part 2 optimization change):
name                                       old time/op    new time/op    delta
RemoteSegment/healthy_segment-8    21.7µs ± 8%    15.4µs ±16%  -29.38%  (p=0.008 n=5+5)

name                                       old alloc/op   new alloc/op   delta
RemoteSegment/healthy_segment-8    7.41kB ± 0%    1.87kB ± 0%  -74.83%  (p=0.000 n=5+4)

name                                       old allocs/op  new allocs/op  delta
RemoteSegment/healthy_segment-8       150 ± 0%       130 ± 0%  -13.33%  (p=0.008 n=5+5)

Change-Id: I21feca9ec6ac0a2558ac5ce8894451c54f69e52d
2023-10-16 12:06:16 +00:00
.github .github: remove invalid codeowners 2022-11-10 15:52:48 +02:00
certificate private/kvstore: move storage package 2023-04-06 17:26:29 +03:00
cmd cmd/satellite/main: complete/fail pending payments cmd 2023-10-06 01:23:34 +00:00
crashcollect crashcollect: removed redundant structure 2021-04-28 00:35:39 +03:00
docs docs/testplan: Adding a testplan for GE revamp (#6355) 2023-10-02 16:56:09 +02:00
installer/windows storj/storj: more domain changes 2021-04-15 20:51:43 +00:00
multinode satellite/satellitedb,multinode/multinodedb: update to latest dbx 2023-09-11 17:21:02 +00:00
private private/apigen: Validate param types 2023-10-10 12:37:20 +00:00
resources cmd: add ca-certificates to Docker images (#3986) 2020-12-08 01:38:33 +01:00
satellite satellite/repair/checker: optimize processing, part 3 2023-10-16 12:06:16 +00:00
scripts satellite/console: make Etherscan URL more configurable 2023-10-14 01:58:43 +00:00
storagenode storagenode/orders: archive unsent order for untrusted satellite 2023-10-12 13:48:07 +00:00
testsuite go.mod: update storj.io/common 2023-10-05 15:52:06 +00:00
versioncontrol versioncontrol: implement partial version rollout automation 2023-06-02 16:01:33 +00:00
web web/satellite: fix object count calculation inside folders 2023-10-13 12:27:58 +00:00
.dockerignore Forward-port release-alpha8 build script issues (#1726) 2019-04-09 23:01:10 -06:00
.earthlyignore build: provides earthfile for nightly build 2022-10-27 09:25:17 +00:00
.gitattributes web/: add check for change to eslint import 2021-12-21 15:59:23 +00:00
.gitignore gitignore: add go workspace files 2022-12-13 10:15:53 -07:00
.gitreview add config file for git review usage 2021-10-14 18:01:30 +00:00
CODE_OF_CONDUCT.md Adding CODE_OF_CONDUCT to storj/storj repo (#779) 2018-12-07 15:10:02 -05:00
CODEOWNERS update CODEOWNERS 2023-02-02 10:01:50 +00:00
CONTRIBUTING.md go.mod: update to minimum supported go version (#4239) 2021-10-22 21:12:13 +02:00
DEVELOPING.md Makefile: run lint locally in docker 2022-05-25 12:30:15 -05:00
docker-compose.tests.yaml Makefile: disable postgres fsync in the test container 2022-12-01 22:03:31 +00:00
Earthfile Earthfile: Use same NodeJS version as Makefile 2023-10-16 08:04:21 +00:00
go.mod go.mod: update storj.io/common 2023-10-05 15:52:06 +00:00
go.sum go.mod: update storj.io/common 2023-10-05 15:52:06 +00:00
Jenkinsfile {Jenkinsfile, Makefile}: update Go to 1.21.3 2023-10-11 10:47:04 +02:00
Jenkinsfile.premerge ci: move go-licenses check to premerge 2023-03-20 09:20:28 +00:00
Jenkinsfile.public private/kvstore: move storage package 2023-04-06 17:26:29 +03:00
Jenkinsfile.verify satellite/console/consoleweb/consoleapi: fix defer in loop 2023-10-05 12:55:36 +03:00
LICENSE license code with agplv3 (#126) 2018-07-05 10:24:26 -04:00
MAINTAINERS.md Maintainers: remove link 2022-03-14 14:16:31 +02:00
Makefile {Jenkinsfile, Makefile}: update Go to 1.21.3 2023-10-11 10:47:04 +02:00
monkit.lock satellite/repair: unify repair logic 2023-09-25 09:42:08 -05:00
proto.lock certificate/certificatepb: add definitions for migration 2023-01-25 10:28:36 +02:00
README.md Update logo in README.md (#6354) 2023-09-28 19:44:11 +02:00

Storj V3 Network

Go Report Card Go Doc Coverage Status

Storj logo

Storj is building a distributed cloud storage network. Check out our white paper for more info!


Storj is an S3-compatible platform and suite of distributed applications that allows you to store data in a secure and distributed manner. Your files are encrypted, broken into little pieces and stored in a global distributed network of computers. Luckily, we also support allowing you (and only you) to retrieve those files!

Table of Contents

Contributing to Storj

All of our code for Storj v3 is open source. If anything feels off, or if you feel that some functionality is missing, please check out the contributing page. There you will find instructions for sharing your feedback, building the tool locally, and submitting pull requests to the project.

A Note about Versioning

While we are practicing semantic versioning for our client libraries such as uplink, we are not practicing semantic versioning in this repo, as we do not intend for it to be used via Go modules. We may have backwards-incompatible changes between minor and patch releases in this repo.

Start using Storj

Our wiki has documentation and tutorials. Check out these three tutorials:

License

This repository is currently licensed with the AGPLv3 license.

For code released under the AGPLv3, we request that contributors sign our Contributor License Agreement (CLA) so that we can relicense the code under Apache v2, or other licenses in the future.

Support

If you have any questions or suggestions please reach out to us on our community forum or file a ticket at https://support.storj.io/.