1
0
mirror of https://github.com/minio/minio.git synced 2025-01-24 21:23:15 -05:00

11 Commits

Author SHA1 Message Date
Harshavardhana
65f34cd823
fix: remove ODirectReader entirely since we do not need it anymore () 2023-12-09 10:17:51 -08:00
Klaus Post
e8c0a50862
optimization use small blocks up to 64KB () 2023-05-01 09:47:49 -07:00
Klaus Post
6a04067514
fix: tweak read buffer size to reduce over-reading () 2023-01-01 08:14:20 -08:00
Klaus Post
ac055b09e9
Add detailed scanner metrics () 2022-07-05 14:45:49 -07:00
Harshavardhana
5a9f133491
speed up startup sequence for all operations ()
This speed-up is intended for faster startup times
for almost all MinIO operations. Changes here are

- Drives are not re-read for 'format.json' on a regular
  basis once read during init is remembered and refreshed
  at 5 second intervals.

- Do not do O_DIRECT tests on drives with existing 'format.json'
  only fresh setups need this check.

- Parallelize initializing erasureSets for multiple sets.

- Avoid re-reading format.json when migrating 'format.json'
  from really old V1->V2->V3

- Keep a copy of local drives for any given server in memory
  for a quick lookup.
2022-01-24 11:28:45 -08:00
Harshavardhana
f527c708f2
run gofumpt cleanup across code-base () 2022-01-02 09:15:06 -08:00
Harshavardhana
9c5d9ae376
fallback O_DIRECT if not supported, do regular reads() () 2021-11-17 15:48:47 -08:00
Harshavardhana
d00ff3c453
use O_DIRECT for all ReadFileStream ()
This PR also removes  to ensure
that we can use a better mechanism to
handle page-cache, using O_DIRECT
even for Range GETs.
2021-09-29 16:40:28 -07:00
Harshavardhana
38027c8f52
use fadvise to control Linux page-cache ()
This PR brings two optimizations mainly
for page-cache build-up and how to avoid
getting OOM killed in the process. Although
these memories are reclaimable Linux is not
fast enough to reclaim them as needed on a
very busy system. fadvise is a system call
implemented in Linux to advise page-cache to
avoid overload as we get significant amount
of requests on the server.

- FADV_SEQUENTIAL tells that all I/O from now
  is going to be sequential, allowing for more
  resposive throughput.

- FADV_NOREUSE tells kernel to start removing
  things for this 'fd' from page-cache.
2021-09-28 10:02:56 -07:00
Klaus Post
470553ff5d
Tweak readall allocation and renameData buffer reuse ()
Use a single allocation for reading the file, not the growing buffer of `io.ReadAll`.

Reuse the write buffer if we can when writing metadata in RenameData.
2021-08-30 08:38:11 -07:00
Harshavardhana
1f262daf6f
rename all remaining packages to internal/ ()
This is to ensure that there are no projects
that try to import `minio/minio/pkg` into
their own repo. Any such common packages should
go to `https://github.com/minio/pkg`
2021-06-01 14:59:40 -07:00