pkg/api: use a rwlock when accessing storage
The original patch used a mutex, however, the workload patterns are likely to be read-heavy, so use a rwlock instead.
This commit is contained in:
parent
2fd87b6a86
commit
dfe023225f
@ -1362,8 +1362,8 @@ go_repository(
|
||||
go_repository(
|
||||
name = "com_github_opensuse_umoci",
|
||||
importpath = "github.com/openSUSE/umoci",
|
||||
sum = "h1:MZgFLy5Jl3VKe5uEOU9c25FoySbx3vUXeXLw4Jf6aRs=",
|
||||
version = "v0.4.5",
|
||||
sum = "h1:/8Yu54FufyHHQgIZ/wLy+BLQyzk0gbOG24xf5suWOOI=",
|
||||
version = "v0.4.6-0.20200320140503-9aa268eeb258",
|
||||
)
|
||||
|
||||
go_repository(
|
||||
|
@ -53,7 +53,8 @@ func NewRouteHandler(c *Controller) *RouteHandler {
|
||||
}
|
||||
|
||||
// blobRLockWrapper calls the real handler with read-lock held
|
||||
func (rh *RouteHandler) blobRLockWrapper(f func(w http.ResponseWriter, r *http.Request)) func(w http.ResponseWriter, r *http.Request) {
|
||||
func (rh *RouteHandler) blobRLockWrapper(f func(w http.ResponseWriter,
|
||||
r *http.Request)) func(w http.ResponseWriter, r *http.Request) {
|
||||
return func(w http.ResponseWriter, r *http.Request) {
|
||||
rh.blobLock.RLock()
|
||||
f(w, r)
|
||||
@ -62,7 +63,8 @@ func (rh *RouteHandler) blobRLockWrapper(f func(w http.ResponseWriter, r *http.R
|
||||
}
|
||||
|
||||
// blobLockWrapper calls the real handler with write-lock held
|
||||
func (rh *RouteHandler) blobLockWrapper(f func(w http.ResponseWriter, r *http.Request)) func(w http.ResponseWriter, r *http.Request) {
|
||||
func (rh *RouteHandler) blobLockWrapper(f func(w http.ResponseWriter,
|
||||
r *http.Request)) func(w http.ResponseWriter, r *http.Request) {
|
||||
return func(w http.ResponseWriter, r *http.Request) {
|
||||
rh.blobLock.Lock()
|
||||
f(w, r)
|
||||
|
@ -148,7 +148,6 @@ func TestAPIs(t *testing.T) {
|
||||
_, _, _, err = il.GetImageManifest("test", d.String())
|
||||
So(err, ShouldNotBeNil)
|
||||
})
|
||||
|
||||
})
|
||||
|
||||
err = il.DeleteBlobUpload("test", v)
|
||||
|
Loading…
Reference in New Issue
Block a user