-
Notifications
You must be signed in to change notification settings - Fork 950
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feature: remote volume driver #1326
feature: remote volume driver #1326
Conversation
604e78b
to
4b21275
Compare
Codecov Report
@@ Coverage Diff @@
## master #1326 +/- ##
==========================================
+ Coverage 17.32% 17.33% +<.01%
==========================================
Files 189 189
Lines 11822 11816 -6
==========================================
Hits 2048 2048
+ Misses 9627 9621 -6
Partials 147 147
|
@@ -76,16 +76,38 @@ func (c *Core) GetVolume(id types.VolumeID) (*types.Volume, error) { | |||
}, | |||
} | |||
|
|||
ctx := driver.Contexts() | |||
|
|||
// first, try to get volume from local store. | |||
obj, err := c.store.Get(id.Name) | |||
if err == nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What will happen if err is not nil and err is not metastore.ErrObjectNotFound
either?
In the code, I think it will ignore this case. Does it make sense? @shaloulcy
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It means the bolt works not well, for example bucket not found, even bolt file deleted. We should throw the out the error. Remote volume metas are also stored in boltdb
storage/volume/core.go
Outdated
} | ||
|
||
// at last, scan all drivers | ||
logrus.Debugf("probing all drivers for volume with name: %s", id.Name) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please remove :
or use logrus.Debugf("probing all drivers for volume with name(%s)", id.Name)
storage/volume/core_util.go
Outdated
return errors.Errorf("Backend driver: %s not found", v.Spec.Backend) | ||
dv, err := driver.Get(v.Spec.Backend) | ||
if err != nil { | ||
return errors.Errorf("Backend driver: %s not found, err: %v", v.Spec.Backend, err) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
("failed to get backend driver %s: %v", v.Spec.Backend, err)?
func (t driverTable) Add(name string, d Driver) { | ||
t[name] = d | ||
// driverTable contains all volume drivers | ||
type driverTable struct { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You could use type SafeMap struct
in package pkg/collect
, instead of declaring a brand new one.
If we use SafeMap, lots of functions could be reduced since they may be duplicated with functions in package collect.
WDYT?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Now driverTable only has a field named drivers except sync.Mutex. In future we may add more fields, like alias drivers
and so on. And the SafeMap may not safisfy my requirements. For example we want add a driver, first we will check whether the driver existed. If not, we add the driver. This action is atomic. Of course, we can change the SafeMap
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In future we may add more fields
You can define like this, I think the following :
type driverTable struct {
sync.Mutex
drivers collect.SafeMap
alias xxxType
}
Yes, of course. We could enhance SafeMap. 😄
storage/volume/driver/proxy.go
Outdated
) | ||
|
||
const ( | ||
remoteVolumeCreateService = "/VolumeDriver.Create" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What is the usage of all the const variables? Could you add a little bit annotation for these?
Since it would be quite hard to understand this part of codes with no guidance.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These const variables is the part of remote volume protocols, I will add more annotations
|
||
var resp remoteVolumeCreateResp | ||
|
||
if err := proxy.client.CallService(remoteVolumeCreateService, &req, &resp, true); err != nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am wondering if we could change the function, just making the response in the returned value, instead of passing a pointer of resp in parameter? Does it to meed some particular demand?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To simplize the caller logic. Return io.Reader?
} | ||
} | ||
|
||
func buildVolumeConfig(options map[string]string) (*VolumeConfig, error) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we could add some unit test for this file.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
agree it
Is there any way to add some integration test? @shaloulcy |
@allencloud I think we can add some integration tests using the local-persist volume driver |
Signed-off-by: Eric Li <lcy041536@gmail.com>
modify some logging and add more annotations. I will add more unit-tests and integration tests in other pull requests |
LGTM |
LGTM |
commit 75aab2b Merge: 5c8993b 2f2e9c1 Author: Starnop <starnop@163.com> Date: Sat May 19 21:51:30 2018 +0800 Merge branch 'cri-compatibility' of github.com:Starnop/pouch into cri-compatibility commit 2f2e9c1 Merge: bd9c4fd acbd19a Author: Starnop <starnop@163.com> Date: Fri May 18 15:32:31 2018 +0800 Merge branch 'master' of https://github.com/alibaba/pouch into cri-compatibility commit acbd19a Merge: 6cef601 8e862f9 Author: Yao Zengzeng <yaozengzeng@zju.edu.cn> Date: Fri May 18 15:27:01 2018 +0800 Merge pull request AliyunContainerService#1351 from fuweid/feature_allow_use_image_by_digest_id feature: allow use image by digest id commit 6cef601 Merge: 4423313 caf45ec Author: Wei Fu <fhfuwei@163.com> Date: Fri May 18 15:10:30 2018 +0800 Merge pull request AliyunContainerService#1350 from Ace-Tang/version build: generate version information at build time commit caf45ec Author: Ace-Tang <aceapril@126.com> Date: Fri May 18 13:31:25 2018 +0800 build: generate version information at build time auto-generate git commit, build time at build time, fix go-version hard code. Signed-off-by: Ace-Tang <aceapril@126.com> commit 8e862f9 Author: Wei Fu <fhfuwei@163.com> Date: Fri May 18 13:50:42 2018 +0800 feature: allow use image by digest id Basically, the user can use sha256:xyz to inspect image or run container. Signed-off-by: Wei Fu <fhfuwei@163.com> commit 4423313 Merge: 8410064 f67cf08 Author: Allen Sun <shlallen1990@gmail.com> Date: Fri May 18 11:44:39 2018 +0800 Merge pull request AliyunContainerService#1326 from shaloulcy/core_volume feature: remote volume driver commit 8410064 Merge: 8af60a9 852d4f4 Author: Wei Fu <fhfuwei@163.com> Date: Fri May 18 10:39:15 2018 +0800 Merge pull request AliyunContainerService#1339 from rhinoceros/master docs: Update INSTALLATION.md apt-key fingerprint BE2F475F commit f67cf08 Author: Eric Li <lcy041536@gmail.com> Date: Mon May 14 12:19:46 2018 +0800 feature: remote volume driver Signed-off-by: Eric Li <lcy041536@gmail.com> commit bd9c4fd Merge: 8d01e30 521ca7c Author: Starnop <starnop@163.com> Date: Thu May 17 11:11:40 2018 +0800 Merge branch 'master' of https://github.com/alibaba/pouch into cri-compatibility commit 8af60a9 Merge: ecbe3b6 13a17b5 Author: Allen Sun <shlallen1990@gmail.com> Date: Fri May 18 09:43:40 2018 +0800 Merge pull request AliyunContainerService#1349 from pouchrobot/auto-doc-2018-05-18 docs: auto generate pouch cli/api docs via code commit 13a17b5 Author: pouchrobot <pouch-dev@list.alibaba-inc.com> Date: Fri May 18 01:28:51 2018 +0000 docs: auto generate pouch cli docs via code Signed-off-by: pouchrobot <pouch-dev@list.alibaba-inc.com> commit 5c8993b Merge: 8d01e30 521ca7c Author: Starnop <starnop@163.com> Date: Thu May 17 11:11:40 2018 +0800 Merge branch 'master' of https://github.com/alibaba/pouch into cri-compatibility commit ecbe3b6 Merge: 3374daf 7fc11df Author: Wei Fu <fhfuwei@163.com> Date: Thu May 17 18:53:20 2018 +0800 Merge pull request AliyunContainerService#1227 from Ace-Tang/full_spec_params feature: add pidslimit implement commit 7fc11df Author: Ace-Tang <aceapril@126.com> Date: Fri May 11 16:25:32 2018 +0800 feature: add pidslimit implement Signed-off-by: Ace-Tang <aceapril@126.com> commit 3374daf Merge: 89a5ae5 fd8e0f7 Author: Allen Sun <shlallen1990@gmail.com> Date: Thu May 17 13:44:52 2018 +0800 Merge pull request AliyunContainerService#1341 from Letty5411/0517-assertfix test: enhance cli related tests commit 89a5ae5 Merge: 521ca7c 8469cea Author: Wei Fu <fhfuwei@163.com> Date: Thu May 17 13:17:47 2018 +0800 Merge pull request AliyunContainerService#1331 from Letty5411/0516-doc doc: update test.md about how to run test commit fd8e0f7 Author: letty <letty.ll@alibaba-inc.com> Date: Thu May 17 11:23:16 2018 +0800 test: enhance test Signed-off-by: letty <letty.ll@alibaba-inc.com> commit 521ca7c Merge: 19c956b 6b2a8b4 Author: Yao Zengzeng <yaozengzeng@zju.edu.cn> Date: Thu May 17 10:39:06 2018 +0800 Merge pull request AliyunContainerService#1340 from ZouRui89/race_off bugfix: move IO part behind to ensure execConfig result assignment before IO closes commit 6b2a8b4 Author: Zou Rui <21751189@zju.edu.cn> Date: Wed May 16 18:03:27 2018 +0800 bugfix: move IO part behind to ensure execConfig result assignment before IO closes Signed-off-by: Zou Rui <21751189@zju.edu.cn> commit 8d01e30 Merge: 9339a70 19c956b Author: Starnop <starnop@163.com> Date: Wed May 16 12:57:14 2018 +0800 Merge branch 'master' of https://github.com/alibaba/pouch into cri-compatibility commit 852d4f4 Author: rhinoceros.xn <rhinoceros.xn@gmail.com> Date: Wed May 16 17:37:51 2018 +0800 Update INSTALLATION.md $ apt-key fingerprint BE2F475F pub 4096R/BE2F475F 2018-02-28 Key fingerprint = F443 EDD0 4A58 7E8B F645 9C40 CF68 F84A BE2F 475F uid opsx-admin <opsx@service.alibaba.com> commit 8469cea Author: letty <letty.ll@alibaba-inc.com> Date: Wed May 16 10:08:32 2018 +0800 doc: update test.md about how to run test Signed-off-by: letty <letty.ll@alibaba-inc.com> commit 9339a70 Author: Starnop <starnop@163.com> Date: Tue May 15 17:35:53 2018 +0800 cri com and up
Signed-off-by: Eric Li lcy041536@gmail.com
Ⅰ. Describe what this PR did
Now pouch only supports local/tempfs/ceph volumes. Docker can support more volumes with the help of volume plugin mechanism. In this PR,we implement remote volume driver, which also use volume plugin mechanism. Pouch volume plugin is compatible with docker, So we can use existing mature docker volumes drivers.
Ⅱ. Does this pull request fix one issue?
NONE
Ⅲ. Describe how you did it
Ⅳ. Describe how to verify it
1. install local-persist volume plugin
After start the local-persist volume plugin, it will create local-persist.sock in
/run/docker/plugins/
2. create a local-persist volume
3. run container with the volume
the volume Status has a ref filed, which is the container id
4. remove container and volume
Ⅴ. Special notes for reviews