-
-
Notifications
You must be signed in to change notification settings - Fork 598
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
Plugins defined in databag do not get installed #89
Comments
@Pneumatus Hi, verified this issue in Vagrant with a Can you use a different mechanism to specify plugins?, eg. role override or node attributes? I'll keep this issue open to investigate it further. |
@karmi I've swapped back to using role overrides for now and look forward to a resolution. Cheers. |
@Pneumatus Cool. I'm wondering if exposing the plugins list via data bag is a good idea after all, because of higher chance of problems like this. It makes sense to me to support the |
@karmi For us at least, having the plugins configured in a databag means we can do all of our environment specific configuration via databags rather than being able to do some in databags and some in environment overrides. Arguably we could do it all in environment overrides if we wanted (and not use databags at all) if we wanted to keep everything in the same place but I really don't like using environment overrides unless the attributes are for use universally across the environment (like, chef-server URL). |
Agreed. Talked about it to @vhyza, and the current situation is a bit too crazy. I think it makes sense to expose:
|
@karmi I think i have found a bug in the plugins.rb recipe. It looks like it always just goes to next b/c of the aws check. Attempting to fix now, if I can get it all to work I'll create a pull request. I am using the plugins.json data bag and that is working well, couldn't get the plugins attribute to work in the settings.json - just FYI. |
additional FYI.. I am using chef 11. |
It seems to me that the aws recipe check shouldn't be there, since we should only install that plugin when the elasticsearch::aws recipe is used. If we find that plugin in the plugins.rb we should just ignore all together and not check for the recipe - since it doesn't really matter. Please let me know if this logic makes sense or if there is a use case for having this logic. Thanks! |
Okay, so found the issue here. And i now understand the need for the aws check, even though it could be done differently. Problem is how the specified plugins are added to the default.elasticsearch.plugins field. I'll create a pull request so that we can get this issue resolved. |
@karmi Hey Karel - I was hoping we could get this merged soon, or adjusted to work best for you guys. I'd like to not have to rely on my branch, which will not be merged from upstream consistently. Any help would be greatly appreciated, willing to help iron out any problems with the pull request. Thanks for your time/help! |
@NickPadilla Thanks for pinging me, left a note at #150 -- just notice above that in an ideal world where we have all the time we need, I'd refactor the support a bit, and move plugins into the |
Hey all, this should be fixed. If anyone would like to have the plugins specified in the elasticsearch/settings databag then it would be helpful to add that functionality. Right now it works to use the plugins databag. |
Could we have this added to the README.md? Right now I'm unable to get this to work because I don't understand the directory structure. ie: $ cat data_bags/elasticsearch/plugins.json
{
"id": "plugins",
"elasticsearch": {
"plugins": {
"karmi/elasticsearch-paramedic": {},
"mobz/elasticsearch-head": {},
"lukas-vlcek/bigdesk": { "version": "2.0.0" },
"elasticsearch-cloud-aws": { "version": "1.10.0" }
}
}
} I'm chef solo with a role like the following: "recipe[elasticsearch]",
"recipe[elasticsearch::plugins]" And I'm able to make this work using a wrapper recipe and the following overrides, but I'd prefer if I could just throw a databag item in there and not have the extra overhead of another recipe: override[:elasticsearch][:plugins] = {"mobz/elasticsearch-head" => ""} etc etc. |
Hello! It sounds like you were able to get this working. In the meantime, we've re-written the cookbook using libraries that expose resources and providers, so you shouldn't see this problem on the newer version. Hope this helps! |
Initially I had been installing plugins via the elasticsearch::plugin recipe with attributes set at role level but have attempted to transition these to a databag. I've created a databag containing:
The only plugin that gets installed is the 'cloud-aws' plugin (but with the wrong version - 1.11.0 which it appears to get from the attributes/aws.rb). Running chef-client with logging set to debug shows
DEBUG: Plugins list: ["karmi/elasticsearch-paramedic", "mobz/elasticsearch-head", "lukas-vlcek/bigdesk", "elasticsearch-cloud-aws"]
but they do not appear to be converged into node attributes correctly.
The text was updated successfully, but these errors were encountered: